]> git.sur5r.net Git - openldap/blobdiff - libraries/liblmdb/Makefile
make clean: remove *.lo
[openldap] / libraries / liblmdb / Makefile
index a34a9deb1453cfdf3deba7b330aac9fd556dd837..bca5cd3819c2f7d60426fa6f8eb48dab2dcbd740 100644 (file)
@@ -17,7 +17,7 @@
 # read mdb.c before changing any of them.
 #
 CC     = gcc
-W      = -W -Wall -Wno-unused-parameter -Wbad-function-cast
+W      = -W -Wall -Wno-unused-parameter -Wbad-function-cast -Wuninitialized
 THREADS = -pthread
 OPT = -O2 -g
 CFLAGS = $(THREADS) $(OPT) $(W) $(XCFLAGS)
@@ -29,8 +29,8 @@ prefix        = /usr/local
 
 IHDRS  = lmdb.h
 ILIBS  = liblmdb.a liblmdb.so
-IPROGS = mdb_stat mdb_copy mdb_dump
-IDOCS  = mdb_stat.1 mdb_copy.1 mdb_dump.1
+IPROGS = mdb_stat mdb_copy mdb_dump mdb_load
+IDOCS  = mdb_stat.1 mdb_copy.1 mdb_dump.1 mdb_load.1
 PROGS  = $(IPROGS) mtest mtest2 mtest3 mtest4 mtest5
 all:   $(ILIBS) $(PROGS)
 
@@ -41,22 +41,23 @@ install: $(ILIBS) $(IPROGS) $(IHDRS)
        for f in $(IDOCS); do cp $$f $(DESTDIR)$(prefix)/man/man1; done
 
 clean:
-       rm -rf $(PROGS) *.[ao] *.so *~ testdb
+       rm -rf $(PROGS) *.[ao] *.[ls]o *~ testdb
 
 test:  all
-       mkdir testdb
+       rm -rf testdb && mkdir testdb
        ./mtest && ./mdb_stat testdb
 
 liblmdb.a:     mdb.o midl.o
        ar rs $@ mdb.o midl.o
 
-liblmdb.so:    mdb.o midl.o
+liblmdb.so:    mdb.lo midl.lo
 #      $(CC) $(LDFLAGS) -pthread -shared -Wl,-Bsymbolic -o $@ mdb.o midl.o $(SOLIBS)
-       $(CC) $(LDFLAGS) -pthread -shared -o $@ mdb.o midl.o $(SOLIBS)
+       $(CC) $(LDFLAGS) -pthread -shared -o $@ mdb.lo midl.lo $(SOLIBS)
 
 mdb_stat: mdb_stat.o liblmdb.a
 mdb_copy: mdb_copy.o liblmdb.a
 mdb_dump: mdb_dump.o liblmdb.a
+mdb_load: mdb_load.o liblmdb.a
 mtest:    mtest.o    liblmdb.a
 mtest2:        mtest2.o liblmdb.a
 mtest3:        mtest3.o liblmdb.a
@@ -65,13 +66,38 @@ mtest5:     mtest5.o liblmdb.a
 mtest6:        mtest6.o liblmdb.a
 
 mdb.o: mdb.c lmdb.h midl.h
-       $(CC) $(CFLAGS) -fPIC $(CPPFLAGS) -c mdb.c
+       $(CC) $(CFLAGS) $(CPPFLAGS) -c mdb.c
 
 midl.o: midl.c midl.h
-       $(CC) $(CFLAGS) -fPIC $(CPPFLAGS) -c midl.c
+       $(CC) $(CFLAGS) $(CPPFLAGS) -c midl.c
+
+mdb.lo: mdb.c lmdb.h midl.h
+       $(CC) $(CFLAGS) -fPIC $(CPPFLAGS) -c mdb.c -o $@
+
+midl.lo: midl.c midl.h
+       $(CC) $(CFLAGS) -fPIC $(CPPFLAGS) -c midl.c -o $@
 
 %:     %.o
        $(CC) $(CFLAGS) $(LDFLAGS) $^ $(LDLIBS) -o $@
 
 %.o:   %.c lmdb.h
        $(CC) $(CFLAGS) $(CPPFLAGS) -c $<
+
+COV_FLAGS=-fprofile-arcs -ftest-coverage
+COV_OBJS=xmdb.o xmidl.o
+
+coverage: xmtest
+       for i in mtest*.c [0-9]*.c; do j=`basename \$$i .c`; $(MAKE) $$j.o; \
+               gcc -o x$$j $$j.o $(COV_OBJS) -pthread $(COV_FLAGS); \
+               rm -rf testdb; mkdir testdb; ./x$$j; done
+       gcov xmdb.c
+       gcov xmidl.c
+
+xmtest:        mtest.o xmdb.o xmidl.o
+       gcc -o xmtest mtest.o xmdb.o xmidl.o -pthread $(COV_FLAGS)
+
+xmdb.o: mdb.c lmdb.h midl.h
+       $(CC) $(CFLAGS) -fPIC $(CPPFLAGS) -O0 $(COV_FLAGS) -c mdb.c -o $@
+
+xmidl.o: midl.c midl.h
+       $(CC) $(CFLAGS) -fPIC $(CPPFLAGS) -O0 $(COV_FLAGS) -c midl.c -o $@