X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=Makefile;h=1ab8b42d1bb615f8a5f8b0bf9ce5ba8376096544;hb=86e86adccae57acf7249583cdf94313fd242bb5a;hp=883bcdd15918bd826faf525332b16b654ae8bc28;hpb=d31f2ce0bec276d54c2a2cfe70c2764aee4503d8;p=i3%2Fi3status diff --git a/Makefile b/Makefile index 883bcdd..1ab8b42 100644 --- a/Makefile +++ b/Makefile @@ -1,42 +1,65 @@ +ifndef PREFIX + PREFIX=/usr +endif +ifndef SYSCONFDIR + ifeq ($(PREFIX),/usr) + SYSCONFDIR=/etc + else + SYSCONFDIR=$(PREFIX)/etc + endif +endif + CFLAGS+=-Wall -Wshadow -Wpointer-arith -Wcast-qual -Wsign-compare CFLAGS+=-g CFLAGS+=-std=gnu99 CFLAGS+=-pedantic -CFLAGS+=-DPREFIX=\"\" -CFLAGS+=-I. -LDFLAGS+=-lconfuse +CPPFLAGS+=-DSYSCONFDIR=\"$(SYSCONFDIR)\" +CPPFLAGS+=-DVERSION=\"${GIT_VERSION}\" +CFLAGS+=-Iinclude +LIBS+=-lconfuse +LIBS+=-lyajl -VERSION=$(shell git describe --tags --abbrev=0) +VERSION:=$(shell git describe --tags --abbrev=0) +GIT_VERSION:="$(shell git describe --tags --always) ($(shell git log --pretty=format:%cd --date=short -n1))" ifeq ($(shell uname),Linux) -CFLAGS+=-DLINUX -CFLAGS+=-D_GNU_SOURCE -LDFLAGS+=-liw +CPPFLAGS+=-DLINUX +CPPFLAGS+=-D_GNU_SOURCE +LIBS+=-liw +LIBS+=-lasound endif ifeq ($(shell uname),GNU/kFreeBSD) -CFLAGS+=-lbsd +LIBS+=-lbsd +endif + +ifeq ($(shell uname),OpenBSD) +CFLAGS+=-I/usr/local/include/ +LDFLAGS+=-L/usr/local/lib/ +LIBS+=-lossaudio endif -# Define this if you want i3status to spit out dzen2-compatible output on stdout -#CFLAGS+=-DDZEN CFLAGS+=$(EXTRA_CFLAGS) +# Fallback for libyajl 1 which did not include yajl_version.h. We need +# YAJL_MAJOR from that file to decide which code path should be used. +CFLAGS += -idirafter yajl-fallback + OBJS:=$(wildcard src/*.c *.c) OBJS:=$(OBJS:.c=.o) src/%.o: src/%.c - @$(CC) $(CFLAGS) -c -o $@ $< + @$(CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $< @echo " CC $<" -%.o: %.c %.h - @$(CC) $(CFLAGS) -c -o $@ $< +%.o: %.c include/%.h + @$(CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $< @echo " CC $<" all: i3status manpage i3status: ${OBJS} - @$(CC) -o $@ src/*.o *.o $(LDFLAGS) + @$(CC) $(LDFLAGS) -o $@ $^ $(LIBS) @echo " LD $@" clean: @@ -46,17 +69,17 @@ distclean: clean rm -f i3status manpage: - make -C man + $(MAKE) -C man install: - install -m 755 -d $(DESTDIR)/usr/bin - install -m 755 -d $(DESTDIR)/etc - install -m 755 -d $(DESTDIR)/usr/share/man/man1 - install -m 755 i3status $(DESTDIR)/usr/bin/i3status + install -m 755 -d $(DESTDIR)$(PREFIX)/bin + install -m 755 -d $(DESTDIR)$(SYSCONFDIR) + install -m 755 -d $(DESTDIR)$(PREFIX)/share/man/man1 + install -m 755 i3status $(DESTDIR)$(PREFIX)/bin/i3status # Allow network configuration for getting the link speed - which setcap && setcap cap_net_admin=ep $(DESTDIR)/usr/bin/i3status - install -m 644 i3status.conf $(DESTDIR)/etc/i3status.conf - install -m 644 man/i3status.1 $(DESTDIR)/usr/share/man/man1 + (which setcap && setcap cap_net_admin=ep $(DESTDIR)$(PREFIX)/bin/i3status) || true + install -m 644 i3status.conf $(DESTDIR)$(SYSCONFDIR)/i3status.conf + install -m 644 man/i3status.1 $(DESTDIR)$(PREFIX)/share/man/man1 release: [ -f i3status-${VERSION} ] || rm -rf i3status-${VERSION} @@ -66,5 +89,7 @@ release: 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 \; + cp -r include i3status-${VERSION} + sed -e 's/^GIT_VERSION:=\(.*\)/GIT_VERSION=${GIT_VERSION}/g;s/^VERSION:=\(.*\)/VERSION=${VERSION}/g' Makefile > i3status-${VERSION}/Makefile tar cjf i3status-${VERSION}.tar.bz2 i3status-${VERSION} rm -rf i3status-${VERSION}