@@@ simplify makefile
authorMark Wooding <mdw@distorted.org.uk>
Thu, 26 Sep 2019 09:01:38 +0000 (10:01 +0100)
committerMark Wooding <mdw@distorted.org.uk>
Thu, 26 Sep 2019 09:22:22 +0000 (10:22 +0100)
Makefile.in

index f7376e5..ab70bd6 100644 (file)
@@ -145,12 +145,12 @@ secnet: Makefile .git/HEAD $(shell sed -n 's#^ref: #.git/#p' .git/HEAD)
 secnet: $(wildcard .git/packed-refs)
 endif
 
+CRYPTO_TESTS = keccak1600 sha3 f25519 x25519 ed25519 fgoldi x448 ed448
+
 check: eax-aes-test.confirm eax-serpent-test.confirm \
        eax-serpentbe-test.confirm check-ipaddrset \
        msgcode-test.confirm \
-       keccak1600-test.confirm sha3-test.confirm \
-       f25519-test.confirm x25519-test.confirm ed25519-test.confirm \
-       fgoldi-test.confirm x448-test.confirm ed448-test.confirm
+       $(foreach c,$(CRYPTO_TESTS),$c-test.confirm)
 
 version.c: Makefile
        echo "#include \"secnet.h\"" >$@.new
@@ -177,61 +177,31 @@ msgcode-test.confirm: msgcode-test
        ./msgcode-test
        touch $@
 
-keccak1600-test: keccak1600-test.o keccak1600.o crypto-test.o
-       $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^
-
-keccak1600-test.confirm: keccak1600-test keccak1600-tests.in
-       ./keccak1600-test <$(srcdir)/keccak1600-tests.in
-       touch $@
-
-sha3-test: sha3-test.o sha3.o keccak1600.o crypto-test.o
+$(foreach c,$(CRYPTO_TESTS),$c-test): %-test: %-test.o crypto-test.o
        $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^
 
-sha3-test.confirm: sha3-test sha3-tests.in
-       ./sha3-test <$(srcdir)/sha3-tests.in
-       touch $@
-
-XDH_FUNCS = x25519 x448
-x25519_FIELD = f25519
-x448_FIELD = fgoldi
-XDH_FIELDS = $(foreach f,$(XDH_FUNCS),$($f_FIELD))
-
-$(addsuffix -test, $(XDH_FIELDS)): %-test: %-test.o %.o crypto-test.o
-       $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^
-
-$(addsuffix -test.o, $(XDH_FIELDS)): %-test.o: ec-field-test.c
-       $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c \
-               -DFIELD=$* $< -o $@
-
-$(addsuffix -test, $(XDH_FUNCS)): %-test: %-test.o %.o crypto-test.o
-       $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^
-x25519-test: f25519.o
-x448-test: fgoldi.o
-
-$(addsuffix -test.o, $(XDH_FUNCS)): %-test.o: xdh-test.c
-       $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c \
-               -DXDH=$* -DFIELD=$($*_FIELD) \
-               $< -o $@
-
-$(addsuffix -test.confirm, $(XDH_FUNCS) $(XDH_FIELDS)): \
+$(foreach c,$(CRYPTO_TESTS),$c-test.confirm): \
                %-test.confirm: %-test %-tests.in
        ./$*-test <$(srcdir)/$*-tests.in
        touch $@
 
-ed25519-test: ed25519-test.o sha512.o f25519.o scaf.o ed25519.o crypto-test.o
-       $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^
-
-ed25519-test.confirm: ed25519-test ed25519-tests.in
-       ./ed25519-test <$(srcdir)/ed25519-tests.in
-       touch $@
-
-ed448-test: ed448-test.o keccak1600.o sha3.o \
-               fgoldi.o scaf.o ed448.o crypto-test.o
-       $(CC) $(LDFLAGS) $(ALL_CFLAGS) -o $@ $^
-
-ed448-test.confirm: ed448-test ed448-tests.in
-       ./ed448-test <$(srcdir)/ed448-tests.in
-       touch $@
+keccak1600-test: keccak1600.o
+sha3-test: sha3.o keccak1600.o
+f25519-test: f25519.o
+x25519-test: x25519.o f25519.o
+ed25519-test: sha512.o f25519.o scaf.o ed25519.o
+fgoldi-test: fgoldi.o
+x448-test: x448.o fgoldi.o
+ed448-test: keccak1600.o sha3.o fgoldi.o scaf.o ed448.o
+
+f25519-test.o: ec-field-test.c
+       $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DFIELD=f25519 $< -o $@
+fgoldi-test.o: ec-field-test.c
+       $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DFIELD=fgoldi $< -o $@
+x25519-test.o: xdh-test.c
+       $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DXDH=x25519 -DFIELD=f25519 $< -o $@
+x448-test.o: xdh-test.c
+       $(CC) $(CPPFLAGS) $(ALL_CFLAGS) -c -DXDH=x448 -DFIELD=fgoldi $< -o $@
 
 check-ipaddrset: ipaddrset-test.py ipaddrset.py ipaddrset-test.expected
        $(srcdir)/ipaddrset-test.py >ipaddrset-test.new
@@ -268,8 +238,8 @@ clean:
        $(RM) -f *.o *.yy.[ch] *.tab.[ch] $(TARGETS) core version.c
        $(RM) -f *.d *.pyc *~ eax-*-test.confirm eax-*-test
        $(RM) -f msgcode-test.confirm msgcode-test
-       $(RM) -f $(addsuffix -test, $(XDH_FUNCS))
-       $(RM) -f $(addsuffix -test.confirm, $(XDH_FUNCS))
+       $(RM) -f $(addsuffix -test, $(CRYPTO_TESTS))
+       $(RM) -f $(addsuffix -test.confirm, $(CRYPTO_TESTS))
 
 realclean:     clean
        $(RM) -f *~ Makefile config.h  *.d \