-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy pathmakefile
More file actions
45 lines (33 loc) · 1.01 KB
/
makefile
File metadata and controls
45 lines (33 loc) · 1.01 KB
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
LEX=flex
LEXFLAGS=
YACC=bison
YACCFLAGS=-v -t -d
CC=gcc
CFLAGS=-ggdb
LIBS=
PARSER=parser
SCANNER=scanner
OBJS=$(SCANNER).o $(PARSER).o ast.o base.o symbol_table.o typecheck_visitor.o graphprinter_visitor.o
PROGRAM=compiler
all: $(OBJS)
$(CC) $(LIBS) $(OBJS) -o $(PROGRAM)
graphprinter_visitor.o: graphprinter_visitor.c graphprinter_visitor.h
$(CC) $(CFLAGS) graphprinter_visitor.c -c
typecheck_visitor.o: typecheck_visitor.c typecheck_visitor.h
$(CC) $(CFLAGS) typecheck_visitor.c -c
symbol_table.o: symbol_table.c symbol_table.h
$(CC) $(CFLAGS) symbol_table.c -c
ast.o: ast.c ast.h
$(CC) $(CFLAGS) ast.c -c
base.o: base.c base.h
$(CC) $(CFLAGS) base.c -c
$(PARSER).o: $(PARSER).c $(PARSER).h
$(CC) $(CFLAGS) $(PARSER).c -c
$(SCANNER).o: $(SCANNER).c $(PARSER).h
$(CC) $(CFLAGS) $(SCANNER).c -c
$(SCANNER).c: $(SCANNER).l
$(LEX) $(LEXFLAGS) -o$(SCANNER).c $(SCANNER).l
$(PARSER).h: $(PARSER).y
$(YACC) $(YACCFLAGS) $(PARSER).y -o $(PARSER).c
clean:
rm -rf $(SCANNER).c $(PARSER).c $(PARSER).h *.o $(PROGRAM)