+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
+
+all: uci libuci.$(SHLIB_EXT) uci-static ucimap-example
+
+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"
+ @echo "#define UCI_PREFIX \"$(prefix)\"" > "$@.tmp"
+ $(call add_feature,PLUGIN_SUPPORT)
+ $(call add_feature,DEBUG)
+ $(call add_feature,DEBUG_TYPECAST)
+ @if [ \! -f "$@" ] || ! cmp "$@.tmp" "$@" >/dev/null; then \
+ mv "$@.tmp" "$@"; \
+ else \
+ rm -f "$@.tmp"; \
+ fi
+
+%.o: %.c
+ $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $<
+
+%-shared.o: %.c
+ $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $(FPIC) $<
+
+%-static.o: %.c
+ $(CC) -c -o $@ $(CPPFLAGS) $(CFLAGS) $<
+
+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
+
+libuci.a: libuci-static.o ucimap-static.o