summaryrefslogtreecommitdiff
path: root/Makefile
blob: 43483955ebb5f8a92e48700c3b5a61140eed736a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
MKDIR   := mkdir
RMDIR   := rm -r
RM      := rm
CC      := gcc
BINDIR  := ./bin
TESTDIR := ./test
SRCDIRS := ./
SRCS    := $(foreach fd, $(SRCDIRS), $(wildcard $(fd)/*.c))
OBJS    := $(patsubst %.c,$(BINDIR)/%.o,$(SRCS))
ARCFIND := $(BINDIR)/arcfind
EXES    := $(ARCFIND)
CFLAGS  := $(addprefix -I,$(SRCDIRS)) $(XTRAFLAGS)
LDLIBS  :=

ARCFIND_O  := $(addprefix ./bin/, main.o tree.o bu-parser.o truth_table.o)

all: $(EXES)
.PHONY: all

$(BINDIR)/%.o: %.c | $(BINDIR)
	$(CC) $(CFLAGS) -c -o $@ $^ $(LDLIBS)

include $(DEPS)

$(ARCFIND): $(ARCFIND_O) | $(BINDIR)
	$(CC) $(CFLAGS) -o $@ $^ $(LDLIBS)

# TODO: one good rule for the test bins

$(BINDIR):
	$(MKDIR) $@

$(TESTDIR):
	$(MKDIR) $@

debug:
	$(MAKE) XTRAFLAGS:="-g -fsanitize=undefined -fsanitize-undefined-trap-on-error -fno-omit-frame-pointer -O0 -DDEBUG -Wuninitialized"
.PHONY: debug

release:
	$(MAKE) XTRAFLAGS:="-O3"
.PHONY: release

clean:
	-$(RM) $(OBJS)
	-$(RM) $(EXES)
.PHONY: clean