X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2FMakefile;h=6f44b008ac232bddf24e1b2b3007f82c692a2202;hb=ed4e86de76d1c3bfb685207fe00078950f67355a;hp=a17efb2e56d5ccd1158e05fd2512ef90e11a1240;hpb=136c4f2fe9e1b7df2929c240e5a94973f596a259;p=libucw.git diff --git a/lib/Makefile b/lib/Makefile index a17efb2e..6f44b008 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -1,23 +1,28 @@ -# Makefile for the UCW Library (c) 1997--2004 Martin Mares +# Makefile for the UCW Library (c) 1997--2007 Martin Mares DIRS+=lib +CONFIGS+=library +LIBUCW=$(o)/lib/libucw.pc 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 eltpool \ mmap pagecache partmap hashfunc \ - lists sorter bitsig \ + lists slists simple-lists bitsig \ log log-file proctitle \ - conf 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 \ + 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-pool fb-atomic fb-param \ str_ctype str_upper str_lower unicode-utf8 stkstring \ wildmatch wordsplit ctmatch patimatch patmatch regex \ - prime random timer log2 randomkey \ + prime primetable random timer randomkey \ + bit-ffs bit-fls \ db \ url \ mainloop exitstatus runcmd sighandler \ @@ -25,21 +30,26 @@ LIBUCW_MODS= \ md5 md5hex \ base64 base224 \ sync \ - qache + qache \ + string \ + bbuf \ + getopt LIBUCW_INCLUDES= \ - lib.h config.h math.h \ + lib.h config.h threads.h \ mempool.h pagecache.h \ - sorter.h arraysort.h \ - lists.h clists.h \ + arraysort.h \ + lists.h clists.h slists.h simple-lists.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 \ + binsearch.h \ + bitops.h \ + conf.h getopt.h ipaccess.h \ profile.h \ - fastbuf.h lfs.h ff-utf8.h \ + fastbuf.h lfs.h ff-utf8.h ff-binary.h \ chartype.h unicode.h stkstring.h \ wildmatch.h patmatch.h \ db.h \ @@ -48,25 +58,37 @@ LIBUCW_INCLUDES= \ lizard.h \ md5.h \ base64.h base224.h \ - qache.h + qache.h \ + kmp.h kmp-search.h \ + partmap.h + +ifdef CONFIG_UCW_THREADS +# Some modules require threading +LIBUCW_MODS+=threads-conf workqueue asio fb-direct +LIBUCW_INCLUDES+=workqueue.h semaphore.h asio.h +endif ifdef CONFIG_OWN_REGEX include $(s)/lib/regex/Makefile endif -LIBUCW=$(o)/lib/libucw.$(LS) +ifdef CONFIG_OWN_GETOPT +include $(s)/lib/getopt/Makefile +endif + +include $(s)/lib/sorter/Makefile + LIBUCW_MOD_PATHS=$(addprefix $(o)/lib/,$(LIBUCW_MODS)) $(o)/lib/libucw.a: $(addsuffix .o,$(LIBUCW_MOD_PATHS)) $(o)/lib/libucw.so: $(addsuffix .oo,$(LIBUCW_MOD_PATHS)) $(o)/lib/hashfunc.o $(o)/lib/hashfunc.oo: CFLAGS += -funroll-loops -$(o)/lib/lizard.o: CFLAGS += -O6 -funroll-loops +$(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/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) $(o)/lib/str-test: $(o)/lib/str-test.o $(LIBUCW) @@ -74,18 +96,37 @@ $(o)/lib/asort-test: $(o)/lib/asort-test.o $(LIBUCW) $(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 kmp-test.test bbuf.test getopt.test fastbuf.test eltpool.test) -TESTS+=$(addprefix $(o)/lib/,regex.test unicode-utf8.test hash-test.test mempool.test stkstring.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 +$(o)/lib/fastbuf.test: $(o)/lib/fb-file-t $(o)/lib/fb-grow-t $(o)/lib/fb-pool-t +$(o)/lib/eltpool.test: $(o)/lib/eltpool-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) - touch $(o)/lib/.include-stamp +API_LIBS+=libucw +API_INCLUDES+=$(o)/lib/.include-stamp +$(o)/lib/.include-stamp: $(addprefix $(s)/lib/,$(LIBUCW_INCLUDES)) obj/autoconf.h + $(Q)$(s)/build/install-includes $(