split off and compile util.c separately
[project/uci.git] / Makefile
index edbdc4e..b00aac8 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,49 +1,36 @@
-VERSION=0.3
+VERSION=0.8
 
 # optional features
 PLUGIN_SUPPORT=1
 DEBUG=0
 DEBUG_TYPECAST=0
 
-COPTS=-O2
-WOPTS=-pedantic -Wno-unused -Werror
-FPIC=-fPIC
-CFLAGS=$(COPTS) $(WOPTS) -Wall -std=gnu99
-
-AR=ar
-LD=ld
-CC=gcc
-LIBS=-lc
-RANLIB=ranlib
-
-ifeq ($(DEBUG),1)
-  COPTS = -O0
-  CFLAGS += -g3
-endif
-OS=$(shell uname)
-ifeq ($(OS),Darwin)
-  LINK=$(LD)
-  SHLIB_EXT=dylib
-  SHLIB_FLAGS=-dylib
-else
-  LINK=$(CC)
-  SHLIB_EXT=so
-  SHLIB_FLAGS=-shared -Wl,-soname,$(SHLIB_FILE)
-endif
+include Makefile.inc
+
+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
+
+all: uci libuci.$(SHLIB_EXT) uci-static ucimap-example
 
-all: uci-static uci libuci.$(SHLIB_EXT)
+$(eval $(call add_dep,libuci,history.c 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
 
 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)
@@ -53,29 +40,56 @@ uci_config.h: FORCE
                rm -f "$@.tmp"; \
        fi
 
+%.o: %.c
+       $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $<
+
+%.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
+       $(CC) -o $@ $< -L. -luci $(LIBS)
 
 uci-static: cli.o libuci.a
-       $(CC) $(CFLAGS) -o $@ $^
+       $(CC) $(CFLAGS) -o $@ $^ $(LIBS)
 
-libuci-static.o: libuci.c $(LIBUCI_DEPS)
-       $(CC) $(CFLAGS) -c -o $@ $<
+ucimap.c: ucimap.h uci.h
 
-libuci-shared.o: libuci.c $(LIBUCI_DEPS)
-       $(CC) $(CFLAGS) $(FPIC) -c -o $@ $<
-
-libuci.a: libuci-static.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)/$(LIBDIRNAME)
+       $(MKDIR) -p $(DESTDIR)$(prefix)/include
+       $(INSTALL) -m0644 libuci.a $(DESTDIR)$(prefix)/$(LIBDIRNAME)/
+       $(INSTALL) -m0644 uci_config.h uci.h ucimap.h $(DESTDIR)$(prefix)/include/
+
+install-bin: all
+       $(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 ucimap-example
+       make -C test
 
 FORCE: ;
 .PHONY: FORCE