aboutsummaryrefslogtreecommitdiffstats
path: root/Makefile
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2017-10-14 12:15:35 +0200
committerMattias Andrée <maandree@kth.se>2017-10-14 12:25:36 +0200
commit9e821d21b1a6462b6d6fad288599e76eaa273603 (patch)
tree8e2e024c43bffcbb78aceb0a9ebc01d7b831e92c /Makefile
parentDo not use texman (diff)
downloadsha3sum-9e821d21b1a6462b6d6fad288599e76eaa273603.tar.gz
sha3sum-9e821d21b1a6462b6d6fad288599e76eaa273603.tar.bz2
sha3sum-9e821d21b1a6462b6d6fad288599e76eaa273603.tar.xz
Simplify makefile
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
-rw-r--r--Makefile149
1 files changed, 44 insertions, 105 deletions
diff --git a/Makefile b/Makefile
index 5590bd0..007ad42 100644
--- a/Makefile
+++ b/Makefile
@@ -1,36 +1,26 @@
.NONPOSIX:
-PREFIX = /usr/local
-BINDIR = $(PREFIX)/bin
-DATADIR = $(PREFIX)/share
-DOCDIR = $(DATADIR)/doc
-MANDIR = $(DATADIR)/man
-INFODIR = $(DATADIR)/info
-LICENSEDIR = $(DATADIR)/licenses
-
-PKGNAME = sha3sum
-
-WARN = -Wall -Wextra -pedantic -Wdouble-promotion -Wformat=2 -Winit-self -Wmissing-include-dirs \
- -Wtrampolines -Wfloat-equal -Wshadow -Wmissing-prototypes -Wmissing-declarations \
- -Wredundant-decls -Wnested-externs -Winline -Wno-variadic-macros -Wswitch-default \
- -Wpadded -Wsync-nand -Wunsafe-loop-optimizations -Wcast-align -Wstrict-overflow \
- -Wdeclaration-after-statement -Wundef -Wbad-function-cast -Wcast-qual -Wlogical-op \
- -Wstrict-prototypes -Wold-style-definition -Wpacked -Wvector-operation-performance \
- -Wunsuffixed-float-constants -Wsuggest-attribute=const -Wsuggest-attribute=noreturn \
- -Wsuggest-attribute=pure -Wsuggest-attribute=format -Wnormalized=nfkc
-
-LDOPTIMISE =
-COPTIMISE = -O3
-
-FLAGS = $(WARN) -std=gnu99
-
-
-KECCAK_CMDS = keccak-224sum keccak-256sum keccak-384sum keccak-512sum keccaksum
-SHA3_CMDS = sha3-224sum sha3-256sum sha3-384sum sha3-512sum
-RAWSHAKE_CMDS = rawshake256sum rawshake512sum
-SHAKE_CMDS = shake256sum shake512sum
-
-CMDS = $(KECCAK_CMDS) $(SHA3_CMDS) $(RAWSHAKE_CMDS) $(SHAKE_CMDS)
+CONFIGFILE = config.mk
+include $(CONFIGFILE)
+
+
+BIN =\
+ keccaksum\
+ keccak-224sum\
+ keccak-256sum\
+ keccak-384sum\
+ keccak-512sum\
+ sha3-224sum\
+ sha3-256sum\
+ sha3-384sum\
+ sha3-512sum\
+ rawshake256sum\
+ rawshake512sum\
+ shake256sum\
+ shake512sum
+
+MAN1 = $(BIN:=.1)
+HDR = common.h
keccak-224sum = Keccak-224
keccak-256sum = Keccak-256
@@ -47,86 +37,35 @@ shake256sum = SHAKE256
shake512sum = SHAKE512
-MAN1 =\
- keccaksum.1\
- keccak-224sum.1\
- keccak-256sum.1\
- keccak-384sum.1\
- keccak-512sum.1\
- sha3-224sum.1\
- sha3-256sum.1\
- sha3-384sum.1\
- sha3-512sum.1\
- rawshake256sum.1\
- rawshake512sum.1\
- shake256sum.1\
- shake512sum.1
+all: $(BIN) $(MAN1)
+%: %.o common.o
+ $(CC) -o $@ $^ $(LDFLAGS)
-
-.PHONY: all
-all: command $(MAN1)
-
-
-.PHONY: command
-command: $(foreach C,$(CMDS),bin/$(C))
-
-bin/%: obj/%.o obj/common.o
- @mkdir -p bin
- $(CC) $(FLAGS) $(LDOPTIMISE) -o $@ $^ $(LDFLAGS) -lkeccak -largparser
-
-obj/%.o: src/%.c src/*.h
- @mkdir -p obj
- $(CC) $(FLAGS) $(COPTIMISE) -c -o $@ $< $(CFLAGS) $(CPPFLAGS)
-
+%.o: %.c $(HDR)
+ $(CC) -c -o $@ $< $(CFLAGS) $(CPPFLAGS)
%.1: xsum.1
- u=$$(printf '%s\n' $* | tr a-z A-Z); sed -e 's/xsum/$*/g' -e 's/XSUM/'"$$u"'/g' -e 's/Xsum/$($*)/g' < xsum.1 > $@
-
+ u=$$(printf '%s\n' $* | tr a-z A-Z); \
+ sed -e 's/xsum/$*/g' -e 's/XSUM/'"$$u"'/g' -e 's/Xsum/$($*)/g' < xsum.1 > $@
-.PHONY: install
-install: install-command install-license install-man
+install:
+ mkdir -p -- "$(DESTDIR)$(PREFIX)/bin"
+ mkdir -p -- "$(DESTDIR)$(MANPREFIX)/man1"
+ mkdir -p -- "$(DESTDIR)$(PREFIX)/share/licenses/sha3sum"
+ cp -- $(BIN) "$(DESTDIR)$(PREFIX)/bin/"
+ cp -- $(MAN1) "$(DESTDIR)$(MANPREFIX)/man1/"
+ cp -- LICENSE "$(DESTDIR)$(PREFIX)/share/licenses/sha3sum/"
-.PHONY: install-command
-install-command: install-keccak install-sha3 install-rawshake install-shake
-
-.PHONY: install-keccak
-install-keccak: $(foreach C,$(KECCAK_CMDS),install-$(C))
-
-.PHONY: install-sha3
-install-sha3: $(foreach C,$(SHA3_CMDS),install-$(C))
-
-.PHONY: install-rawshake
-install-rawshake: $(foreach C,$(RAWSHAKE_CMDS),install-$(C))
-
-.PHONY: install-shake
-install-shake: $(foreach C,$(SHAKE_CMDS),install-$(C))
-
-.PHONY: install-%sum
-install-%sum: bin/%sum
- install -dm755 -- "$(DESTDIR)$(BINDIR)"
- install -m755 -- $< "$(DESTDIR)$(BINDIR)/$*sum"
-
-.PHONY: install-license
-install-license:
- install -dm755 -- "$(DESTDIR)$(LICENSEDIR)/$(PKGNAME)"
- install -m644 -- LICENSE "$(DESTDIR)$(LICENSEDIR)/$(PKGNAME)/LICENSE"
-
-.PHONY: install-man
-install-man: $(MAN1)
- mkdir -p -- "$(DESTDIR)$(MANDIR)/man1"
- cp -- $(MAN1) "$(DESTDIR)$(MANDIR)/man1/"
-
-
-
-.PHONY: uninstall
uninstall:
- -rm -- $(foreach C,$(CMDS),"$(DESTDIR)$(BINDIR)/$(C)")
- -rm -- "$(DESTDIR)$(LICENSEDIR)/$(PKGNAME)/LICENSE"
- -rmdir -- "$(DESTDIR)$(LICENSEDIR)/$(PKGNAME)"
- -cd -- "$(DESTDIR)$(MANDIR)/man1" && rm -- $(MAN1)
+ -cd -- "$(DESTDIR)$(PREFIX)/bin" && rm -- $(BIN)
+ -cd -- "$(DESTDIR)$(MANPREFIX)/man1" && rm -- $(MAN1)
+ -rm -- "$(DESTDIR)$(PREFIX)/share/licenses/sha3sum/LICENSE"
+ -rmdir -- "$(DESTDIR)$(PREFIX)/share/licenses/sha3sum"
-
-.PHONY: clean
clean:
- -rm -r -- bin obj $(MAN1)
+ -rm -r -- $(MAN1) $(BIN)
+
+.SUFFIXES:
+
+.PHONY: all install uninstall clean