mirror of
				https://github.com/mfulz/qmk_firmware.git
				synced 2025-11-03 23:02:34 +01:00 
			
		
		
		
	Refactor common rule list parsing into own function
This commit is contained in:
		
							parent
							
								
									9b02e66ce0
								
							
						
					
					
						commit
						dfe510d5b8
					
				
							
								
								
									
										61
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								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
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user