-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
51 lines (42 loc) · 1.43 KB
/
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
CXX := g++
TARGET := cell_move_router
OPENMPFLAG :=
CXXFLAGS := -std=c++11 -O3 -static -static-libstdc++ -static-libgcc
WARNINGFLAGS := -Wall -Wextra
INCLUDE := src/include
SRC_DIRS := src\
src/lib\
src/lib/cell_move_router\
src/lib/cell_move_router/Input/Raw\
src/lib/cell_move_router/Input/Processed\
src/lib/cell_move_router/Grid\
src/lib/cell_move_router/Router\
src/lib/cell_move_router/RegionCalculator\
src/lib/cell_move_router/Mover
FLUTE_WRAPPER_DIR := $(INCLUDE)/Third/Flute3-Cpp-Wrapper
FLUTE_WRAPPER_LIB := $(FLUTE_WRAPPER_DIR)/libflute3wrapper.a
SRCS := $(wildcard $(SRC_DIRS:=/*.cpp))
OBJS := $(SRCS:.cpp=.o)
DEPS = $(OBJS:.o=.d)
ifndef BOOST_LIBRARY_PATH
BOOST_LIBRARY_PATH := ""
endif
all: $(TARGET)
$(TARGET): $(OBJS) $(FLUTE_WRAPPER_LIB)
$(CXX) -o $@ $^ -lpthread $(OPENMPFLAG)
$(FLUTE_WRAPPER_LIB):
$(MAKE) -C $(FLUTE_WRAPPER_DIR)
%.o: %.cpp
$(CXX) $(CXXFLAGS) $(WARNINGFLAGS) $(OPENMPFLAG) -I $(INCLUDE) -isystem $(BOOST_LIBRARY_PATH) -MMD -c $< -o $@
clean:
rm -rf $(TARGET) $(OBJS) $(DEPS)
ifeq (test,$(firstword $(MAKECMDGOALS)))
TEST_CASE_ID := $(wordlist 2,$(words $(MAKECMDGOALS)),$(MAKECMDGOALS))
$(eval $(TEST_CASE_ID):;@:)
endif
test: $(TARGET)
@echo test on case$(TEST_CASE_ID)
./$(TARGET) benchmark/case$(TEST_CASE_ID).txt evaluator/output_$(TEST_CASE_ID).txt
./evaluator/evaluator benchmark/case$(TEST_CASE_ID).txt evaluator/output_$(TEST_CASE_ID).txt
.PHONY: all clean test
-include $(DEPS)