Explicitly list component-objects in the Makefile
There was a long tinkering process at farbfeld about this, but the sad truth is that it's the only way to make the Makefile truly portable. Listing it just as $(COM:=.o): config.mk $(REQ:=.h) omits the dependency on the c-file itself, which incurs that strictly speaking the object file is not depending on the source file, which is nonsense. You don't see strictly Posix compliant Makefiles around very often and most use nasty GNU-extensions everywhere. It is a good idea to go ahead as a fitting example and show how to write them portably.
This commit is contained in:
parent
682c0fedde
commit
0efd64ffaa
1 changed files with 25 additions and 6 deletions
31
Makefile
31
Makefile
|
@ -30,19 +30,38 @@ COM =\
|
||||||
|
|
||||||
all: slstatus
|
all: slstatus
|
||||||
|
|
||||||
slstatus: slstatus.o $(COM:=.o) $(REQ:=.o)
|
components/battery.o: components/battery.c config.mk $(REQ:=.h)
|
||||||
|
components/cpu.o: components/cpu.c config.mk $(REQ:=.h)
|
||||||
|
components/datetime.o: components/datetime.c config.mk $(REQ:=.h)
|
||||||
|
components/disk.o: components/disk.c config.mk $(REQ:=.h)
|
||||||
|
components/entropy.o: components/entropy.c config.mk $(REQ:=.h)
|
||||||
|
components/hostname.o: components/hostname.c config.mk $(REQ:=.h)
|
||||||
|
components/ip.o: components/ip.c config.mk $(REQ:=.h)
|
||||||
|
components/kernel_release.o: components/kernel_release.c config.mk $(REQ:=.h)
|
||||||
|
components/keyboard_indicators.o: components/keyboard_indicators.c config.mk $(REQ:=.h)
|
||||||
|
components/keymap.o: components/keymap.c config.mk $(REQ:=.h)
|
||||||
|
components/load_avg.o: components/load_avg.c config.mk $(REQ:=.h)
|
||||||
|
components/netspeeds.o: components/netspeeds.c config.mk $(REQ:=.h)
|
||||||
|
components/num_files.o: components/num_files.c config.mk $(REQ:=.h)
|
||||||
|
components/ram.o: components/ram.c config.mk $(REQ:=.h)
|
||||||
|
components/run_command.o: components/run_command.c config.mk $(REQ:=.h)
|
||||||
|
components/swap.o: components/swap.c config.mk $(REQ:=.h)
|
||||||
|
components/temperature.o: components/temperature.c config.mk $(REQ:=.h)
|
||||||
|
components/uptime.o: components/uptime.c config.mk $(REQ:=.h)
|
||||||
|
components/user.o: components/user.c config.mk $(REQ:=.h)
|
||||||
|
components/volume.o: components/volume.c config.mk $(REQ:=.h)
|
||||||
|
components/wifi.o: components/wifi.c config.mk $(REQ:=.h)
|
||||||
slstatus.o: slstatus.c slstatus.h arg.h config.h config.mk $(REQ:=.h)
|
slstatus.o: slstatus.c slstatus.h arg.h config.h config.mk $(REQ:=.h)
|
||||||
$(COM:=.o): config.mk $(REQ:=.h)
|
|
||||||
|
.c.o:
|
||||||
|
$(CC) -o $@ -c $(CPPFLAGS) $(CFLAGS) $<
|
||||||
|
|
||||||
config.h:
|
config.h:
|
||||||
cp config.def.h $@
|
cp config.def.h $@
|
||||||
|
|
||||||
.o:
|
slstatus: slstatus.o $(COM:=.o) $(REQ:=.o)
|
||||||
$(CC) -o $@ $(LDFLAGS) $< $(COM:=.o) $(REQ:=.o) $(LDLIBS)
|
$(CC) -o $@ $(LDFLAGS) $< $(COM:=.o) $(REQ:=.o) $(LDLIBS)
|
||||||
|
|
||||||
.c.o:
|
|
||||||
$(CC) -o $@ -c $(CPPFLAGS) $(CFLAGS) $<
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f slstatus slstatus.o $(COM:=.o) $(REQ:=.o)
|
rm -f slstatus slstatus.o $(COM:=.o) $(REQ:=.o)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue