chiark / gitweb /
Add global unihash table; use universal hashing instead of CRC.
[mLib] / Makefile.am
index 8e0c51d..32ef349 100644 (file)
@@ -1,6 +1,6 @@
 ## -*-Makefile-*-
 ##
-## $Id: Makefile.am,v 1.42 2003/12/13 20:37:59 mdw Exp $
+## $Id: Makefile.am,v 1.45 2003/12/15 20:53:08 mdw Exp $
 ##
 ## Building the distribution
 ##
 ##----- Revision history ----------------------------------------------------
 ##
 ## $Log: Makefile.am,v $
+## Revision 1.45  2003/12/15 20:53:08  mdw
+## New program to make fixed tables for universal hashing.
+##
+## Revision 1.44  2003/12/14 14:56:57  mdw
+## Fix distribution.
+##
+## Revision 1.43  2003/12/14 14:45:30  mdw
+## Test universal hashing and fix bugs.
+##
 ## Revision 1.42  2003/12/13 20:37:59  mdw
 ## Add adns support in background resolver.
 ##
@@ -144,7 +153,7 @@ AUTOMAKE_OPTIONS = foreign
 SUBDIRS = man
 
 bin_SCRIPTS = mLib-config
-bin_PROGRAMS = crc-mktab
+bin_PROGRAMS = crc-mktab unihash-mkstatic
 
 lib_LTLIBRARIES = libmLib.la
 pkglibexecdir = $(libexecdir)/$(PACKAGE)
@@ -169,10 +178,11 @@ libmLib_la_LDFLAGS = -version-info 2:3:0
 
 libmLib_la_SOURCES = \
        alloc.c arena.c exc.c quis.c pquis.c report.c sub.c trace.c \
-               traceopt.c track.c unihash.c \
+               traceopt.c track.c \
        pool.c pool-file.c pool-sub.c \
        atom.c assoc.c darray.c dstr.c dputf.c dspool.c hash.c sym.c \
        crc32.c crc32-tab.c \
+       unihash.c unihash-global.c \
        env.c fdflags.c fdpass.c fwatch.c lock.c \
        @BRES_SOURCE@.c \
        conn.c lbuf.c ident.c pkbuf.c sel.c selbuf.c selpk.c sig.c \
@@ -181,7 +191,7 @@ libmLib_la_SOURCES = \
 EXTRA_libmLib_la_SOURCES = bres.c bres-adns.c
 libmLib_la_LIBADD = @DEPLIBS@
 
-BUILT_SOURCES = crc32-tab.c
+BUILT_SOURCES = crc32-tab.c unihash-global.c
 
 crc32-tab.c: crc-mktab
        ./crc-mktab \
@@ -189,14 +199,25 @@ crc32-tab.c: crc-mktab
                -c -scrc32_table -icrc32.h -tuint32 -ocrc32-tab.c.new
        mv crc32-tab.c.new crc32-tab.c
 
-crc_mktab_SOURCES = crc-mktab.c mdwopt.c quis.c pquis.c report.c str.c
+unihash-global.c: unihash-mkstatic
+       ./unihash-mkstatic \
+               -c -sunihash_global -iunihash.h -ounihash-global.c.new
+       mv unihash-global.c.new unihash-global.c
+
+crc_mktab_SOURCES = \
+       crc-mktab.c \
+       mdwopt.c quis.c pquis.c report.c str.c
+unihash_mkstatic_SOURCES = \
+       unihash-mkstatic.c \
+       mdwopt.c quis.c pquis.c report.c str.c unihash.c
 
 ## --- Test code ---
 
 noinst_PROGRAMS = da.t sym.t assoc.t bits.t
 
 check: \
-       da.test sym.test assoc.test bits.test base64.test hex.test
+       da.test sym.test assoc.test bits.test base64.test hex.test \
+       unihash.test
 
 da_t_SOURCES = da-test.c
 da_t_LDADD = libmLib.la
@@ -243,9 +264,11 @@ bits.test: bits.t
        ./bits.t -f $(srcdir)/bits.in
 
 base64.to: base64.c
-       $(COMPILE) -c -DTEST_RIG -DSRCDIR=\"$(srcdir)\" $(srcdir)/base64.c -o base64.to
+       $(COMPILE) -c -DTEST_RIG -DSRCDIR=\"$(srcdir)\" \
+               $(srcdir)/base64.c -o base64.to
 base64.t: base64.to base64.o libmLib.la
-       $(CC) $(CFLAGS) $(LDFLAGS) base64.to .libs/libmLib.a $(LIBS) -o base64.t
+       $(CC) $(CFLAGS) $(LDFLAGS) \
+               base64.to .libs/libmLib.a $(LIBS) -o base64.t
 base64.test: base64.t base64.in base64.ref
        ./base64.t <$(srcdir)/base64.in >base64.out
        cmp base64.out $(srcdir)/base64.ref
@@ -254,9 +277,11 @@ base64.test: base64.t base64.in base64.ref
        @echo "base64 tested OK."
 
 hex.to: hex.c
-       $(COMPILE) -c -DTEST_RIG -DSRCDIR=\"$(srcdir)\" $(srcdir)/hex.c -o hex.to
+       $(COMPILE) -c -DTEST_RIG -DSRCDIR=\"$(srcdir)\" \
+               $(srcdir)/hex.c -o hex.to
 hex.t: hex.to hex.o libmLib.la
-       $(CC) $(CFLAGS) $(LDFLAGS) hex.to .libs/libmLib.a $(LIBS) -o hex.t
+       $(CC) $(CFLAGS) $(LDFLAGS) \
+               hex.to .libs/libmLib.a $(LIBS) -o hex.t
 hex.test: hex.t hex.in hex.ref
        ./hex.t <$(srcdir)/hex.in >hex.out
        cmp hex.out $(srcdir)/hex.ref
@@ -264,11 +289,23 @@ hex.test: hex.t hex.in hex.ref
        cmp hex.out $(srcdir)/hex.in
        @echo "hex tested OK."
 
+unihash.to: unihash.c
+       $(COMPILE) -c -DTEST_RIG -DSRCDIR=\"$(srcdir)\" \
+               $(srcdir)/unihash.c -o unihash.to
+unihash.t: unihash.to libmLib.la
+       $(CC) $(CFLAGS) $(LDFLAGS) \
+               unihash.to .libs/libmLib.a $(LIBS) -o unihash.t
+unihash.in: unihash-check.pl
+       perl $(srcdir)/unihash-check.pl >unihash.in.new
+       mv unihash.in.new unihash.in
+unihash.test: unihash.t unihash.in
+       ./unihash.t -f unihash.in
+
 TEST_CLEAN = \
-       *.t \
+       *.t *.to \
        da.in da.ref da.out \
        sym.in sym.ref sym.out \
-       base64.out hex.out 
+       base64.out hex.out unihash.in
 
 TEST_DIST = \
        da-gtest da-ref \