-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
86 lines (58 loc) · 1.89 KB
/
Makefile
File metadata and controls
86 lines (58 loc) · 1.89 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
LIB=CodeParser
DRIVER=CodeParser_driver
TEST=test_binary
C=gcc
CFLAGS= -Wall
CXX=g++
CXXFLAGS= -std=c++11 -g -I./include -Wall
LIB_FLAGS=-fPIC
LIB_OBJDIR=./obj/lib
LIB_SRCDIR=./src/lib
LIB_BINDIR=./bin/lib
DRIVER_OBJDIR=./obj/driver
DRIVER_SRCDIR=./src/driver
DRIVER_BINDIR=./bin/driver
DRIVER_LDFLAGS=-L$(LIB_BINDIR)
DRIVER_LFLAGS=-l$(LIB)
TEST_OBJDIR=./obj/test
TEST_SRCDIR=./src/test
TEST_BINDIR=./bin/test
LIB_SRCS=$(shell find $(LIB_SRCDIR) -maxdepth 1 -type f -name "*.cpp")
LIB_OBJS=$(patsubst $(LIB_SRCDIR)/%.cpp, $(LIB_OBJDIR)/%.o, $(LIB_SRCS))
DRIVER_SRCS=$(shell find $(DRIVER_SRCDIR) -maxdepth 1 -type f -name "*.cpp")
DRIVER_OBJS=$(patsubst $(DRIVER_SRCDIR)/%.cpp, $(DRIVER_OBJDIR)/%.o, $(DRIVER_SRCS))
TEST_SRCS=$(shell find $(TEST_SRCDIR) -maxdepth 1 -type f -name "*.c")
TEST_OBJS=$(patsubst $(TEST_SRCDIR)/%.c, $(TEST_OBJDIR)/%.o, $(TEST_SRCS))
all: $(LIB) $(DRIVER) $(TEST)
lib: $(LIB)
driver: $(DRIVER)
test: $(TEST)
$(LIB): $(LIB_OBJS)
$(CXX) -shared -Wl,-soname,lib$(LIB).so $(LIB_OBJS) -lc -o $(LIB_BINDIR)/lib$(LIB).so
$(LIB_OBJS): $(LIB_OBJDIR)/%.o : $(LIB_SRCDIR)/%.cpp LIB_PRINT
$(CXX) $(CXXFLAGS) $(LIB_FLAGS) $(LDFLAGS) -c $< -o $@
.PHONY: LIB_PRINT
LIB_PRINT:
@printf "\nMaking lib ojects...\n"
$(DRIVER): $(DRIVER_OBJS)
$(CXX) $(CXXFLAGS) $(DRIVER_LDFLAGS) $^ $(DRIVER_LFLAGS) -o $(DRIVER_BINDIR)/$(DRIVER)
$(DRIVER_OBJDIR)/%.o : $(DRIVER_SRCDIR)/%.cpp DRIVER_PRINT
$(CXX) $(CXXFLAGS) $(LDFLAGS) -c $< -o $@
.PHONY: DRIVER_PRINT
DRIVER_PRINT:
@printf "\nMaking driver objects...\n"
$(TEST): $(TEST_OBJS)
$(C) $(CFLAGS) $^ -o $(TEST_BINDIR)/$(TEST)
$(TEST_OBJDIR)/%.o : $(TEST_SRCDIR)/%.c TEST_PRINT
$(C) $(CFLAGS) -c $< -o $@
.PHONY: TEST_PRINT
TEST_PRINT:
@printf "\nMaking test objects...\n"
.PHONY: clean
clean:
rm -f $(LIB_OBJDIR)/*.o
rm -f $(LIB_BINDIR)/*
rm -f $(DRIVER_OBJDIR)/*.o
rm -f $(DRIVER_BINDIR)/*
rm -f $(TEST_OBJDIR)/*.o
rm -f $(TEST_BINDIR)/*