summaryrefslogtreecommitdiffstats
path: root/Makefile
diff options
context:
space:
mode:
authorFred Sundvik <fsundvik@gmail.com>2016-08-04 08:17:02 +0200
committerFred Sundvik <fsundvik@gmail.com>2016-08-20 02:24:40 +0200
commitdfe510d5b8f83c9977b507ed204632c2f22c5d24 (patch)
treecada6f1cec36e9560ddd80143e2da72689df7175 /Makefile
parent9b02e66ce0f703480e42038a5084174a45b54b1d (diff)
downloadqmk_firmware-dfe510d5b8f83c9977b507ed204632c2f22c5d24.tar.gz
qmk_firmware-dfe510d5b8f83c9977b507ed204632c2f22c5d24.tar.xz
Refactor common rule list parsing into own function
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile61
1 files changed, 29 insertions, 32 deletions
diff --git a/Makefile b/Makefile
index b4204478e..e88eeefee 100644
--- a/Makefile
+++ b/Makefile
@@ -65,6 +65,20 @@ define COMPARE_AND_REMOVE_FROM_RULE
endif
endef
+# Recursively try to find a match
+# $1 The list to be checked
+# If a match is found, then RULE_FOUND is set to true
+# and MATCHED_ITEM to the item that was matched
+define TRY_TO_MATCH_RULE_FROM_LIST
+ $$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,$$(firstword $1)))
+ ifeq ($$(RULE_FOUND),true)
+ MATCHED_ITEM := $$(firstword $1)
+ else ifneq ($1,)
+ $$(eval $$(call TRY_TO_MATCH_RULE_FROM_LIST,$$(wordlist 2,9999,$1)))
+ endif
+endef
+
+
define PARSE_ALL_KEYBOARDS
COMMANDS += allkb
#$$(info $$(RULE))
@@ -73,51 +87,31 @@ endef
# $1 = Keyboard
define PARSE_KEYBOARD
+ CURRENT_KB := $1
$$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,allkm))
ifeq ($$(RULE_FOUND),true)
- $$(eval $$(call PARSE_ALL_KEYMAPS, $1))
+ $$(eval $$(call PARSE_ALL_KEYMAPS))
else
KEYMAPS := $(notdir $(patsubst %/.,%,$(wildcard $(ROOT_DIR)/keyboards/$1/keymaps/*/.)))
- $$(eval $$(call TRY_PARSE_KEYMAP,$$(KEYMAPS),$1))
+ $$(eval $$(call TRY_TO_MATCH_RULE_FROM_LIST,$$(KEYMAPS)))
+ ifeq ($$(RULE_FOUND),true)
+ $$(eval $$(call PARSE_KEYMAP,$$(MATCHED_ITEM)))
+ endif
endif
endef
define PARSE_ALL_KEYMAPS
COMMANDS += ALL_KEYMAPS
- COMMAND_ALL_KEYMAPS := All keymaps in $1
+ COMMAND_ALL_KEYMAPS := All keymaps in $(CURRENT_KB)
endef
-# $1 Keyboard
-# $2 Keymap
+# $1 Keymap
define PARSE_KEYMAP
- COMMANDS += KEYBOARD_$1_KEYMAP_$2
- COMMAND_KEYBOARD_$1_KEYMAP_$2 := Keyboard $1, Keymap $2
+ CURRENT_KM = $1
+ COMMANDS += KEYBOARD_$$(CURRENT_KB)_KEYMAP_$$(CURRENT_KM)
+ COMMAND_KEYBOARD_$$(CURRENT_KB)_KEYMAP_$$(CURRENT_KM) := Keyboard $$(CURRENT_KB), Keymap $$(CURRENT_KM)
endef
-# Recursively try to find a matching keyboard
-# During the first call $1 contains a list of all keyboards
-# One keyboard is checked and removed at a time
-define TRY_PARSE_KEYBOARD
- CURRENT_KB := $$(firstword $1)
- $$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,$$(CURRENT_KB)))
- ifeq ($$(RULE_FOUND),true)
- $$(eval $$(call PARSE_KEYBOARD,$$(CURRENT_KB)))
- else ifneq ($1,)
- $$(eval $$(call TRY_PARSE_KEYBOARD,$$(wordlist 2,9999,$1)))
- endif
-endef
-
-# $1 list of keymaps
-# $2 keyboard
-define TRY_PARSE_KEYMAP
- CURRENT_KM := $$(firstword $1)
- $$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,$$(CURRENT_KM)))
- ifeq ($$(RULE_FOUND),true)
- $$(eval $$(call PARSE_KEYMAP,$2,$$(CURRENT_KM)))
- else ifneq ($1,)
- $$(eval $$(call TRY_PARSE_KEYMAP,$$(wordlist 2,9999,$1),$2))
- endif
-endef
define PARSE_RULE
RULE := $1
@@ -126,7 +120,10 @@ define PARSE_RULE
ifeq ($$(RULE_FOUND),true)
$$(eval $$(call PARSE_ALL_KEYBOARDS))
else
- $$(eval $$(call TRY_PARSE_KEYBOARD,$(KEYBOARDS)))
+ $$(eval $$(call TRY_TO_MATCH_RULE_FROM_LIST,$$(KEYBOARDS)))
+ ifeq ($$(RULE_FOUND),true)
+ $$(eval $$(call PARSE_KEYBOARD,$$(MATCHED_ITEM)))
+ endif
endif
endef