From: Felix Fietkau Date: Tue, 17 Aug 2010 11:34:04 +0000 (+0200) Subject: simplify dependency handling X-Git-Url: http://pilppa.org/gitweb/?p=uci.git;a=commitdiff_plain;h=a20ce3e0b064e0694a3b6c1e99456f1057ceb707 simplify dependency handling --- diff --git a/Makefile b/Makefile index 7354caf..506893f 100644 --- a/Makefile +++ b/Makefile @@ -14,12 +14,18 @@ define add_feature @echo "$(if $(findstring 1,$($(1))),#define UCI_$(1) 1,#undef UCI_$(1))" >> $@.tmp endef -LIBUCI_DEPS=file.c history.c list.c util.c uci.h uci_config.h uci_internal.h +define add_dep +$(1).shared.o: $(2) +$(1).static.o: $(2) +endef + all: uci libuci.$(SHLIB_EXT) uci-static ucimap-example +$(eval $(call add_dep,libuci,file.c history.c list.c util.c uci.h uci_config.h uci_internal.h)) +$(eval $(call add_dep,ucimap,uci.h uci_config.h ucimap.h)) + cli.o: cli.c uci.h uci_config.h -ucimap.o: ucimap.c uci.h uci_config.h ucimap.h uci_config.h: FORCE @rm -f "$@.tmp" @@ -36,33 +42,30 @@ uci_config.h: FORCE %.o: %.c $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $< -%-shared.o: %.c - $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $(FPIC) $< - -%-static.o: %.c +%.static.o: %.c $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $< +%.shared.o: %.c + $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $(FPIC) $< + uci: cli.o libuci.$(SHLIB_EXT) $(CC) -o $@ $< -L. -luci $(LIBS) uci-static: cli.o libuci.a $(CC) $(CFLAGS) -o $@ $^ $(LIBS) -libuci-static.o: libuci.c $(LIBUCI_DEPS) -libuci-shared.o: libuci.c $(LIBUCI_DEPS) -ucimap-static.o: ucimap.c $(LIBUCI_DEPS) ucimap.h -ucimap-shared.o: ucimap.c $(LIBUCI_DEPS) ucimap.h +ucimap.c: ucimap.h uci.h -libuci.a: libuci-static.o ucimap-static.o +libuci.a: libuci.static.o ucimap.static.o rm -f $@ $(AR) rc $@ $^ $(RANLIB) $@ -libuci.$(SHLIB_EXT): libuci-shared.o ucimap-shared.o +libuci.$(SHLIB_EXT): libuci.shared.o ucimap.shared.o $(LINK) $(SHLIB_FLAGS) -o $(SHLIB_FILE) $^ $(LIBS) ln -sf $(SHLIB_FILE) $@ -ucimap-example.o: ucimap-example.c list.h +ucimap-example.c: list.h ucimap-example: ucimap-example.o libuci.a $(CC) $(CFLAGS) -o $@ $^ $(LIBS)