]> git.donarmstrong.com Git - qmk_firmware.git/commitdiff
Refactor common rule list parsing into own function
authorFred Sundvik <fsundvik@gmail.com>
Thu, 4 Aug 2016 06:17:02 +0000 (09:17 +0300)
committerFred Sundvik <fsundvik@gmail.com>
Sat, 20 Aug 2016 00:24:40 +0000 (03:24 +0300)
Makefile

index b4204478e1d5927f893018aa1a180d9a5a2fd252..e88eeefee49c15c32ac63592f507e139d407242f 100644 (file)
--- 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