X-Git-Url: https://git.xinqibao.xyz/slstatus.git/blobdiff_plain/94ea78f0fe394fc6b42dc0d83be9abf3d1c77ea0..11d4bec6481886abb889cbeded5c8f52e5dfd844:/Makefile?ds=inline diff --git a/Makefile b/Makefile index f31d1c7..d690612 100644 --- a/Makefile +++ b/Makefile @@ -1,49 +1,83 @@ -# See LICENSE file for copyright and license details. +# See LICENSE file for copyright and license details +# slstatus - suckless status monitor +.POSIX: include config.mk -SRC = ${NAME}.c -OBJ = ${SRC:.c=.o} +REQ = util +HDR = arg.h +COM =\ + battery\ + cpu\ + datetime\ + disk\ + entropy\ + hostname\ + ip\ + kernel_release\ + keyboard_indicators\ + load_avg\ + num_files\ + ram\ + run_command\ + swap\ + temperature\ + uptime\ + user\ + volume\ + wifi -all: options ${NAME} +all: slstatus -options: - @echo ${NAME} build options: - @echo "CFLAGS = ${CFLAGS}" - @echo "LDFLAGS = ${LDFLAGS}" - @echo "CC = ${CC}" +slstatus: slstatus.o $(COM:=.o) $(REQ:=.o) +slstatus.o: slstatus.c slstatus.h $(HDR) $(REQ:=.h) -.c.o: - @echo CC $< - @${CC} -c ${CFLAGS} $< +battery.o: battery.c config.mk $(HDR) $(REQ:=.h) +cpu.o: cpu.c config.mk $(HDR) $(REQ:=.h) +datetime.o: datetime.c config.mk $(HDR) $(REQ:=.h) +disk.o: disk.c config.mk $(HDR) $(REQ:=.h) +entropy.o: entropy.c config.mk $(HDR) $(REQ:=.h) +hostname.o: hostname.c config.mk $(HDR) $(REQ:=.h) +ip.o: ip.c config.mk $(HDR) $(REQ:=.h) +kernel_release.o: kernel_release.c config.mk $(HDR) $(REQ:=.h) +keyboard_indicators.o: keyboard_indicators.c config.mk $(HDR) $(REQ:=.h) +load_avg.o: load_avg.c config.mk $(HDR) $(REQ:=.h) +num_files.o: num_files.c config.mk $(HDR) $(REQ:=.h) +ram.o: ram.c config.mk $(HDR) $(REQ:=.h) +run_command.o: run_command.c config.mk $(HDR) $(REQ:=.h) +swap.o: swap.c config.mk $(HDR) $(REQ:=.h) +temperature.o: temperature.c config.mk $(HDR) $(REQ:=.h) +uptime.o: uptime.c config.mk $(HDR) $(REQ:=.h) +user.o: user.c config.mk $(HDR) $(REQ:=.h) +volume.o: volume.c config.mk $(HDR) $(REQ:=.h) +wifi.o: wifi.c config.mk $(HDR) $(REQ:=.h) -${OBJ}: config.mk +.o: + $(CC) -o $@ $(LDFLAGS) $< $(COM:=.o) $(REQ:=.o) $(LDLIBS) -${NAME}: ${OBJ} - @echo CC -o $@ - @${CC} -o $@ ${OBJ} ${LDFLAGS} +.c.o: + $(CC) -c $(CPPFLAGS) $(CFLAGS) $< clean: - @echo cleaning - @rm -f ${NAME} ${OBJ} ${NAME}-${VERSION}.tar.gz - -dist: clean - @echo creating dist tarball - @mkdir -p ${NAME}-${VERSION} - @cp -R Makefile config.mk LICENSE \ - ${SRC} ${NAME}-${VERSION} - @tar -cf ${NAME}-${VERSION}.tar ${NAME}-${VERSION} - @gzip ${NAME}-${VERSION}.tar - @rm -rf ${NAME}-${VERSION} + rm -f slstatus slstatus.o $(COM:=.o) $(REQ:=.o) + +dist: + rm -rf "slstatus-$(VERSION)" + mkdir -p "slstatus-$(VERSION)" + cp -R LICENSE Makefile README config.mk config.def.h \ + $(HDR) slstatus.c $(COM:=.c) $(REQ:=.c) $(REQ:=.h) \ + slstatus.1 "slstatus-$(VERSION)" + tar -cf - "slstatus-$(VERSION)" | gzip -c > "slstatus-$(VERSION).tar.gz" + rm -rf "slstatus-$(VERSION)" install: all - @echo installing executable file to ${DESTDIR}${PREFIX}/bin - @mkdir -p ${DESTDIR}${PREFIX}/bin - @cp -f ${NAME} ${DESTDIR}${PREFIX}/bin - @chmod 755 ${DESTDIR}${PREFIX}/bin/${NAME} + mkdir -p "$(DESTDIR)$(PREFIX)/bin" + cp -f slstatus "$(DESTDIR)$(PREFIX)/bin" + chmod 755 "$(DESTDIR)$(PREFIX)/bin/slstatus" + mkdir -p "$(DESTDIR)$(MANPREFIX)/man1" + cp -f slstatus.1 "$(DESTDIR)$(MANPREFIX)/man1" + chmod 644 "$(DESTDIR)$(MANPREFIX)/man1/slstatus.1" uninstall: - @echo removing executable file from ${DESTDIR}${PREFIX}/bin - @rm -f ${DESTDIR}${PREFIX}/bin/${NAME} - -.PHONY: all options clean dist install uninstall + rm -f "$(DESTDIR)$(PREFIX)/bin/slstatus" + rm -f "$(DESTDIR)$(MANPREFIX)/man1/slstatus.1"