# HG changeset patch # User Giulio Moro # Date 1463532392 -3600 # Node ID 4815ed0f21de993a89a5f7ffba392a7737fafb6e # Parent 8fecfcbaf2f0fc5d91d691a7ec7ce47ae47d8e17 Makefile refactoring: - avoids recursive call to build with/without main - takes EXAMPLE parameter. Copies the examples/$(EXAMPLE) folder to projects/$(PROJECT) and $PROJECT defaults to exampleTestProject - you can now `make run` (TODO: currently re-links, should instead run without linking) diff -r 8fecfcbaf2f0 -r 4815ed0f21de Makefile --- a/Makefile Tue May 17 18:16:26 2016 +0100 +++ b/Makefile Wed May 18 01:46:32 2016 +0100 @@ -11,10 +11,23 @@ # if the PROJECT variable is not set, throw an error and exit # otherwise, we could have unexpected data loss when calling clean without it ifndef PROJECT - $(error PROJECT is not set) + ifndef EXAMPLE + $(error PROJECT or EXAMPLE should be set) + endif endif -PROJECT_DIR := $(abspath projects/$(PROJECT)) +ifndef EXAMPLE + PROJECT_DIR := $(abspath projects/$(PROJECT)) +endif + +ifdef EXAMPLE + PROJECT?=exampleTempProject + PROJECT_DIR?=$(abspath projects/$(PROJECT)) + $(shell rm -rf $(PROJECT_DIR)) + $(shell cp -r examples/$(EXAMPLE) $(PROJECT_DIR)) + EXAMPLE:=that +endif + $(shell mkdir -p $(PROJECT_DIR)/build) RM := rm -rf STATIC_LIBS := ./libprussdrv.a ./libNE10.a @@ -112,7 +125,7 @@ $(PROJECT_DIR)/build/%.o: $(PROJECT_DIR)/%.c @echo 'Building $(notdir $<)...' # @echo 'Invoking: C Compiler' - @$(CC) $(SYNTAX_FLAG) $(INCLUDES) $(C_FLAGS) -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" -std=c99 + $(CC) $(SYNTAX_FLAG) $(INCLUDES) $(C_FLAGS) -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" -std=c99 @echo ' ...done' @echo ' ' @@ -129,27 +142,12 @@ # function, and conditionally call one of two recursive make targets depending on whether # we want to link in the default main file or not. The kludge is the mess of a shell script # line below. Surely there's a better way to do this? -BeagleRT: $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) - $(eval NEXT_TARGET := $(shell bash -c 'if [ `nm $(PROJECT_DIR)/build/*.o | grep -w T | grep -w main | wc -l` == '0' ]; then echo "BeagleRT_with_main"; else echo "BeagleRT_without_main"; fi')) - @$(MAKE) $(NEXT_TARGET) -# @echo 'Finished building target: $@' -# @echo ' ' -# $(MAKE) --no-print-directory post-build +BeagleRT: $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(DEFAULT_MAIN_OBJS) + $(eval DEFAULT_MAIN_CONDITIONAL := $(shell bash -c 'if [ `nm $(PROJECT_DIR)/build/*.o | grep -w T | grep -w main | wc -l` == '0' ]; then echo "$(DEFAULT_MAIN_OBJS)"; else echo ""; fi')) + @echo 'Invoking: C++ linker' + @$(CXX) $(SYNTAX_FLAG) -L/usr/xenomai/lib -L/usr/arm-linux-gnueabihf/lib -L/usr/arm-linux-gnueabihf/lib/xenomai -L/usr/lib/arm-linux-gnueabihf -pthread -Wpointer-arith -o "$(PROJECT_DIR)/$(PROJECT)" $(CORE_OBJS) $(DEFAULT_MAIN_CONDITIONAL) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS) + @echo 'Finished building target: $@' -# Rule for building BeagleRT including the default main file (no user-supplied main()) -BeagleRT_with_main: $(CORE_OBJS) $(DEFAULT_MAIN_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) - @echo 'Linking default main.cpp...' -# @echo 'Invoking: C++ Linker' - @$(CXX) $(SYNTAX_FLAG) -L/usr/xenomai/lib -L/usr/arm-linux-gnueabihf/lib -L/usr/arm-linux-gnueabihf/lib/xenomai -L/usr/lib/arm-linux-gnueabihf -pthread -Wpointer-arith -o "$(PROJECT_DIR)/$(PROJECT)" $(CORE_OBJS) $(DEFAULT_MAIN_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS) - @echo ' ...done' - -# Rule for building BeagleRT without the default main file (user-supplied main()) -BeagleRT_without_main: $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) - @echo 'Linking main.cpp from project...' -# @echo 'Invoking: C++ Linker' - @$(CXX) $(SYNTAX_FLAG) -L/usr/xenomai/lib -L/usr/arm-linux-gnueabihf/lib -L/usr/arm-linux-gnueabihf/lib/xenomai -L/usr/lib/arm-linux-gnueabihf -pthread -Wpointer-arith -o "$(PROJECT_DIR)/$(PROJECT)" $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS) - @echo ' ...done' - # Other Targets: # This rule compiles c and c++ source files without output or linking SYNTAX: $(C_OBJS) $(CPP_OBJS) @@ -163,7 +161,14 @@ distclean: -$(RM) build/source/* $(CORE_OBJS) $(CORE_CPP_DEPS) $(DEFAULT_MAIN_OBJS) $(DEFAULT_MAIN_CPP_DEPS) BeagleRT -@echo ' ' +OUTPUT_FILE="$(PROJECT_DIR)/$(PROJECT)" +$(OUTPUT_FILE): BeagleRT +run: $(OUTPUT_FILE) + @echo "Running $(OUTPUT_FILE)" + @$(OUTPUT_FILE) + + # Remove only the user-generated objects #clean: # -$(RM) build/source/* BeagleRT @@ -172,5 +177,5 @@ post-build: # Nothing to do here (for now) -.PHONY: all clean distclean projectclean dependents debug +.PHONY: all clean distclean projectclean dependents debug run .SECONDARY: post-build