-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathMakefile
executable file
·58 lines (50 loc) · 2.15 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
52
53
54
55
56
57
58
########################################################################################################
# General parameters of compilations
CXX=g++
CXX_FLAGS = -std=c++14 -Wall -O3 -I ./include/ -pthread -msse4.2
########################################################################################################
BUILD_DIR = build
BIN_DIR = bin
########################################################################################################
# Define object to be created
SRC_H_OBJ = $(wildcard src/*.h)
SRC_CPP_OBJ = $(subst .h,.cpp,$(SRC_H_OBJ))
SRC_CPP_KMC_OBJ = $(wildcard include/KMC/kmc_api/*.cpp)
OBJ = $(SRC_CPP_OBJ:src/%.cpp=$(BUILD_DIR)/%.o)
OBJ_KMC = $(SRC_CPP_KMC_OBJ:include/KMC/kmc_api/%.cpp=$(BUILD_DIR)/%.o)
########################################################################################################
# Define BIN to be created
SRC_CPP_BIN = $(filter-out $(SRC_CPP_OBJ),$(wildcard src/*.cpp))
BIN = $(SRC_CPP_BIN:src/%.cpp=%)
########################################################################################################
# Define dependencies - Gcc/Clang will create these .d files containing dependencies.
DEP = $(OBJ:%.o=%.d)
########################################################################################################
# Define rules
all: $(BIN)
@echo "Built everything"
$(BIN) : $(OBJ_KMC) $(OBJ)
@echo $^
mkdir -p bin
$(CXX) $(CXX_FLAGS) $^ src/$(notdir $@).cpp -o bin/$@
# Include all .d files
-include $(DEP)
.SECONDEXPANSION:
$(OBJ_KMC) : $$(patsubst %.o,%.cpp,include/KMC/kmc_api/$$(notdir $$@))
mkdir -p $(@D)
@echo $<
@echo $@
$(CXX) $(CXX_FLAGS) -MMD -c $< -o $@
# Build target for every single object file.
# The potential dependency on header files is covered
# by calling `-include $(DEP)`.
$(OBJ) : $$(patsubst %.o,%.cpp,src/$$(notdir $$@)) $(OBJ_KMC)
mkdir -p $(@D)
# The -MMD flags additionaly creates a .d file with
# # the same name as the .o file
$(CXX) $(CXX_FLAGS) -MMD -c $< -o $@
.PHONY : clean
clean :
# This should remove all generated files.
-rm $(BUILD_DIR) $(BIN_DIR) -Rf
########################################################################################################