-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
33 lines (25 loc) · 863 Bytes
/
Makefile
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
GCC = gcc -Wall -Wextra -g -rdynamic
SRCDIR = ./src
BINDIR = ./bin
TESTDIR = ./test
MODULES = util syntax lexer parser typecheck interpreter icode icodegen \
icode_interpreter vmcodegen vmcode_interpreter ncode ncodegen \
testing_programs
MAIN = ./main
all: $(MAIN)
$(MAIN): $(addprefix $(BINDIR)/, $(MODULES:=.o)) ./src/main.c
$(GCC) -o $@ $^
$(BINDIR)/%.o: $(SRCDIR)/%.c $(SRCDIR)/%.h src/lexer.c src/parser.c
@mkdir -p ./bin/
$(GCC) -c -o $@ $<
src/lexer.c: src/lexer.l
flex -o $@ $^
src/parser.c: src/parser.y
bison -o $@ $^
.PHONY: clean
clean:
@rm -rf ./main ./bin/ ./src/lexer.c ./src/parser.c
test: $(addprefix $(BINDIR)/test_, $(MODULES))
@$(addprefix $(BINDIR)/test_, $(MODULES:= && )) echo "All tests passed."
$(BINDIR)/test_%: $(TESTDIR)/test_%.c $(addprefix $(BINDIR)/, $(MODULES:=.o))
@$(GCC) -o $@ $^ -iquote $(SRCDIR)