X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;ds=sidebyside;f=lib%2FMakefile;h=c23ac8c576850cda75d49f51a718735c1ec3d892;hb=78775c3f5e38e8bee7d04b0f994766c7dd1e6578;hp=8cbf1c989cd732250749bba2726aa03d15d711c2;hpb=b1fbf9e3292eab73fa448dd6c937e70eb66dc4a7;p=libucw.git diff --git a/lib/Makefile b/lib/Makefile index 8cbf1c98..c23ac8c5 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -1,20 +1,23 @@ -# Makefile for the UCW Library (c) 1997--2006 Martin Mares +# Makefile for the UCW Library (c) 1997--2007 Martin Mares DIRS+=lib +LIBUCW=$(o)/lib/libucw.$(LS) ifdef CONFIG_UCW_DBTOOL PROGS+=$(o)/lib/db-tool endif LIBUCW_MODS= \ - alloc alloc_str realloc mempool mempool-str mempool-fmt \ + threads \ + alloc alloc_str realloc bigalloc mempool mempool-str mempool-fmt \ mmap pagecache partmap hashfunc \ - lists slists sorter bitsig \ + lists slists simple-lists sorter bitsig \ log log-file proctitle \ - conf conf2 ipaccess \ + conf-alloc conf-dump conf-input conf-intr conf-journal conf-parse conf-section \ + ipaccess \ profile \ - fastbuf ff-printf ff-utf8 \ - fb-file carefulio fb-mem fb-temp fb-mmap fb-limfd fb-buffer fb-grow \ + fastbuf ff-binary ff-string ff-printf ff-utf8 \ + fb-file carefulio fb-mem fb-temp fb-mmap fb-limfd fb-buffer fb-grow fb-atomic fb-param \ str_ctype str_upper str_lower unicode-utf8 stkstring \ wildmatch wordsplit ctmatch patimatch patmatch regex \ prime primetable random timer randomkey \ @@ -27,19 +30,21 @@ LIBUCW_MODS= \ base64 base224 \ sync \ qache \ - string + string \ + bbuf \ + getopt LIBUCW_INCLUDES= \ - lib.h config.h math.h \ + lib.h config.h threads.h math.h \ mempool.h pagecache.h \ - sorter.h arraysort.h \ + sorter.h sorter-globals.h arraysort.h \ lists.h clists.h \ unaligned.h prefetch.h \ bbuf.h gbuf.h bitarray.h bitsig.h \ hashfunc.h hashtable.h \ heap.h binheap.h binheap-node.h \ redblack.h \ - conf.h ipaccess.h \ + conf.h getopt.h ipaccess.h \ profile.h \ fastbuf.h lfs.h ff-utf8.h \ chartype.h unicode.h stkstring.h \ @@ -50,12 +55,26 @@ LIBUCW_INCLUDES= \ lizard.h \ md5.h \ base64.h base224.h \ - qache.h + qache.h \ + kmp.h kmp-search.h + +ifdef CONFIG_UCW_THREADS +# Some modules require threading +LIBS+=-lpthread +LIBUCW_MODS+=threads-conf workqueue asio fb-direct +LIBUCW_INCLUDES+=workqueue.h asio.h +endif ifdef CONFIG_OWN_REGEX include $(s)/lib/regex/Makefile endif +ifdef CONFIG_OWN_GETOPT +include $(s)/lib/getopt/Makefile +endif + +include $(s)/lib/sorter/Makefile + LIBUCW=$(o)/lib/libucw.$(LS) LIBUCW_MOD_PATHS=$(addprefix $(o)/lib/,$(LIBUCW_MODS)) @@ -68,7 +87,6 @@ $(o)/lib/lizard.o: CFLAGS += $(COPT2) -funroll-loops $(o)/lib/db-test: $(o)/lib/db-test.o $(LIBUCW) $(o)/lib/db-tool: $(o)/lib/db-tool.o $(LIBUCW) $(o)/lib/conf-test: $(o)/lib/conf-test.o $(LIBUCW) -$(o)/lib/conf2-test: $(o)/lib/conf2-test.o $(LIBUCW) $(o)/lib/sort-test: $(o)/lib/sort-test.o $(LIBUCW) $(o)/lib/lfs-test: $(o)/lib/lfs-test.o $(LIBUCW) $(o)/lib/hash-test: $(o)/lib/hash-test.o $(LIBUCW) @@ -80,19 +98,29 @@ $(o)/lib/lizard-test: $(o)/lib/lizard-test.o $(LIBUCW) $(o)/lib/kmp-test: $(o)/lib/kmp-test.o $(LIBUCW) $(LIBCHARSET) $(o)/lib/ipaccess-test: $(o)/lib/ipaccess-test.o $(LIBUCW) -TESTS+=$(addprefix $(o)/lib/,regex.test unicode-utf8.test hash-test.test mempool.test stkstring.test slists.test kmp-test.test) +TESTS+=$(addprefix $(o)/lib/,regex.test unicode-utf8.test hash-test.test mempool.test stkstring.test \ + slists.test kmp-test.test bbuf.test getopt.test) + $(o)/lib/regex.test: $(o)/lib/regex-t $(o)/lib/unicode-utf8.test: $(o)/lib/unicode-utf8-t $(o)/lib/hash-test.test: $(o)/lib/hash-test -$(o)/lib/mempool.test: $(o)/lib/mempool-fmt-t $(o)/lib/mempool-str-t +$(o)/lib/mempool.test: $(o)/lib/mempool-t $(o)/lib/mempool-fmt-t $(o)/lib/mempool-str-t $(o)/lib/stkstring.test: $(o)/lib/stkstring-t $(o)/lib/bitops.test: $(o)/lib/bit-ffs-t $(o)/lib/bit-fls-t $(o)/lib/slists.test: $(o)/lib/slists-t $(o)/lib/kmp-test.test: $(o)/lib/kmp-test +$(o)/lib/bbuf.test: $(o)/lib/bbuf-t +$(o)/lib/getopt.test: $(o)/lib/getopt-t + +ifdef CONFIG_UCW_THREADS +TESTS+=$(addprefix $(o)/lib/,asio.test) +$(o)/lib/asio.test: $(o)/lib/asio-t +endif INCLUDES+=$(o)/lib/.include-stamp $(o)/lib/.include-stamp: $(addprefix $(s)/lib/,$(LIBUCW_INCLUDES)) $(s)/build/install-includes $(s)/lib run/include/lib $(?F) + $(s)/build/install-includes $(o)/lib run/include/lib autoconf.h touch $(o)/lib/.include-stamp ifdef CONFIG_UCW_PERL