-# Makefile for the UCW Library (c) 1997--2010 Martin Mares <mj@ucw.cz>
+# Makefile for the UCW Library (c) 1997--2014 Martin Mares <mj@ucw.cz>
DIRS+=ucw
LIBUCW=$(o)/ucw/libucw.pc
LIBUCW_MODS= \
threads \
- alloc alloc_str realloc bigalloc mempool mempool-str mempool-fmt eltpool \
- mmap partmap hashfunc \
+ alloc alloc_str alloc-std \
+ bigalloc mempool mempool-str mempool-fmt eltpool \
+ partmap hashfunc \
slists simple-lists bitsig \
- log log-stream log-file log-syslog log-conf proctitle tbf \
- conf-alloc conf-dump conf-input conf-intr conf-journal conf-parse conf-section \
+ log log-stream log-file log-syslog log-conf tbf \
+ conf-context conf-alloc conf-dump conf-input conf-intr conf-journal conf-parse conf-section conf-getopt \
ipaccess \
- profile \
- fastbuf ff-binary ff-string ff-printf ff-unicode ff-stkstring \
- fb-file carefulio fb-mem fb-temp tempfile fb-mmap fb-limfd fb-buffer fb-grow fb-pool fb-atomic fb-param fb-socket \
- char-cat char-upper char-lower unicode stkstring \
+ fastbuf ff-binary ff-string ff-printf ff-unicode ff-varint ff-stkstring \
+ fb-file fb-mem fb-temp tempfile fb-mmap fb-limfd fb-buffer fb-grow fb-pool fb-atomic fb-param fb-socket fb-multi fb-null \
+ char-cat char-upper char-lower unicode varint stkstring \
wildmatch regex \
- prime primetable random timer randomkey \
- bit-ffs bit-fls \
+ prime primetable random \
+ time-stamp time-timer time-conf \
+ bit-ffs bit-fls bit-array \
url \
- mainloop main-block \
- exitstatus runcmd sighandler \
- lizard lizard-safe adler32 \
- md5 sha1 sha1-hmac \
+ mainloop main-block main-rec \
+ proctitle exitstatus runcmd \
+ lizard lizard-safe adler32 sighandler \
+ md5 sha1 sha1-hmac crc crc-tables \
base64 base224 \
- sync \
- qache \
+ io-careful io-sync io-mmap io-size \
string str-esc str-split str-match str-imatch str-hex str-fix \
bbuf gary \
getopt \
strtonum \
- respool trans res-fd res-mem res-subpool res-mempool
+ resource trans res-fd res-mem res-subpool res-mempool res-eltpool \
+ daemon daemon-ctrl \
+ signames \
+ opt opt-help opt-conf
LIBUCW_MAIN_INCLUDES= \
- lib.h log.h threads.h \
- mempool.h \
+ lib.h log.h tbf.h threads.h time.h \
+ alloc.h mempool.h eltpool.h \
clists.h slists.h simple-lists.h \
- string.h stkstring.h unicode.h chartype.h regex.h \
+ string.h stkstring.h unicode.h varint.h chartype.h regex.h \
wildmatch.h \
- unaligned.h prefetch.h \
+ unaligned.h \
bbuf.h gbuf.h gary.h bitarray.h bitsig.h \
hashfunc.h hashtable.h \
heap.h binheap.h binheap-node.h \
prime.h \
bitops.h \
conf.h getopt.h ipaccess.h \
- profile.h \
- fastbuf.h lfs.h ff-unicode.h ff-binary.h \
+ fastbuf.h io.h ff-unicode.h ff-varint.h ff-binary.h fb-socket.h \
url.h \
mainloop.h \
+ process.h \
lizard.h \
- md5.h \
+ md5.h sha1.h crc.h \
base64.h base224.h \
- qache.h \
- kmp.h kmp-search.h binsearch.h \
+ kmp.h kmp-search.h trie.h binsearch.h \
partmap.h \
strtonum.h \
- respool.h trans.h
+ resource.h trans.h \
+ daemon.h \
+ signames.h \
+ sighandler.h \
+ opt.h
ifdef CONFIG_UCW_THREADS
# Some modules require threading
LIBUCW_MODS+=fb-direct
endif
-ifdef CONFIG_OWN_GETOPT
+ifdef CONFIG_UCW_OWN_GETOPT
include $(s)/ucw/getopt/Makefile
endif
LIBUCW_MOD_PATHS=$(addprefix $(o)/ucw/,$(LIBUCW_MODS))
-$(o)/ucw/libucw.a: $(addsuffix .o,$(LIBUCW_MOD_PATHS))
-$(o)/ucw/libucw-pic.a: $(addsuffix .oo,$(LIBUCW_MOD_PATHS))
-$(o)/ucw/libucw.so: $(addsuffix .oo,$(LIBUCW_MOD_PATHS))
+export LIBUCW_LIBS=-lm
+ifdef CONFIG_UCW_THREADS
+LIBUCW_LIBS+=-lpthread
+endif
+ifdef CONFIG_UCW_PCRE
+LIBUCW_LIBS+=-lpcre
+endif
+ifdef CONFIG_UCW_MONOTONIC_CLOCK
+LIBUCW_LIBS+=-lrt
+endif
+
+$(o)/ucw/libucw$(LV).a: $(addsuffix .o,$(LIBUCW_MOD_PATHS))
+$(o)/ucw/libucw$(LV).so: $(addsuffix .oo,$(LIBUCW_MOD_PATHS))
+$(o)/ucw/libucw$(LV).so: SONAME_SUFFIX=.0
+$(o)/ucw/libucw$(LV).so: LIBS+=$(LIBUCW_LIBS)
-ifdef CONFIG_STATIC_PIC
-$(o)/ucw/libucw.pc: $(o)/ucw/libucw-pic.a
+ifdef CONFIG_INSTALL_API
+$(o)/ucw/libucw.pc: $(addprefix $(o)/ucw/libucw$(LV),.a .so)
endif
$(o)/ucw/hashfunc.o $(o)/ucw/hashfunc.oo: CFLAGS += -funroll-loops
$(o)/ucw/lizard.o: CFLAGS += $(COPT2) -funroll-loops
+$(o)/ucw/ff-varint-t: $(LIBUCW)
+$(o)/ucw/varint-t: $(LIBUCW)
$(o)/ucw/conf-test: $(o)/ucw/conf-test.o $(LIBUCW)
-$(o)/ucw/lfs-test: $(o)/ucw/lfs-test.o $(LIBUCW)
$(o)/ucw/hash-test: $(o)/ucw/hash-test.o $(LIBUCW)
$(o)/ucw/hashfunc-test: $(o)/ucw/hashfunc-test.o $(LIBUCW)
$(o)/ucw/asort-test: $(o)/ucw/asort-test.o $(LIBUCW)
endif
$(o)/ucw/ipaccess-test: $(o)/ucw/ipaccess-test.o $(LIBUCW)
$(o)/ucw/trie-test: $(o)/ucw/trie-test.o $(LIBUCW)
+$(o)/ucw/opt-test: $(o)/ucw/opt-test.o $(LIBUCW)
TESTS+=$(addprefix $(o)/ucw/,regex.test unicode.test hash-test.test mempool.test stkstring.test \
slists.test bbuf.test kmp-test.test getopt.test ff-unicode.test eltpool.test \
- fb-socket.test trie-test.test string.test sha1.test asort-test.test binheap-test.test \
- redblack-test.test fb-file.test fb-grow.test fb-pool.test fb-atomic.test \
- fb-limfd.test fb-temp.test fb-mem.test fb-buffer.test fb-mmap.test url.test strtonum-test.test \
- gary.test)
+ trie-test.test string.test sha1.test asort-test.test binheap-test.test \
+ fb-file.test fb-socket.test fb-grow.test fb-pool.test fb-atomic.test fb-limfd.test fb-temp.test \
+ fb-mem.test fb-buffer.test fb-mmap.test fb-multi.test fb-null.test \
+ redblack-test.test url.test strtonum-test.test \
+ gary.test time.test crc.test signames.test md5.test bitops.test opt.test)
+$(o)/ucw/varint.test: $(o)/ucw/varint-t
$(o)/ucw/regex.test: $(o)/ucw/regex-t
$(o)/ucw/unicode.test: $(o)/ucw/unicode-t
$(o)/ucw/hash-test.test: $(o)/ucw/hash-test
$(o)/ucw/bbuf.test: $(o)/ucw/bbuf-t
$(o)/ucw/getopt.test: $(o)/ucw/getopt-t
$(o)/ucw/ff-unicode.test: $(o)/ucw/ff-unicode-t
+$(o)/ucw/ff-varint.test: $(o)/ucw/ff-varint-t
$(o)/ucw/eltpool.test: $(o)/ucw/eltpool-t
$(o)/ucw/string.test: $(o)/ucw/str-hex-t $(o)/ucw/str-esc-t $(o)/ucw/str-fix-t
$(o)/ucw/sha1.test: $(o)/ucw/sha1-t $(o)/ucw/sha1-hmac-t
$(o)/ucw/redblack-test.test: $(o)/ucw/redblack-test
$(o)/ucw/strtonum-test.test: $(o)/ucw/strtonum-test
$(addprefix $(o)/ucw/fb-,file.test grow.test pool.test socket.test atomic.test \
- limfd.test temp.test mem.test buffer.test mmap.test): %.test: %-t
+ limfd.test temp.test mem.test buffer.test mmap.test multi.test null.test): %.test: %-t
$(o)/ucw/url.test: $(o)/ucw/url-t
$(o)/ucw/gary.test: $(o)/ucw/gary-t
+$(o)/ucw/time.test: $(o)/ucw/time-conf-t
+$(o)/ucw/crc.test: $(o)/ucw/crc-t
+$(o)/ucw/signames.test: $(o)/ucw/signames-t
+$(o)/ucw/md5.test: $(o)/ucw/md5-t
+$(o)/ucw/opt.test: $(o)/ucw/opt-test
ifdef CONFIG_UCW_THREADS
TESTS+=$(addprefix $(o)/ucw/,asio.test)
CONFIGS+=libucw
-INSTALL_TARGETS+=install-libucw
-install-libucw:
- install -d -m 755 $(DESTDIR)$(INSTALL_LIB_DIR) $(DESTDIR)$(INSTALL_INCLUDE_DIR)/ucw/ $(DESTDIR)$(INSTALL_PKGCONFIG_DIR) $(DESTDIR)$(INSTALL_CONFIG_DIR)
+INSTALL_TARGETS+=install-libucw-lib
+install-libucw-lib:
+ install -d -m 755 $(DESTDIR)$(INSTALL_LIB_DIR)
+ install -m 644 run/lib/libucw$(LV).so.0 $(DESTDIR)$(INSTALL_LIB_DIR)/libucw$(LV).so.0.0
+ ln -sf libucw$(LV).so.0.0 $(DESTDIR)$(INSTALL_LIB_DIR)/libucw$(LV).so.0
+.PHONY: install-libucw-lib
+
+INSTALL_TARGETS+=install-libucw-api
+install-libucw-api: install-ucw-sorter-api
+ install -d -m 755 $(DESTDIR)$(INSTALL_LIB_DIR) $(DESTDIR)$(INSTALL_INCLUDE_DIR)/ucw/ $(DESTDIR)$(INSTALL_PKGCONFIG_DIR)
install -m 644 $(addprefix run/include/ucw/,$(LIBUCW_MAIN_INCLUDES) autoconf.h config.h) $(DESTDIR)$(INSTALL_INCLUDE_DIR)/ucw/
install -m 644 run/lib/pkgconfig/libucw.pc $(DESTDIR)$(INSTALL_PKGCONFIG_DIR)
- install -m 644 run/lib/libucw.$(LS) $(DESTDIR)$(INSTALL_LIB_DIR)
-ifdef CONFIG_STATIC_PIC
- install -m 644 run/lib/libucw-pic.$(LS) $(DESTDIR)$(INSTALL_LIB_DIR)
-endif
- install -m 644 run/$(CONFIG_DIR)/libucw $(DESTDIR)$(INSTALL_CONFIG_DIR)
+ ln -sf libucw$(LV).so.0.0 $(DESTDIR)$(INSTALL_LIB_DIR)/libucw$(LV).so
+ install -m 644 run/lib/libucw$(LV).a $(DESTDIR)$(INSTALL_LIB_DIR)
+.PHONY: install-libucw-api
-.PHONY: install-libucw
+INSTALL_TARGETS+=install-libucw-config
+install-libucw-config:
+ install -d -m 755 $(DESTDIR)$(INSTALL_CONFIG_DIR)
+ install -m 644 run/$(CONFIG_DIR)/libucw $(DESTDIR)$(INSTALL_CONFIG_DIR)
+.PHONY: install-libucw-config