code re-organized

This commit is contained in:
Thomas Klaehn
2020-02-20 22:19:09 +01:00
parent 8234b46a7d
commit 7d313f9f74
13 changed files with 43 additions and 70 deletions

View File

@@ -1,3 +1,4 @@
PLATFORM ?= posix
CROSS_COMPILE ?=
TARGET_FILE ?= test_c
@@ -18,9 +19,8 @@ UNIT_TEST_OBJ_DIR = $(OBJ_DIR)/$(UNIT_TEST_SRC_DIR)
PREFIX ?= /usr
BIN_INSTALL_DIR = $(PREFIX)/bin
INCLUDES := interface/
INCLUDES += include/
INCLUDES += include/$(ARCH)/
INCLUDES += include/platform/$(PLATFORM)/
INCLUDES += $(PREFIX)/include/
INCLUDES += $(EXTRA_INC)
@@ -39,12 +39,13 @@ C_FLAGS += -fpic
C_FLAGS += -O0 -ggdb3 -Wall
CPP_FLAGS += $(addprefix -I, $(INCLUDES))
CPP_FLAGS += -DPLATFORM=$(PLATFORM) -DPLATFORM_$(PLATFORM)
CHECK_FLAGS = $(addprefix -I,$(filter-out $(PREFIX)/include/,$(INCLUDES)))
CHECK_FLAGS += --enable=all --template=gcc --error-exitcode=1 --suppress=missingIncludeSystem --inline-suppr --force
CHECK_FLAGS += --enable=all --template=gcc --error-exitcode=1 --suppress=missingIncludeSystem --inline-suppr --force --xml --xml-version=2 2> cppcheck-report.xml
C_SRCS = $(wildcard $(SRC_DIR)/*.c)
C_SRCS += $(wildcard $(SRC_DIR)/$(ARCH)/*.c)
C_SRCS += $(wildcard $(SRC_DIR)/platform/$(PLATFORM)/*.c)
C_OBJS = $(patsubst $(SRC_DIR)%,$(OBJ_DIR)%,$(patsubst %.c,%.o,$(C_SRCS)))
UNIT_TEST_SRCS = $(wildcard $(UNIT_TEST_SRC_DIR)/*.c) $(filter-out %main.c,$(CC_SRCS))
@@ -60,7 +61,7 @@ THIS_MAKEFILE := $(lastword $(MAKEFILE_LIST))
debug:
@echo $(C_SRCS)
@echo $(C_OBJS)
@echo $(ARCH)
@echo $(PLATFORM)
@echo $(CPP_FLAGS)
all: $(TARGET)
@@ -84,6 +85,12 @@ clean:
distclean:
rm -rf $(OBJ_DIR) $(BIN_DIR) $(COVERAGE_DIR)
.PHONY: check
check: $(C_SRCS)
echo $(C_SRCS)
cppcheck $(CHECK_FLAGS) $(C_SRCS)
.PHONY: coverage
coverage: _cov_genhtml
$(eval COVERAGE:=$(shell grep 'lines' .coverage.tmp | egrep -o '[0-9]+.[0-9]+%'))
@@ -110,10 +117,6 @@ build_unit_test: $(UNIT_TEST_TARGET)
exec_unit_test: $(UNIT_TEST_TARGET)
$(UNIT_TEST_TARGET)
.PHONY: check
check: $(CC_SRCS)
$(CHECK) $(CHECK_FLAGS) $(CC_SRCS)
$(UNIT_TEST_TARGET): $(UNIT_TEST_OBJS) $(THIS_MAKEFILE)
@mkdir -p $(BIN_DIR)/$(UNIT_TEST_SRC_DIR)
$(CC) $(C_FLAGS) $(LD_FLAGS) $(UNIT_TEST_OBJS) -o $@
@@ -124,7 +127,7 @@ $(TARGET): $(OBJS) $(THIS_MAKEFILE)
.PRECIOUS: $(OBJ_DIR)/%.d
$(OBJ_DIR)/%.d: $(SRC_DIR)/%.c
@mkdir -p $(OBJ_DIR)/$(ARCH)
@mkdir -p $(OBJ_DIR)/platform/$(PLATFORM)
$(CPP) -MM -MF $@ -MP -MT $(patsubst %.d,%.o,$@) $(CPP_FLAGS) $(patsubst $(OBJ_DIR)/%.d,$(SRC_DIR)/%.c,$@)
.PRECIOUS: $(UNIT_TEST_OBJ_DIR)/%.d
@@ -133,7 +136,7 @@ $(UNIT_TEST_OBJ_DIR)/%.d: $(UNIT_TEST_SRC_DIR)/%.c
$(CPP) -MM -MF $@ -MP -MT $(patsubst %.d,%.o,$@) $(CPP_FLAGS) $(patsubst $(UNIT_TEST_OBJ_DIR)/%.d,$(UNIT_TEST_SRC_DIR)/%.c,$@)
$(OBJ_DIR)/%.o: $(SRC_DIR)/%.c $(OBJ_DIR)/%.d
@mkdir -p $(OBJ_DIR)/$(ARCH)
@mkdir -p $(OBJ_DIR)/platform/$(PLATFORM)
$(CC) -c $(CPP_FLAGS) $(C_FLAGS) $< -o $@
$(UNIT_TEST_OBJ_DIR)/%.o: $(UNIT_TEST_SRC_DIR)/%.c $(UNIT_TEST_OBJ_DIR)/%.d