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
|
|
|