Browse Source

Rule parsing to match kebyoards

Fred Sundvik 9 years ago
parent
commit
f97ae2b199
1 changed files with 31 additions and 0 deletions
  1. 31 0
      Makefile

+ 31 - 0
Makefile

@@ -1,5 +1,9 @@
 STARTING_MAKEFILE := $(firstword $(MAKEFILE_LIST))
 STARTING_MAKEFILE := $(firstword $(MAKEFILE_LIST))
 ROOT_MAKEFILE := $(lastword $(MAKEFILE_LIST))
 ROOT_MAKEFILE := $(lastword $(MAKEFILE_LIST))
+ROOT_DIR := $(dir, $(ROOT_MAKEFILE))
+ifeq ($(ROOT_DIR),)
+    ROOT_DIR := .
+endif
 ABS_STARTING_MAKEFILE := $(abspath $(STARTING_MAKEFILE))
 ABS_STARTING_MAKEFILE := $(abspath $(STARTING_MAKEFILE))
 ABS_ROOT_MAKEFILE := $(abspath $(ROOT_MAKEFILE))
 ABS_ROOT_MAKEFILE := $(abspath $(ROOT_MAKEFILE))
 ABS_STARTING_DIR := $(dir $(ABS_STARTING_MAKEFILE))
 ABS_STARTING_DIR := $(dir $(ABS_STARTING_MAKEFILE))
@@ -32,9 +36,14 @@ ifeq ($(CURRENT_PATH_ELEMENT),keyboards)
     endif
     endif
 endif
 endif
 
 
+$(info $(ROOT_DIR)/keyboards)
+KEYBOARDS := $(notdir $(patsubst %/.,%,$(wildcard $(ROOT_DIR)/keyboards/*/.)))
+
 $(info Keyboard: $(KEYBOARD))
 $(info Keyboard: $(KEYBOARD))
 $(info Keymap: $(KEYMAP))
 $(info Keymap: $(KEYMAP))
 $(info Subproject: $(SUBPROJECT))
 $(info Subproject: $(SUBPROJECT))
+$(info Keyboards: $(KEYBOARDS))
+
 
 
 # Compare the start of the RULE_VARIABLE with the first argument($1)
 # Compare the start of the RULE_VARIABLE with the first argument($1)
 # If the rules equals $1 or starts with $1-, RULE_FOUND is set to true
 # If the rules equals $1 or starts with $1-, RULE_FOUND is set to true
@@ -62,12 +71,34 @@ define PARSE_ALL_KEYBOARDS
     COMMAND_allkb := "All keyboards with $$(RULE)"
     COMMAND_allkb := "All keyboards with $$(RULE)"
 endef
 endef
 
 
+define PARSE_KEYBOARD
+    COMMANDS += $1
+    #$$(info $$(RULE))
+    COMMAND_$1 := "Keyboard $1 with $$(RULE)"
+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
+
 define PARSE_RULE
 define PARSE_RULE
     RULE := $1
     RULE := $1
     COMMANDS :=
     COMMANDS :=
     $$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,allkb))
     $$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,allkb))
     ifeq ($$(RULE_FOUND),true)
     ifeq ($$(RULE_FOUND),true)
         $$(eval $$(call PARSE_ALL_KEYBOARDS))
         $$(eval $$(call PARSE_ALL_KEYBOARDS))
+    else
+        $$(eval $$(call TRY_PARSE_KEYBOARD,$(KEYBOARDS)))
     endif
     endif
 endef
 endef