35 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
# Helper macros to convert spaces into question marks and back again
 | 
						|
e := 
 | 
						|
sp := $(e) $(e)
 | 
						|
qs = $(subst ?,$(sp),$1)
 | 
						|
sq = $(subst $(sp),?,$1)
 | 
						|
 | 
						|
# Get name of this Makefile (avoid getting word 0 and a starting space)
 | 
						|
makefile_name := $(wordlist 1,1000,$(MAKEFILE_LIST))
 | 
						|
 | 
						|
# Get path of this Makefile
 | 
						|
makefile_path := $(call qs,$(dir $(call sq,$(abspath $(call sq,$(makefile_name))))))
 | 
						|
 | 
						|
# Get path where the Application is
 | 
						|
application_path := $(call qs,$(abspath $(call sq,$(makefile_path)../..)))
 | 
						|
 | 
						|
.PHONY: clean assets all
 | 
						|
 | 
						|
ifneq ($(words $(makefile_path))$(words $(MAKEFILE_LIST)),11)
 | 
						|
all clean assets:
 | 
						|
$(error Spaces not allowed in path)
 | 
						|
else
 | 
						|
 | 
						|
ADDITIONAL_SOURCES := 
 | 
						|
ADDITIONAL_INCLUDE_PATHS := $(application_path)/../Core/Inc
 | 
						|
ADDITIONAL_LIBRARY_PATHS := 
 | 
						|
ADDITIONAL_LIBRARIES :=
 | 
						|
export ADDITIONAL_SOURCES ADDITIONAL_INCLUDE_PATHS ADDITIONAL_LIBRARY_PATHS ADDITIONAL_LIBRARIES
 | 
						|
 | 
						|
all: $(filter assets,$(MAKECMDGOALS))
 | 
						|
all assets: $(filter clean,$(MAKECMDGOALS))
 | 
						|
all clean assets:
 | 
						|
	@$(MAKE) -r -f generated/simulator/gcc/Makefile -s $(MFLAGS) $@ -C "$(application_path)"
 | 
						|
endif
 | 
						|
 |