common.mk 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. # Functionality common to both top-level project makefile (project.mk)
  2. # and component makefiles (component_wrapper.mk)
  3. #
  4. PYTHON=$(call dequote,$(CONFIG_SDK_PYTHON))
  5. # Include project config makefile, if it exists.
  6. #
  7. # (Note that we only rebuild this makefile automatically for some
  8. # targets, see project_config.mk for details.)
  9. SDKCONFIG_MAKEFILE ?= $(abspath $(BUILD_DIR_BASE)/include/config/auto.conf)
  10. -include $(SDKCONFIG_MAKEFILE)
  11. export SDKCONFIG_MAKEFILE # sub-makes (like bootloader) will reuse this path
  12. # BATCH_BUILD flag disables interactive terminal features, defaults to verbose build
  13. ifdef BATCH_BUILD
  14. V ?= 1
  15. endif
  16. #Handling of V=1/VERBOSE=1 flag
  17. #
  18. # if V=1, $(summary) does nothing and $(details) will echo extra details
  19. # if V is unset or not 1, $(summary) echoes a summary and $(details) does nothing
  20. VERBOSE ?=
  21. V ?= $(VERBOSE)
  22. ifeq ("$(V)","1")
  23. summary := @true
  24. details := @echo
  25. else
  26. summary := @echo
  27. details := @true
  28. # disable echoing of commands, directory names
  29. MAKEFLAGS += --silent
  30. endif # $(V)==1
  31. ifdef CONFIG_SDK_MAKE_WARN_UNDEFINED_VARIABLES
  32. MAKEFLAGS += --warn-undefined-variables
  33. endif
  34. # Get version variables
  35. include $(IDF_PATH)/make/version.mk
  36. # General make utilities
  37. # convenience variable for printing an 80 asterisk wide separator line
  38. SEPARATOR:="*******************************************************************************"
  39. # macro to remove quotes from an argument, ie $(call dequote,$(CONFIG_BLAH))
  40. define dequote
  41. $(subst ",,$(1))
  42. endef
  43. # " comment kept here to keep syntax highlighting happy
  44. # macro to keep an absolute path as-is, but resolve a relative path
  45. # against a particular parent directory
  46. #
  47. # $(1) path to resolve
  48. # $(2) directory to resolve non-absolute path against
  49. #
  50. # Path and directory don't have to exist (definition of a "relative
  51. # path" is one that doesn't start with /)
  52. #
  53. # $(2) can contain a trailing forward slash or not, result will not
  54. # double any path slashes.
  55. #
  56. # example $(call resolvepath,$(CONFIG_PATH),$(CONFIG_DIR))
  57. define resolvepath
  58. $(abspath $(foreach dir,$(1),$(if $(filter /%,$(dir)),$(dir),$(subst //,/,$(2)/$(dir)))))
  59. endef
  60. # macro to include a target only if it's on the list of targets that make
  61. # was invoked with
  62. #
  63. # This allows you to have something like an "order-only phony prerequisite",
  64. # ie a prerequisite that determines an order phony targets have to run in.
  65. #
  66. # Because normal order-only prerequisites don't work with phony targets.
  67. #
  68. # example $(call prereq_if_explicit,erase_flash)
  69. define prereq_if_explicit
  70. $(filter $(1),$(MAKECMDGOALS))
  71. endef
  72. # macro to kill duplicate items in a list without messing up the sort order of the list.
  73. # Will only keep the unique items; if there are non-unique items in the list, it will remove
  74. # the later recurring ones so only the first one remains.
  75. # Copied from http://stackoverflow.com/questions/16144115/makefile-remove-duplicate-words-without-sorting
  76. define uniq
  77. $(if $1,$(firstword $1) $(call uniq,$(filter-out $(firstword $1),$1)))
  78. endef
  79. # macro to strip leading ../s from a path
  80. # Given $(1) which is a directory, remove any leading ../s from it
  81. # (recursively keeps removing ../ until not found)
  82. # if the path contains nothing but ../.., a single . is returned (cwd)
  83. define stripLeadingParentDirs
  84. $(foreach path,$(1),$(if $(subst ..,,$(path)),$(if $(filter ../%,$(path)),$(call stripLeadingParentDirs,$(patsubst ../%,%,$(path))),$(path)),.))
  85. endef