-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathMakefile
More file actions
100 lines (87 loc) · 3.05 KB
/
Makefile
File metadata and controls
100 lines (87 loc) · 3.05 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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# ----------------------
# MACROS
# ----------------------
# DIRS
INCDIR = include
BINDIR = bin
SRCDIR = src
BUILDDIR = build
LIBDIR = lib
CCFLEX = cc
# LEXER
LEXER = $(BINDIR)/mjclexer
# TARGET
TARGET = $(BINDIR)/mjc
# EXTENSIONS
CPPSRCEXT = hpp
HEADEREXT = h
# SOURCES LIST
SOURCES = $(shell find $(SRCDIR) -type f -name *.$(SRCEXT))
# OBJECTS
OBJS = $(patsubst $(SRCDIR)/%, $(BUILDDIR)/%, $(SOURCES:.$(SRCEXT)=.o))
# COMPILER
CC = g++
# FLEX
FLEX = flex
# FOR CLEANING
RM = /bin/rm
# WARNING FLAG
WARN = -Wall
# DEBUG FLAGS
DEBUG = -g
# LINKING FLAGS
LIBOPTS =
LIBFLAG = -L $(LIBDIR) $(LIBOPTS)
INCFLAG = -I $(INCDIR)
LFLAGS = $(DEBUG) $(WARN) $(INCFLAG) $(LIBFLAG)
# COMPILATION FLAGS
CFLAGS = $(DEBUG) -c $(WARN) -std=c++11
# ----------------------
# ENTRIES
# ----------------------
$(TARGET): $(OBJS)
@echo "Linking..."
@echo " $(CC) $^ -o $(TARGET) $(LFLAGS)"; $(CC) $^ -o $(TARGET) $(LFLAGS)
$(BUILDDIR)/%.o: $(SRCDIR)/%.$(CPPSRCEXT)
@mkdir -p $(BUILDDIR)
@echo " $(CC) $(CFLAGS) $(INCFLAG) -o $@ $<"; $(CC) $(CFLAGS) $(INCFLAG) -o $@ $<
# DUMMY ENTRIES
ll1parser:
@echo "Making lexer...";
@mkdir -p $(BUILDDIR)
@mkdir -p $(BINDIR)
$(FLEX) -o $(SRCDIR)/lex.yy.c -ll $(SRCDIR)/mjclexer.l;
yacc -o $(SRCDIR)/y.tab.c $(SRCDIR)/MJLALRParser.y --defines=include/y.tab.h -v
g++ $(SRCDIR)/MJMessage.cpp $(SRCDIR)/MJNonRecursiveParser.cpp $(SRCDIR)/MJRecursiveParser.cpp $(SRCDIR)/lex.yy.c $(SRCDIR)/MJToken.cpp $(SRCDIR)/MJLexLexer.cpp $(SRCDIR)/ParserDriver.cpp -o $(BINDIR)/mjcll1 $(INCFLAG) -std=c++11 -Wall
lalrparser:
@echo "Making lexer...";
@mkdir -p $(BUILDDIR)
@mkdir -p $(BINDIR)
lex -o $(SRCDIR)/lex.yy.c $(SRCDIR)/mjclexer.l
yacc -o $(SRCDIR)/y.tab.c $(SRCDIR)/MJLALRParser.y --defines=include/y.tab.h
g++ $(SRCDIR)/MJToken.cpp $(SRCDIR)/MJMessage.cpp -o $(BINDIR)/mjclalr $(SRCDIR)/y.tab.c $(SRCDIR)/lex.yy.c $(INCFLAG) -std=c++11
lalrparserast:
@echo "Making lexer...";
@mkdir -p $(BUILDDIR)
@mkdir -p $(BINDIR)
lex -o $(SRCDIR)/lex.yy.c $(SRCDIR)/mjclexer.l
bison -o $(SRCDIR)/y.tab.c $(SRCDIR)/MJLALRParser.y --defines=include/y.tab.h
g++ $(SRCDIR)/ast/Expr.cpp $(SRCDIR)/MJToken.cpp $(SRCDIR)/MJMessage.cpp -o $(BINDIR)/mjclalr $(SRCDIR)/y.tab.c $(SRCDIR)/lex.yy.c $(INCFLAG) -std=c++11
lalrcodegen:
@echo "Making lexer...";
@mkdir -p $(BUILDDIR)
@mkdir -p $(BINDIR)
lex -o $(SRCDIR)/lex.yy.c $(SRCDIR)/mjclexer.l
bison -o $(SRCDIR)/y.tab.c $(SRCDIR)/MJLALRParser.y --defines=include/y.tab.h
g++ $(SRCDIR)/code-generation/NodeVisitorCodeGen.cpp $(SRCDIR)/ast/Expr.cpp $(SRCDIR)/MJToken.cpp $(SRCDIR)/MJMessage.cpp -o $(BINDIR)/mjccodegen $(SRCDIR)/y.tab.c $(SRCDIR)/lex.yy.c $(INCFLAG) -std=c++11
lexer:
@echo "Building lexer...";
@mkdir -p $(BUILDDIR)
@mkdir -p $(BINDIR)
$(FLEX) -o $(BUILDDIR)/lex.yy.c $(SRCDIR)/mjclexer.l;
yacc -o $(SRCDIR)/y.tab.c $(SRCDIR)/MJLALRParser.y --defines=include/y.tab.h -v
g++ $(SRCDIR)/MJMessage.cpp $(SRCDIR)/MJToken.cpp $(BUILDDIR)/lex.yy.c -D__EXECUTABLE__ -o $(LEXER) $(INCFLAG) -std=c++11
clean:
@echo "Cleaning..."
@echo " $(RM) -r $(BUILDDIR) $(TARGET)"; $(RM) -rf $(BUILDDIR) $(BINDIR)
.PHONY: clean lexer