-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
38 lines (27 loc) · 868 Bytes
/
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
# Makefile adapted from
# http://make.mad-scientist.net/papers/advanced-auto-dependency-generation/
OBJDIR := .obj
DEPDIR := .d
DATADIR := data
$(shell mkdir -p $(OBJDIR) > /dev/null)
$(shell mkdir -p $(DEPDIR) > /dev/null)
$(shell mkdir -p $(DATADIR) > /dev/null)
CXX = clang++
CXXFLAGS = -std=c++11 -Wall -Wextra -g -Ofast
DEPFLAGS = -MT $@ -MMD -MP -MF $(DEPDIR)/$*.Td
POSTCOMPILE = @mv -f $(DEPDIR)/$*.Td $(DEPDIR)/$*.d && touch $@
EXEC = htsim
SRCS = $(wildcard *.cpp)
OBJS = $(SRCS:%.cpp=$(OBJDIR)/%.o)
$(EXEC): $(OBJS)
$(CXX) $(CXXFLAGS) $^ -o $@
$(OBJS): $(OBJDIR)/%.o: %.cpp
$(OBJS): $(OBJDIR)/%.o: %.cpp $(DEPDIR)/%.d
$(CXX) $(CXXFLAGS) $(DEPFLAGS) -c $< -o $@
$(POSTCOMPILE)
$(DEPDIR)/%.d: ;
clean:
rm -frv $(OBJDIR) $(DEPDIR) $(EXEC)
.PRECIOUS: $(DEPDIR)/%.d
.PHONY: clean
include $(wildcard $(patsubst %,$(DEPDIR)/%.d,$(basename $(SRCS))))