diff options
author | Jari Vetoniemi <mailroxas@gmail.com> | 2017-04-20 16:49:35 +0300 |
---|---|---|
committer | Jari Vetoniemi <mailroxas@gmail.com> | 2017-05-01 22:58:22 +0300 |
commit | 29086b1d12a2c28cffdbfbf0b3990a7bd75506b9 (patch) | |
tree | 8acd48bc30932812744c0adb102d7a7add494357 /Makefile | |
parent | 76b8c9e03c97b16d9ff97f3b79c0ecbff0f5e7f2 (diff) |
work in progress
Diffstat (limited to 'Makefile')
-rw-r--r-- | Makefile | 61 |
1 files changed, 37 insertions, 24 deletions
@@ -1,42 +1,55 @@ PREFIX ?= /usr/local bindir ?= /bin -WARNINGS := -Wall -Wextra -Wformat=2 -Winit-self -Wfloat-equal -Wcast-align -Wpointer-arith -CFLAGS += -std=c11 $(WARNINGS) +MAKEFLAGS += --no-builtin-rules -all: fspec-dump dec2bin xidec xi2path xils xifile +# GCC 7: -Wstringop-overflow=, -Walloc-size-larger-than=, -Wduplicated-{branches,cond} +WARNINGS := -Wall -Wextra -Wpedantic -Wformat=2 -Wstrict-aliasing=3 -Wstrict-overflow=5 -Wstack-usage=12500 \ + -Wfloat-equal -Wcast-align -Wpointer-arith -Wchar-subscripts + +override CFLAGS ?= -g +override CFLAGS += -std=c11 $(WARNINGS) +override CPPFLAGS += -Isrc + +bins = fspec-dump dec2bin xidec xi2path xils xifile uneaf +all: $(bins) %.c: %.rl ragel $^ -fspec-dump: src/ragel/ragel.h src/ragel/fspec.h src/ragel/fspec.c src/dump.c - $(LINK.c) $(filter %.c,$^) $(LDLIBS) -o $@ +%.a: + $(LINK.c) -c $(filter %.c,$^) $(LDLIBS) -o $@ + +$(bins): %: + $(LINK.c) $(filter %.c %.a,$^) $(LDLIBS) -o $@ + +fspec-ragel.a: src/ragel/ragel.h src/ragel/ragel.c +fspec-bcode.a: src/fspec/memory.h src/fspec/bcode.h src/fspec/bcode.c +fspec-lexer.a: src/ragel/ragel.h src/fspec/lexer.h src/fspec/lexer.c +fspec-validator.a: src/ragel/ragel.h src/fspec/validator.h src/fspec/validator.c -dec2bin: src/utils/dec2bin.c - $(LINK.c) $(filter %.c,$^) $(LDLIBS) -o $@ +fspec-dump: private CPPFLAGS += $(shell pkg-config --cflags-only-I squash-0.8) +fspec-dump: private LDLIBS += $(shell pkg-config --libs-only-l squash-0.8) +fspec-dump: src/dump.c fspec-ragel.a fspec-bcode.a fspec-lexer.a fspec-validator.a -xidec: src/xi/xidec.c - $(LINK.c) $(filter %.c,$^) $(LDLIBS) -o $@ +dec2bin: src/bin/misc/dec2bin.c -xi2path: src/xi/xi2path.c - $(LINK.c) $(filter %.c,$^) $(LDLIBS) -o $@ +xidec: src/bin/xi/xidec.c +xi2path: src/bin/xi/xi2path.c +xils: src/bin/xi/xils.c +xifile: src/bin/xi/xifile.c -xils: src/xi/xils.c - $(LINK.c) $(filter %.c,$^) $(LDLIBS) -o $@ +uneaf: private LDLIBS += $(shell pkg-config --libs-only-l zlib) +uneaf: src/bin/fw/uneaf.c -xifile: src/xi/xifile.c - $(LINK.c) $(filter %.c,$^) $(LDLIBS) -o $@ +install-bin: $(bins) + install -dm755 "$(DESTDIR)$(PREFIX)$(bindir)" + install -m755 $^ "$(DESTDIR)$(PREFIX)$(bindir)/" -install: - install -Dm755 $(DESTDIR)$(PREFIX)$(bindir)/fspec-dump - install -Dm755 $(DESTDIR)$(PREFIX)$(bindir)/dec2bin - install -Dm755 $(DESTDIR)$(PREFIX)$(bindir)/xidec - install -Dm755 $(DESTDIR)$(PREFIX)$(bindir)/xi2path - install -Dm755 $(DESTDIR)$(PREFIX)$(bindir)/xils - install -Dm755 $(DESTDIR)$(PREFIX)$(bindir)/xifile +install: install-bin clean: - $(RM) src/ragel/fspec.c - $(RM) fspec-dump dec2bin xidec xi2path xils xifile + $(RM) src/ragel/ragel.c src/fspec/lexer.c src/fspec/validator.c + $(RM) $(bins) *.a .PHONY: all clean install |