-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
90 lines (69 loc) · 1.75 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
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
NAME := skeleton
# Compiler and linker
CXX := clang++
LD := clang++
# Paths
SRCDIR := src
INCDIR := include
LIBDIR := ..
OBJDIR := obj
BINDIR := .
# Library dependencies
LIBS := $(addprefix $(LIBDIR)/, )
LIBDIRS := $(dir $(LIBS))
LIBINCS := $(addsuffix $(INCDIR), $(LIBDIRS))
LIBARS := $(notdir $(LIBS))
# Sources
INCS := $(LIBINCS) $(INCDIR)
SRCS := $(addprefix $(SRCDIR)/,\
main.cpp\
)
OBJS := $(SRCS:$(SRCDIR)/%.cpp=$(OBJDIR)/%.o)
DEPS := $(OBJS:.o=.d)
# Flags
CXXFLAGS := -Wall -Wextra -Werror -Wpedantic -std=c++98 $(INCS:%=-I%)
DFLAGS = -MT $@ -MMD -MP -MF $(OBJDIR)/$*.d
LDFLAGS := $(LIBDIRS:%=-L%)
LDLIBS := $(LIBARS:lib%.a=-l%)
# Compiling commands
COMPILE.cpp = $(CXX) $(DFLAGS) $(CXXFLAGS) -c
COMPILE.o = $(LD) $(LDFLAGS)
all: $(BINDIR)/$(NAME)
# Directories
$(OBJDIR) $(BINDIR):
@echo "MK $@"
mkdir -p "$@"
# Libraries
$(LIBS): %.a: FORCE
$(MAKE) -C $(dir $@) NAME=$(@F)
# Objects
$(OBJS): $(OBJDIR)/%.o: $(SRCDIR)/%.cpp | $(OBJDIR)
@mkdir -p '$(@D)'
@echo "CXX $<"
$(COMPILE.cpp) $< -o $@
# Dependencies
$(DEPS): $(OBJDIR)/%.d:
include $(wildcard $(DEPS))
# Binaries
$(BINDIR)/$(NAME): $(OBJS) $(LIBS) | $(BINDIR)
@echo "LD $@ $(LIBARS:lib%.a=-l%)"
$(COMPILE.o) $< -o $@ $(LDLIBS)
# Remove temporary objects
clean:
$(foreach libdir, $(LIBDIRS),\
echo "MK -C $(libdir) $@" && $(MAKE) -C $(libdir) $@ && ):
@echo "RM $(OBJDIR)"
rm -rf "$(OBJDIR)"
# Remove all binaries
fclean: clean
$(foreach libdir, $(LIBDIRS),\
echo "MK -C $(libdir) $@" && $(MAKE) -C $(libdir) $@ && ):
@echo "RM $(BINDIR)/$(NAME)"
rm -f "$(BINDIR)/$(NAME)"
@rmdir "$(BINDIR)" 2>/dev/null && echo "RM $(BINDIR)" || :
# Remove and rebuild all binaries
re: fclean all
FORCE: ;
.PHONY: all clean fclean re
# Assign a value to VERBOSE to enable verbose output
$(VERBOSE).SILENT: