X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2FMakefile;h=0d2b9acf507197dd07a6a3cda507e0a4c0e9dc2a;hb=116954d49373438c669eadd764e03ee8ac4211bb;hp=39885a9ff4b8c30052eba804477ab434eb827e20;hpb=b48097fe5ddf0d0a6b7df4d2ebc4c9f6110edaa3;p=libucw.git diff --git a/lib/Makefile b/lib/Makefile index 39885a9f..0d2b9acf 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 kmp \ + 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 \ str_ctype str_upper str_lower unicode-utf8 stkstring \ wildmatch wordsplit ctmatch patimatch patmatch regex \ prime primetable random timer randomkey \ @@ -26,10 +29,12 @@ LIBUCW_MODS= \ md5 md5hex \ base64 base224 \ sync \ - qache + qache \ + string \ + bbuf LIBUCW_INCLUDES= \ - lib.h config.h math.h \ + lib.h config.h threads.h math.h \ mempool.h pagecache.h \ sorter.h arraysort.h \ lists.h clists.h \ @@ -38,7 +43,7 @@ LIBUCW_INCLUDES= \ 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 \ @@ -51,11 +56,19 @@ LIBUCW_INCLUDES= \ base64.h base224.h \ qache.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 -LIBUCW=$(o)/lib/libucw.$(LS) +include $(s)/lib/sorter/Makefile + LIBUCW_MOD_PATHS=$(addprefix $(o)/lib/,$(LIBUCW_MODS)) $(o)/lib/libucw.a: $(addsuffix .o,$(LIBUCW_MOD_PATHS)) @@ -67,7 +80,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) @@ -77,8 +89,9 @@ $(o)/lib/redblack-test: $(o)/lib/redblack-test.o $(LIBUCW) $(o)/lib/binheap-test: $(o)/lib/binheap-test.o $(LIBUCW) $(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) +TESTS+=$(addprefix $(o)/lib/,regex.test unicode-utf8.test hash-test.test mempool.test stkstring.test slists.test kmp-test.test bbuf.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 @@ -86,10 +99,18 @@ $(o)/lib/mempool.test: $(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 + +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