Proper looping for allkb and allkm
This commit is contained in:
		
							parent
							
								
									dfe510d5b8
								
							
						
					
					
						commit
						9ee6d4a23d
					
				
					 1 changed files with 15 additions and 10 deletions
				
			
		
							
								
								
									
										25
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										25
									
								
								Makefile
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -78,21 +78,32 @@ define TRY_TO_MATCH_RULE_FROM_LIST
 | 
			
		|||
    endif
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
define ALL_IN_LIST_LOOP
 | 
			
		||||
    OLD_RULE$1 := $$(RULE)
 | 
			
		||||
    $$(eval $$(call $1,$$(ITEM$1)))
 | 
			
		||||
    RULE := $$(OLD_RULE$1)
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
define PARSE_ALL_IN_LIST
 | 
			
		||||
    $$(foreach ITEM$1,$2,$$(eval $$(call ALL_IN_LIST_LOOP,$1)))
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
define PARSE_ALL_KEYBOARDS
 | 
			
		||||
    COMMANDS += allkb
 | 
			
		||||
    #$$(info $$(RULE))
 | 
			
		||||
    COMMAND_allkb := "All keyboards with $$(RULE)"
 | 
			
		||||
    $$(eval $$(call PARSE_ALL_IN_LIST,PARSE_KEYBOARD,$(KEYBOARDS)))
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
define PARSE_ALL_KEYMAPS
 | 
			
		||||
    $$(eval $$(call PARSE_ALL_IN_LIST,PARSE_KEYMAP,$$(KEYMAPS)))
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
# $1 = Keyboard
 | 
			
		||||
define PARSE_KEYBOARD
 | 
			
		||||
    CURRENT_KB := $1
 | 
			
		||||
    KEYMAPS := $(notdir $(patsubst %/.,%,$(wildcard $(ROOT_DIR)/keyboards/$1/keymaps/*/.)))
 | 
			
		||||
    $$(eval $$(call COMPARE_AND_REMOVE_FROM_RULE,allkm))
 | 
			
		||||
    ifeq ($$(RULE_FOUND),true)
 | 
			
		||||
        $$(eval $$(call PARSE_ALL_KEYMAPS))
 | 
			
		||||
    else
 | 
			
		||||
        KEYMAPS := $(notdir $(patsubst %/.,%,$(wildcard $(ROOT_DIR)/keyboards/$1/keymaps/*/.)))
 | 
			
		||||
        $$(eval $$(call TRY_TO_MATCH_RULE_FROM_LIST,$$(KEYMAPS)))
 | 
			
		||||
        ifeq ($$(RULE_FOUND),true)
 | 
			
		||||
            $$(eval $$(call PARSE_KEYMAP,$$(MATCHED_ITEM)))
 | 
			
		||||
| 
						 | 
				
			
			@ -100,11 +111,6 @@ define PARSE_KEYBOARD
 | 
			
		|||
    endif
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
define PARSE_ALL_KEYMAPS
 | 
			
		||||
    COMMANDS += ALL_KEYMAPS
 | 
			
		||||
    COMMAND_ALL_KEYMAPS := All keymaps in $(CURRENT_KB)
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
# $1 Keymap
 | 
			
		||||
define PARSE_KEYMAP
 | 
			
		||||
    CURRENT_KM = $1
 | 
			
		||||
| 
						 | 
				
			
			@ -112,7 +118,6 @@ define PARSE_KEYMAP
 | 
			
		|||
    COMMAND_KEYBOARD_$$(CURRENT_KB)_KEYMAP_$$(CURRENT_KM) := Keyboard $$(CURRENT_KB), Keymap $$(CURRENT_KM)
 | 
			
		||||
endef
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
define PARSE_RULE
 | 
			
		||||
    RULE := $1
 | 
			
		||||
    COMMANDS :=
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue