Consolidate KEYBOARD_OUTPUT+KEYMAP_OUTPUT=>INTERMEDIATE_OUTPUT (#21272)
				
					
				
			This commit is contained in:
		
							parent
							
								
									45dc1ccffe
								
							
						
					
					
						commit
						ffdc70bf0a
					
				
					 8 changed files with 59 additions and 66 deletions
				
			
		| 
						 | 
				
			
			@ -27,7 +27,6 @@ QMK_BIN ?= qmk
 | 
			
		|||
# Set the filename for the final firmware binary
 | 
			
		||||
KEYBOARD_FILESAFE := $(subst /,_,$(KEYBOARD))
 | 
			
		||||
TARGET ?= $(KEYBOARD_FILESAFE)_$(KEYMAP)
 | 
			
		||||
KEYBOARD_OUTPUT := $(BUILD_DIR)/obj_$(KEYBOARD_FILESAFE)
 | 
			
		||||
 | 
			
		||||
ifeq ($(strip $(DUMP_CI_METADATA)),yes)
 | 
			
		||||
    $(info CI Metadata: KEYBOARD=$(KEYBOARD))
 | 
			
		||||
| 
						 | 
				
			
			@ -44,7 +43,7 @@ endif
 | 
			
		|||
# Object files and generated keymap directory
 | 
			
		||||
#     To put object files in current directory, use a dot (.), do NOT make
 | 
			
		||||
#     this an empty or blank macro!
 | 
			
		||||
KEYMAP_OUTPUT := $(BUILD_DIR)/obj_$(TARGET)
 | 
			
		||||
INTERMEDIATE_OUTPUT := $(BUILD_DIR)/obj_$(TARGET)
 | 
			
		||||
 | 
			
		||||
ifdef SKIP_VERSION
 | 
			
		||||
    OPT_DEFS += -DSKIP_VERSION
 | 
			
		||||
| 
						 | 
				
			
			@ -60,7 +59,7 @@ VERSION_H_FLAGS += --skip-git
 | 
			
		|||
endif
 | 
			
		||||
 | 
			
		||||
# Generate the board's version.h file.
 | 
			
		||||
$(shell $(QMK_BIN) generate-version-h $(VERSION_H_FLAGS) -q -o $(KEYMAP_OUTPUT)/src/version.h)
 | 
			
		||||
$(shell $(QMK_BIN) generate-version-h $(VERSION_H_FLAGS) -q -o $(INTERMEDIATE_OUTPUT)/src/version.h)
 | 
			
		||||
 | 
			
		||||
# Determine which subfolders exist.
 | 
			
		||||
KEYBOARD_FOLDER_PATH_1 := $(KEYBOARD)
 | 
			
		||||
| 
						 | 
				
			
			@ -121,7 +120,7 @@ MAIN_KEYMAP_PATH_4 := $(KEYBOARD_PATH_4)/keymaps/$(KEYMAP)
 | 
			
		|||
MAIN_KEYMAP_PATH_5 := $(KEYBOARD_PATH_5)/keymaps/$(KEYMAP)
 | 
			
		||||
 | 
			
		||||
# Pull in rules from info.json
 | 
			
		||||
INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/info_rules.mk)
 | 
			
		||||
INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --keyboard $(KEYBOARD) --output $(INTERMEDIATE_OUTPUT)/src/info_rules.mk)
 | 
			
		||||
include $(INFO_RULES_MK)
 | 
			
		||||
 | 
			
		||||
# Check for keymap.json first, so we can regenerate keymap.c
 | 
			
		||||
| 
						 | 
				
			
			@ -161,28 +160,28 @@ endif
 | 
			
		|||
 | 
			
		||||
# Have we found a keymap.json?
 | 
			
		||||
ifneq ("$(wildcard $(KEYMAP_JSON))", "")
 | 
			
		||||
    KEYMAP_C := $(KEYMAP_OUTPUT)/src/keymap.c
 | 
			
		||||
    KEYMAP_H := $(KEYMAP_OUTPUT)/src/config.h
 | 
			
		||||
    KEYMAP_C := $(INTERMEDIATE_OUTPUT)/src/keymap.c
 | 
			
		||||
    KEYMAP_H := $(INTERMEDIATE_OUTPUT)/src/config.h
 | 
			
		||||
 | 
			
		||||
    # Load the keymap-level rules.mk if exists
 | 
			
		||||
    -include $(KEYMAP_PATH)/rules.mk
 | 
			
		||||
 | 
			
		||||
    # Load any rules.mk content from keymap.json
 | 
			
		||||
    INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --output $(KEYMAP_OUTPUT)/src/rules.mk $(KEYMAP_JSON))
 | 
			
		||||
    INFO_RULES_MK = $(shell $(QMK_BIN) generate-rules-mk --quiet --escape --output $(INTERMEDIATE_OUTPUT)/src/rules.mk $(KEYMAP_JSON))
 | 
			
		||||
    include $(INFO_RULES_MK)
 | 
			
		||||
 | 
			
		||||
# Add rules to generate the keymap files - indentation here is important
 | 
			
		||||
$(KEYMAP_OUTPUT)/src/keymap.c: $(KEYMAP_JSON)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)/src/keymap.c: $(KEYMAP_JSON)
 | 
			
		||||
	@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) json2c --quiet --output $(KEYMAP_C) $(KEYMAP_JSON))
 | 
			
		||||
	@$(BUILD_CMD)
 | 
			
		||||
 | 
			
		||||
$(KEYMAP_OUTPUT)/src/config.h: $(KEYMAP_JSON)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)/src/config.h: $(KEYMAP_JSON)
 | 
			
		||||
	@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-config-h --quiet --output $(KEYMAP_H) $(KEYMAP_JSON))
 | 
			
		||||
	@$(BUILD_CMD)
 | 
			
		||||
 | 
			
		||||
generated-files: $(KEYMAP_OUTPUT)/src/config.h $(KEYMAP_OUTPUT)/src/keymap.c
 | 
			
		||||
generated-files: $(INTERMEDIATE_OUTPUT)/src/config.h $(INTERMEDIATE_OUTPUT)/src/keymap.c
 | 
			
		||||
 | 
			
		||||
endif
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -323,34 +322,34 @@ ifneq ("$(wildcard $(KEYBOARD_PATH_5)/info.json)","")
 | 
			
		|||
    INFO_JSON_FILES += $(KEYBOARD_PATH_5)/info.json
 | 
			
		||||
endif
 | 
			
		||||
 | 
			
		||||
CONFIG_H += $(KEYBOARD_OUTPUT)/src/info_config.h
 | 
			
		||||
KEYBOARD_SRC += $(KEYBOARD_OUTPUT)/src/default_keyboard.c
 | 
			
		||||
CONFIG_H += $(INTERMEDIATE_OUTPUT)/src/info_config.h
 | 
			
		||||
KEYBOARD_SRC += $(INTERMEDIATE_OUTPUT)/src/default_keyboard.c
 | 
			
		||||
 | 
			
		||||
$(KEYBOARD_OUTPUT)/src/info_config.h: $(INFO_JSON_FILES)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)/src/info_config.h: $(INFO_JSON_FILES)
 | 
			
		||||
	@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-config-h --quiet --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/info_config.h)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-config-h --quiet --keyboard $(KEYBOARD) --output $(INTERMEDIATE_OUTPUT)/src/info_config.h)
 | 
			
		||||
	@$(BUILD_CMD)
 | 
			
		||||
 | 
			
		||||
$(KEYBOARD_OUTPUT)/src/default_keyboard.c: $(INFO_JSON_FILES)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)/src/default_keyboard.c: $(INFO_JSON_FILES)
 | 
			
		||||
	@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-keyboard-c --quiet --keyboard $(KEYBOARD) --output $(KEYBOARD_OUTPUT)/src/default_keyboard.c)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-keyboard-c --quiet --keyboard $(KEYBOARD) --output $(INTERMEDIATE_OUTPUT)/src/default_keyboard.c)
 | 
			
		||||
	@$(BUILD_CMD)
 | 
			
		||||
 | 
			
		||||
$(KEYBOARD_OUTPUT)/src/default_keyboard.h: $(INFO_JSON_FILES)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)/src/default_keyboard.h: $(INFO_JSON_FILES)
 | 
			
		||||
	@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-keyboard-h --quiet --keyboard $(KEYBOARD) --include $(FOUND_KEYBOARD_H) --output $(KEYBOARD_OUTPUT)/src/default_keyboard.h)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-keyboard-h --quiet --keyboard $(KEYBOARD) --include $(FOUND_KEYBOARD_H) --output $(INTERMEDIATE_OUTPUT)/src/default_keyboard.h)
 | 
			
		||||
	@$(BUILD_CMD)
 | 
			
		||||
 | 
			
		||||
generated-files: $(KEYBOARD_OUTPUT)/src/info_config.h $(KEYBOARD_OUTPUT)/src/default_keyboard.c $(KEYBOARD_OUTPUT)/src/default_keyboard.h
 | 
			
		||||
generated-files: $(INTERMEDIATE_OUTPUT)/src/info_config.h $(INTERMEDIATE_OUTPUT)/src/default_keyboard.c $(INTERMEDIATE_OUTPUT)/src/default_keyboard.h
 | 
			
		||||
 | 
			
		||||
generated-files: $(KEYMAP_OUTPUT)/src/info_deps.d
 | 
			
		||||
generated-files: $(INTERMEDIATE_OUTPUT)/src/info_deps.d
 | 
			
		||||
 | 
			
		||||
$(KEYMAP_OUTPUT)/src/info_deps.d:
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)/src/info_deps.d:
 | 
			
		||||
	@$(SILENT) || printf "$(MSG_GENERATING) $@" | $(AWK_CMD)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-make-dependencies -kb $(KEYBOARD) -km $(KEYMAP) -o $(KEYMAP_OUTPUT)/src/info_deps.d)
 | 
			
		||||
	$(eval CMD=$(QMK_BIN) generate-make-dependencies -kb $(KEYBOARD) -km $(KEYMAP) -o $(INTERMEDIATE_OUTPUT)/src/info_deps.d)
 | 
			
		||||
	@$(BUILD_CMD)
 | 
			
		||||
 | 
			
		||||
-include $(KEYMAP_OUTPUT)/src/info_deps.d
 | 
			
		||||
-include $(INTERMEDIATE_OUTPUT)/src/info_deps.d
 | 
			
		||||
 | 
			
		||||
.INTERMEDIATE : generated-files
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -423,8 +422,7 @@ VPATH += $(KEYMAP_PATH)
 | 
			
		|||
VPATH += $(USER_PATH)
 | 
			
		||||
VPATH += $(KEYBOARD_PATHS)
 | 
			
		||||
VPATH += $(COMMON_VPATH)
 | 
			
		||||
VPATH += $(KEYBOARD_OUTPUT)/src
 | 
			
		||||
VPATH += $(KEYMAP_OUTPUT)/src
 | 
			
		||||
VPATH += $(INTERMEDIATE_OUTPUT)/src
 | 
			
		||||
 | 
			
		||||
include $(BUILDDEFS_PATH)/common_features.mk
 | 
			
		||||
include $(BUILDDEFS_PATH)/generic_features.mk
 | 
			
		||||
| 
						 | 
				
			
			@ -471,17 +469,14 @@ PROJECT_CONFIG := $(CONFIG_H)
 | 
			
		|||
CONFIG_H += $(POST_CONFIG_H)
 | 
			
		||||
ALL_CONFIGS := $(PROJECT_CONFIG) $(CONFIG_H)
 | 
			
		||||
 | 
			
		||||
OUTPUTS := $(KEYMAP_OUTPUT) $(KEYBOARD_OUTPUT)
 | 
			
		||||
$(KEYMAP_OUTPUT)_SRC := $(SRC)
 | 
			
		||||
$(KEYMAP_OUTPUT)_DEFS := $(OPT_DEFS) \
 | 
			
		||||
-DQMK_KEYBOARD=\"$(KEYBOARD)\" -DQMK_KEYBOARD_H=\"$(KEYBOARD_OUTPUT)/src/default_keyboard.h\" \
 | 
			
		||||
-DQMK_KEYMAP=\"$(KEYMAP)\" -DQMK_KEYMAP_H=\"$(KEYMAP).h\" -DQMK_KEYMAP_CONFIG_H=\"$(KEYMAP_PATH)/config.h\"
 | 
			
		||||
$(KEYMAP_OUTPUT)_INC :=  $(VPATH) $(EXTRAINCDIRS)
 | 
			
		||||
$(KEYMAP_OUTPUT)_CONFIG := $(CONFIG_H)
 | 
			
		||||
$(KEYBOARD_OUTPUT)_SRC := $(PLATFORM_SRC)
 | 
			
		||||
$(KEYBOARD_OUTPUT)_DEFS := $(PROJECT_DEFS)
 | 
			
		||||
$(KEYBOARD_OUTPUT)_INC := $(PROJECT_INC)
 | 
			
		||||
$(KEYBOARD_OUTPUT)_CONFIG := $(PROJECT_CONFIG)
 | 
			
		||||
OUTPUTS := $(INTERMEDIATE_OUTPUT)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)_SRC := $(SRC) $(PLATFORM_SRC)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)_DEFS := $(OPT_DEFS) \
 | 
			
		||||
	-DQMK_KEYBOARD=\"$(KEYBOARD)\" -DQMK_KEYBOARD_H=\"$(INTERMEDIATE_OUTPUT)/src/default_keyboard.h\" \
 | 
			
		||||
	-DQMK_KEYMAP=\"$(KEYMAP)\" -DQMK_KEYMAP_H=\"$(KEYMAP).h\" -DQMK_KEYMAP_CONFIG_H=\"$(KEYMAP_PATH)/config.h\" \
 | 
			
		||||
	$(PROJECT_DEFS)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)_INC :=  $(VPATH) $(EXTRAINCDIRS) $(PROJECT_INC)
 | 
			
		||||
$(INTERMEDIATE_OUTPUT)_CONFIG := $(CONFIG_H) $(PROJECT_CONFIG)
 | 
			
		||||
 | 
			
		||||
# Default target.
 | 
			
		||||
all: build check-size
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue