]> git.sur5r.net Git - i3/i3status/blobdiff - Makefile
Treat the interface as 'down' when it cannot be found in /proc/net/wireless (Thanks...
[i3/i3status] / Makefile
index 0cb662af320723a1e4a12c1cd30ed81d2a08c103..9f61eef9f75d69b6734e6ada53dad47448d901c1 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,30 +1,70 @@
-CFLAGS+=-Wall -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations -Wshadow -Wpointer-arith -Wcast-qual -Wsign-compare
+CFLAGS+=-Wall -Wshadow -Wpointer-arith -Wcast-qual -Wsign-compare
 CFLAGS+=-g
+CFLAGS+=-std=gnu99
+CFLAGS+=-pedantic
 CFLAGS+=-DPREFIX=\"\"
+CFLAGS+=-I.
+LDFLAGS+=-lconfuse
+
+VERSION=$(shell git describe --tags --abbrev=0)
 
 ifeq ($(shell uname),Linux)
 CFLAGS+=-DLINUX
+CFLAGS+=-D_GNU_SOURCE
+LDFLAGS+=-liw
+endif
+
+ifeq ($(shell uname),GNU/kFreeBSD)
+CFLAGS+=-lbsd
 endif
 
-wmiistatus: wmiistatus.o wmiistatus.h config.h config.o
+# Define this if you want i3status to spit out dzen2-compatible output on stdout
+#CFLAGS+=-DDZEN
+CFLAGS+=$(EXTRA_CFLAGS)
+
+OBJS:=$(wildcard src/*.c *.c)
+OBJS:=$(OBJS:.c=.o)
+
+src/%.o: src/%.c
+       @$(CC) $(CFLAGS) -c -o $@ $<
+       @echo " CC $<"
+
+%.o: %.c %.h
+       @$(CC) $(CFLAGS) -c -o $@ $<
+       @echo " CC $<"
+
+all: i3status manpage
+
+i3status: ${OBJS}
+       @$(CC) -o $@ src/*.o *.o $(LDFLAGS)
+       @echo " LD $@"
 
 clean:
-       rm -f *.o
+       rm -f *.o src/*.o
 
 distclean: clean
-       rm -f wmiistatus
+       rm -f i3status
+
+manpage:
+       make -C man
 
 install:
        install -m 755 -d $(DESTDIR)/usr/bin
-       install -m 755 -d $(DESTDIR)/etc/init.d
+       install -m 755 -d $(DESTDIR)/etc
        install -m 755 -d $(DESTDIR)/usr/share/man/man1
-       install -m 755 wmiistatus $(DESTDIR)/usr/bin/wmiistatus
-       install -m 755 wmiistatus.init $(DESTDIR)/etc/init.d/wmiistatus
-       install -m 644 wmiistatus.conf $(DESTDIR)/etc/wmiistatus.conf
-       install -m 644 wmiistatus.1 $(DESTDIR)/usr/share/man/man1
+       install -m 755 i3status $(DESTDIR)/usr/bin/i3status
+       # Allow network configuration for getting the link speed
+       (which setcap && setcap cap_net_admin=ep $(DESTDIR)/usr/bin/i3status) || true
+       install -m 644 i3status.conf $(DESTDIR)/etc/i3status.conf
+       install -m 644 man/i3status.1 $(DESTDIR)/usr/share/man/man1
 
 release:
-       tar cf wmiistatus.tar *.c *.h *.1 *.conf *.init Makefile
-       bzip2 -9 wmiistatus.tar
-
-all: wmiistatus
+       [ -f i3status-${VERSION} ] || rm -rf i3status-${VERSION}
+       mkdir i3status-${VERSION}
+       find . -maxdepth 1 -type f \( -regex ".*\.\(c\|conf\|h\)" -or -name "Makefile" -or -name "LICENSE" \) -exec cp '{}' i3status-${VERSION} \;
+       mkdir i3status-${VERSION}/src
+       mkdir i3status-${VERSION}/man
+       find src -maxdepth 1 -type f \( -regex ".*\.\(c\|h\)" \) -exec cp '{}' i3status-${VERSION}/src \;
+       find man -maxdepth 1 -type f \( -regex ".*\.\(1\|man\|conf\)" -or -name "Makefile" \) -exec cp '{}' i3status-${VERSION}/man \;
+       tar cjf i3status-${VERSION}.tar.bz2 i3status-${VERSION}
+       rm -rf i3status-${VERSION}