From f89d8dd191950a7ee79b77e73f851707cda3b673 Mon Sep 17 00:00:00 2001 From: kanjoe24 <165808281+kanjoe24@users.noreply.github.com> Date: Mon, 16 Dec 2024 13:16:19 +0000 Subject: [PATCH] Fix gh #154 : Fix review comments --- Makefile | 42 ++++++++++++++++-------------------------- 1 file changed, 16 insertions(+), 26 deletions(-) diff --git a/Makefile b/Makefile index c68e0ef..0efab27 100755 --- a/Makefile +++ b/Makefile @@ -38,7 +38,6 @@ TOP_DIR ?= $(UT_CORE_DIR) BIN_DIR ?= $(TOP_DIR)/build/bin LIB_DIR ?= $(TOP_DIR)/build/$(TARGET)/lib BUILD_DIR ?= $(TOP_DIR)/build/$(TARGET)/obj -LIBRARY_DIR = $(LIB_DIR) # Non-Moveable Directories FRAMEWORK_DIR = $(UT_CORE_DIR)/framework @@ -76,6 +75,16 @@ else # GTEST case SRCS := $(shell find $(SRC_DIRS) -type f \( -name '*.cpp' -o -name '*.c' \) | grep -v "$(EXCLUDE_DIRS)") endif +# Check if BUILD_WEAK_STUBS_SRC is defined +ifdef BUILD_WEAK_STUBS_SRC + +# Define variables for the static library and its source files +WEAK_STUBS_LIB := $(LIB_DIR)/libweak_stubs_libs.a +WEAK_STUBS_SRC := $(wildcard $(BUILD_WEAK_STUBS_SRC)/*.c) + +XLDFLAGS := -L$(LIB_DIR) -lweak_stubs_libs $(XLDFLAGS) +endif + VARIANT_FILE := .variant ifeq ($(TARGET),arm) @@ -119,7 +128,7 @@ VPATH += $(UT_CORE_DIR) $(TOP_DIR) # Default target .PHONY: clean list arm linux framework test createdirs all printenv -all: framework $(OBJS) $(if $(LIBRARY_NAME),$(LIBRARY_DIR)/$(LIBRARY_NAME)$(LIBRARY_EXTENSION)) +all: framework $(OBJS) $(if $(BUILD_WEAK_STUBS_SRC),$(WEAK_STUBS_LIB)) # Build framework # Recursive make is needed as src files are not available during the first iteration @@ -140,7 +149,7 @@ download_and_build: @${MAKE} -C $(UT_CONTROL) TARGET=${TARGET} # Build the test binary -test: $(OBJS) createdirs $(if $(LIBRARY_NAME),$(LIBRARY_DIR)/$(LIBRARY_NAME)$(LIBRARY_EXTENSION)) +test: $(OBJS) createdirs $(if $(BUILD_WEAK_STUBS_SRC),$(WEAK_STUBS_LIB)) @${ECHOE} ${GREEN}Linking $@ $(BUILD_DIR)/$(TARGET_EXEC)${NC} @$(COMPILER) $(OBJS) -o $(BUILD_DIR)/$(TARGET_EXEC) $(XCFLAGS) $(XLDFLAGS) @cp $(BUILD_DIR)/$(TARGET_EXEC) $(BIN_DIR)/ @@ -178,21 +187,10 @@ checkvariantchange: fi \ fi -# Create the library (shared or static) -$(LIBRARY_DIR)/$(LIBRARY_NAME)$(LIBRARY_EXTENSION): $(LIBRARY_OBJS) createdirs - @if [ "${LIBRARY_TYPE}" = "shared" ]; then \ - ${ECHOE} ${GREEN}Building shared library $(LIBRARY_NAME)$(LIBRARY_EXTENSION)${NC}; \ - $(CC) $(LIBRARY_OBJS) $(LIBRARY_FLAGS) -o $@; \ - else \ - ${ECHOE} ${GREEN}Building static library $(LIBRARY_NAME)$(LIBRARY_EXTENSION)${NC}; \ - $(AR) rcs $@ $(LIBRARY_OBJS); \ - fi - -# Create object files for the library -$(LIBRARY_DIR)/%.o: $(SRC_DIR)/%.c - @${ECHOE} ${GREEN}Building [${YELLOW}$<${GREEN}] for library${NC} - @$(MKDIR_P) $(dir $@) - @$(CC) $(XCFLAGS) $(CFLAGS) -I$(LIBRARY_INC) -c $< -o $@ +# Create the library weak_stubs_libs +$(WEAK_STUBS_LIB): $(WEAK_STUBS_SRC) + @${ECHOE} ${GREEN}Building weak_stubs_libs...${NC} + $(AR) rcs $@ $^ arm: make TARGET=arm @@ -263,14 +261,6 @@ list: @${ECHOE} @${ECHOE} ${YELLOW}INC_FLAGS:${NC} $(INC_FLAGS) @${ECHOE} - @${ECHOE} ${YELLOW}LIBRARY_DIR:${NC} $(LIBRARY_DIR) - @${ECHOE} - @${ECHOE} ${YELLOW}LIBRARY_NAME:${NC} $(LIBRARY_NAME) - @${ECHOE} - @${ECHOE} ${YELLOW}LIBRARY_EXTENSION:${NC} $(LIBRARY_EXTENSION) - @${ECHOE} - @${ECHOE} ${YELLOW}LIBRARY_TYPE:${NC} $(LIBRARY_TYPE) - @${ECHOE} @${ECHOE} ${YELLOW}DEPS:${NC} $(DEPS) @${ECHOE} @${ECHOE} --------- ut_control ----------------