X-Git-Url: http://pilppa.org/gitweb/?a=blobdiff_plain;f=Makefile;h=109e56114818e14149f2ff02ab851314233ddd12;hb=HEAD;hp=cbdf08e4bdca7590998176dc20577a1a48aaa03a;hpb=a315dd546791450a2ee00317938748947632d4f8;p=uci.git diff --git a/Makefile b/Makefile index cbdf08e..109e561 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,4 @@ -VERSION=0.7 +VERSION=0.8 # optional features PLUGIN_SUPPORT=1 @@ -7,22 +7,30 @@ DEBUG_TYPECAST=0 include Makefile.inc -LIBS=-lc +LIBS=-lc -ldl SHLIB_FILE=libuci.$(SHLIB_EXT).$(VERSION) 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 + +SOURCES = libuci.c file.c ucimap.c util.c delta.c + +all: uci libuci.$(SHLIB_EXT) uci-static ucimap-example -all: uci-static uci libuci.$(SHLIB_EXT) libucimap.a +$(eval $(call add_dep,libuci,list.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_list.h uci_config.h: FORCE @rm -f "$@.tmp" + @echo "#define UCI_PREFIX \"$(prefix)\"" > "$@.tmp" $(call add_feature,PLUGIN_SUPPORT) $(call add_feature,DEBUG) $(call add_feature,DEBUG_TYPECAST) @@ -32,51 +40,57 @@ uci_config.h: FORCE rm -f "$@.tmp"; \ fi -uci: cli.o libuci.$(SHLIB_EXT) - $(CC) -o $@ $< -L. -luci +%.o: %.c + $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $< -uci-static: cli.o libuci.a - $(CC) $(CFLAGS) -o $@ $^ +%.static.o: %.c + $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $< + +%.shared.o: %.c + $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $(FPIC) $< -libuci-static.o: libuci.c $(LIBUCI_DEPS) - $(CC) $(CFLAGS) -c -o $@ $< +uci: cli.o libuci.$(SHLIB_EXT) + $(CC) -o $@ $< -L. -luci $(LIBS) -libuci-shared.o: libuci.c $(LIBUCI_DEPS) - $(CC) $(CFLAGS) $(FPIC) -c -o $@ $< +uci-static: cli.o libuci.a + $(CC) $(CFLAGS) -o $@ $^ $(LIBS) -libuci.a: libuci-static.o - rm -f $@ - $(AR) rc $@ $^ - $(RANLIB) $@ +ucimap.c: ucimap.h uci.h -libucimap.a: ucimap.o +libuci.a: $(patsubst %.c,%.static.o, $(SOURCES)) rm -f $@ $(AR) rc $@ $^ $(RANLIB) $@ -libuci.$(SHLIB_EXT): libuci-shared.o +libuci.$(SHLIB_EXT): $(patsubst %.c,%.shared.o, $(SOURCES)) $(LINK) $(SHLIB_FLAGS) -o $(SHLIB_FILE) $^ $(LIBS) ln -sf $(SHLIB_FILE) $@ +ucimap-example.c: list.h +ucimap-example: ucimap-example.o libuci.a + $(CC) $(CFLAGS) -o $@ $^ $(LIBS) + clean: - rm -f uci uci-static *.[oa] *.so* *.dylib* uci_config.h + rm -f uci uci-static *.[oa] *.so* *.dylib* uci_config.h ucimap-example install: install-bin install-dev install-dev: all - $(MKDIR) -p $(DESTDIR)$(prefix)/lib + $(MKDIR) -p $(DESTDIR)$(prefix)/$(LIBDIRNAME) $(MKDIR) -p $(DESTDIR)$(prefix)/include - $(INSTALL) -m0644 libuci.a libucimap.a $(DESTDIR)$(prefix)/lib/ - $(INSTALL) -m0644 uci_config.h uci.h uci_list.h ucimap.h $(DESTDIR)$(prefix)/include/ + $(MKDIR) -p $(DESTDIR)$(prefix)/$(LIBDIRNAME)/pkgconfig + $(INSTALL) -m0644 libuci.a $(DESTDIR)$(prefix)/$(LIBDIRNAME)/ + $(INSTALL) -m0644 uci_config.h uci.h ucimap.h $(DESTDIR)$(prefix)/include/ + $(INSTALL) -m0644 $(LIBUCIPC) $(DESTDIR)$(prefix)/$(LIBDIRNAME)/pkgconfig/libuci.pc install-bin: all - $(MKDIR) -p $(DESTDIR)$(prefix)/lib - $(INSTALL) -m0755 $(SHLIB_FILE) $(DESTDIR)$(prefix)/lib/ - ln -sf $(SHLIB_FILE) $(DESTDIR)$(prefix)/lib/libuci.$(SHLIB_EXT) + $(MKDIR) -p $(DESTDIR)$(prefix)/$(LIBDIRNAME) + $(INSTALL) -m0755 $(SHLIB_FILE) $(DESTDIR)$(prefix)/$(LIBDIRNAME)/ + ln -sf $(SHLIB_FILE) $(DESTDIR)$(prefix)/$(LIBDIRNAME)/libuci.$(SHLIB_EXT) $(MKDIR) -p $(DESTDIR)$(prefix)/bin $(INSTALL) -m0755 uci $(DESTDIR)$(prefix)/bin/ -test: all +test: all ucimap-example make -C test FORCE: ;