From 1816e8b3564708f62296217b8cff0f7188b7c9f3 Mon Sep 17 00:00:00 2001 From: Daniel Karbach Date: Tue, 10 Mar 2015 22:36:07 +0100 Subject: [PATCH] build both release and debug at the same time oh wow don't miss to run make clean before merging this, otherwise rm build/*.[do] --- .gitignore | 1 + Makefile | 59 +++++++++++++++++++++++++++++++++++++----------------- 2 files changed, 42 insertions(+), 18 deletions(-) diff --git a/.gitignore b/.gitignore index efe752e..e8f25c7 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ *.swp *.swo blank +blank.debug build diff --git a/Makefile b/Makefile index 0665d5c..e44a871 100644 --- a/Makefile +++ b/Makefile @@ -13,39 +13,62 @@ CXXFLAGS += -Wall LDXXFLAGS ?= LDXXFLAGS += $(PKGLIBS) -# debug -CXXFLAGS += -g3 -O0 - -# release -#CPPFLAGS += -DNDEBUG +DEBUG_FLAGS = -g3 -O0 +RELEASE_FLAGS = -DNDEBUG -O2 SOURCE_DIR := src -BUILD_DIR := build +DEBUG_DIR := build/debug +RELEASE_DIR := build/release +DIR := $(RELEASE_DIR) $(DEBUG_DIR) build -SRC = $(wildcard $(SOURCE_DIR)/*.cpp) -OBJ = $(patsubst $(SOURCE_DIR)/%.cpp, $(BUILD_DIR)/%.o, $(SRC)) -DEP = $(OBJ:.o=.d) -BIN = blank +SRC := $(wildcard $(SOURCE_DIR)/*.cpp) +RELEASE_OBJ := $(patsubst $(SOURCE_DIR)/%.cpp, $(RELEASE_DIR)/%.o, $(SRC)) +DEBUG_OBJ := $(patsubst $(SOURCE_DIR)/%.cpp, $(DEBUG_DIR)/%.o, $(SRC)) +RELEASE_DEP := $(RELEASE_OBJ:.o=.d) +DEBUG_DEP := $(DEBUG_OBJ:.o=.d) +RELEASE_BIN := blank +DEBUG_BIN := blank.debug +OBJ := $(RELEASE_OBJ) $(DEBUG_OBJ) +DEP := $(RELEASE_DEP) $(DEBUG_DEP) +BIN := $(RELEASE_BIN) $(DEBUG_BIN) all: $(BIN) +release: $(RELEASE_BIN) + +debug: $(DEBUG_BIN) + +run: blank + ./blank + +gdb: blank.debug + gdb ./blank.debug + clean: - rm -df $(OBJ) $(DEP) $(BUILD_DIR) + rm -df $(OBJ) $(DEP) $(DIR) distclean: clean rm -f $(BIN) -.PHONY: all clean distclean +.PHONY: all release debug run gdb clean distclean -include $(DEP) -$(BIN): $(OBJ) +$(RELEASE_BIN): $(RELEASE_OBJ) @echo link: $@ - @$(LDXX) -o $@ $(CXXFLAGS) $(LDXXFLAGS) $^ + @$(LDXX) -o $@ $(CXXFLAGS) $(LDXXFLAGS) $(RELEASE_FLAGS) $^ + +$(DEBUG_BIN): $(DEBUG_OBJ) + @echo link: $@ + @$(LDXX) -o $@ $(CXXFLAGS) $(LDXXFLAGS) $(DEBUG_FLAGS) $^ + +$(RELEASE_DIR)/%.o: $(SOURCE_DIR)/%.cpp | $(RELEASE_DIR) + @echo compile: $@ + @$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $(RELEASE_FLAGS) -o $@ -MMD -MP -MF"$(@:.o=.d)" -MT"$@" $< -$(BUILD_DIR)/%.o: $(SOURCE_DIR)/%.cpp | $(BUILD_DIR) +$(DEBUG_DIR)/%.o: $(SOURCE_DIR)/%.cpp | $(DEBUG_DIR) @echo compile: $@ - @$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) -o $@ -MMD -MP -MF"$(@:.o=.d)" -MT"$@" $< + @$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $(DEBUG_FLAGS) -o $@ -MMD -MP -MF"$(@:.o=.d)" -MT"$@" $< -$(BUILD_DIR): - mkdir "$@" +$(DIR): + @mkdir -p "$@" -- 2.39.2