Enabling Simple macro optimization
- Requires updates to PartialMap to handle changes - Decides if a macro is simple by checking the sequence depth (Simple == 1)
This commit is contained in:
parent
54c95e9309
commit
09d7e5c8ac
@ -133,14 +133,24 @@ class Backend( BackendBase ):
|
|||||||
|
|
||||||
|
|
||||||
## Results Macros ##
|
## Results Macros ##
|
||||||
# TODO Simple Macros
|
|
||||||
|
# List of non-complex ResultMacros
|
||||||
|
# These are defined as a single combo (sequence depth of 1)
|
||||||
|
simpleResultMacros = []
|
||||||
|
|
||||||
self.fill_dict['ResultMacroGuides'] = ""
|
self.fill_dict['ResultMacroGuides'] = ""
|
||||||
self.fill_dict['ResultMacroRecords'] = ""
|
self.fill_dict['ResultMacroRecords'] = ""
|
||||||
|
|
||||||
# Iterate through each of the result macros
|
# Iterate through each of the result macros
|
||||||
for result in range( 0, len( macros.resultsIndexSorted ) ):
|
for result in range( 0, len( macros.resultsIndexSorted ) ):
|
||||||
self.fill_dict['ResultMacroGuides'] += "Guide_RM( {0} ) = {{ ".format( result )
|
self.fill_dict['ResultMacroGuides'] += "Guide_RM( {0} ) = {{ ".format( result )
|
||||||
self.fill_dict['ResultMacroRecords'] += "Record_RM( {0} );\n".format( result )
|
|
||||||
|
# Determine if the ResultMacro is simple
|
||||||
|
if len( macros.resultsIndexSorted[ result ] ) == 1:
|
||||||
|
simpleResultMacros.append( result )
|
||||||
|
# Otherwise add a Record
|
||||||
|
else:
|
||||||
|
self.fill_dict['ResultMacroRecords'] += "Record_RM( {0} );\n".format( result )
|
||||||
|
|
||||||
# Add the result macro capability index guide (including capability arguments)
|
# Add the result macro capability index guide (including capability arguments)
|
||||||
# See kiibohd controller Macros/PartialMap/kll.h for exact formatting details
|
# See kiibohd controller Macros/PartialMap/kll.h for exact formatting details
|
||||||
@ -163,7 +173,7 @@ class Backend( BackendBase ):
|
|||||||
|
|
||||||
# Add each of the arguments of the capability
|
# Add each of the arguments of the capability
|
||||||
for arg in range( 0, len( resultItem[1] ) ):
|
for arg in range( 0, len( resultItem[1] ) ):
|
||||||
self.fill_dict['ResultMacros'] += "{0}, ".format( resultItem[1][ arg ] )
|
self.fill_dict['ResultMacroGuides'] += "{0}, ".format( resultItem[1][ arg ] )
|
||||||
|
|
||||||
# If sequence is longer than 1, append a sequence spacer at the end of the sequence
|
# If sequence is longer than 1, append a sequence spacer at the end of the sequence
|
||||||
# Required by USB to end at sequence without holding the key down
|
# Required by USB to end at sequence without holding the key down
|
||||||
@ -174,27 +184,48 @@ class Backend( BackendBase ):
|
|||||||
# Add list ending 0 and end of list
|
# Add list ending 0 and end of list
|
||||||
self.fill_dict['ResultMacroGuides'] += "0 };\n"
|
self.fill_dict['ResultMacroGuides'] += "0 };\n"
|
||||||
self.fill_dict['ResultMacroGuides'] = self.fill_dict['ResultMacroGuides'][:-1] # Remove last newline
|
self.fill_dict['ResultMacroGuides'] = self.fill_dict['ResultMacroGuides'][:-1] # Remove last newline
|
||||||
self.fill_dict['ResultMacroRecords'] = self.fill_dict['ResultMacroRecords'][:-1] # Remove last newline
|
|
||||||
|
# Remove last newline if a record was added
|
||||||
|
if self.fill_dict['ResultMacroRecords'] != "":
|
||||||
|
self.fill_dict['ResultMacroRecords'] = self.fill_dict['ResultMacroRecords'][:-1]
|
||||||
|
else:
|
||||||
|
self.fill_dict['ResultMacroRecords'] = "// <None>"
|
||||||
|
|
||||||
|
|
||||||
## Result Macro List ##
|
## Result Macro List ##
|
||||||
self.fill_dict['ResultMacroList'] = "const ResultMacro ResultMacroList[] = {\n"
|
self.fill_dict['ResultMacroList'] = "const ResultMacro ResultMacroList[] = {\n"
|
||||||
|
|
||||||
# Iterate through each of the result macros
|
# Iterate through each of the result macros
|
||||||
# TODO Add simple macros
|
|
||||||
for result in range( 0, len( macros.resultsIndexSorted ) ):
|
for result in range( 0, len( macros.resultsIndexSorted ) ):
|
||||||
self.fill_dict['ResultMacroList'] += "\tDefine_RM_{1}( {0} ),\n".format( result, "Normal" )
|
# Check if this is a simple ResultMacro
|
||||||
|
self.fill_dict['ResultMacroList'] += "\tDefine_RM_{1}( {0} ),\n".format(
|
||||||
|
result,
|
||||||
|
"Simple"
|
||||||
|
if result in simpleResultMacros else
|
||||||
|
"Normal"
|
||||||
|
)
|
||||||
self.fill_dict['ResultMacroList'] += "};"
|
self.fill_dict['ResultMacroList'] += "};"
|
||||||
|
|
||||||
|
|
||||||
## Trigger Macros ##
|
## Trigger Macros ##
|
||||||
|
|
||||||
|
# List of non-complex TriggerMacros
|
||||||
|
# These are defined as a single combo (sequence depth of 1)
|
||||||
|
simpleTriggerMacros = []
|
||||||
|
|
||||||
self.fill_dict['TriggerMacroGuides'] = ""
|
self.fill_dict['TriggerMacroGuides'] = ""
|
||||||
self.fill_dict['TriggerMacroRecords'] = ""
|
self.fill_dict['TriggerMacroRecords'] = ""
|
||||||
|
|
||||||
# Iterate through each of the trigger macros
|
# Iterate through each of the trigger macros
|
||||||
for trigger in range( 0, len( macros.triggersIndexSorted ) ):
|
for trigger in range( 0, len( macros.triggersIndexSorted ) ):
|
||||||
self.fill_dict['TriggerMacroGuides'] += "Guide_TM( {0} ) = {{ ".format( trigger )
|
self.fill_dict['TriggerMacroGuides'] += "Guide_TM( {0} ) = {{ ".format( trigger )
|
||||||
self.fill_dict['TriggerMacroRecords'] += "Record_TM( {0} );\n".format( trigger )
|
|
||||||
|
# Determine if TriggerMacro is simple
|
||||||
|
if len( macros.triggersIndexSorted[ trigger ][ 0 ] ) == 1:
|
||||||
|
simpleTriggerMacros.append( trigger )
|
||||||
|
# Otherwise add a Record
|
||||||
|
else:
|
||||||
|
self.fill_dict['TriggerMacroRecords'] += "Record_TM( {0} );\n".format( trigger )
|
||||||
|
|
||||||
# Add the trigger macro scan code guide
|
# Add the trigger macro scan code guide
|
||||||
# See kiibohd controller Macros/PartialMap/kll.h for exact formatting details
|
# See kiibohd controller Macros/PartialMap/kll.h for exact formatting details
|
||||||
@ -213,17 +244,27 @@ class Backend( BackendBase ):
|
|||||||
# Add list ending 0 and end of list
|
# Add list ending 0 and end of list
|
||||||
self.fill_dict['TriggerMacroGuides'] += "0 };\n"
|
self.fill_dict['TriggerMacroGuides'] += "0 };\n"
|
||||||
self.fill_dict['TriggerMacroGuides'] = self.fill_dict['TriggerMacroGuides'][:-1] # Remove last newline
|
self.fill_dict['TriggerMacroGuides'] = self.fill_dict['TriggerMacroGuides'][:-1] # Remove last newline
|
||||||
self.fill_dict['TriggerMacroRecords'] = self.fill_dict['TriggerMacroRecords'][:-1] # Remove last newline
|
|
||||||
|
# Remove last newline if a record was added
|
||||||
|
if self.fill_dict['TriggerMacroRecords'] != "":
|
||||||
|
self.fill_dict['TriggerMacroRecords'] = self.fill_dict['TriggerMacroRecords'][:-1]
|
||||||
|
else:
|
||||||
|
self.fill_dict['TriggerMacroRecords'] = "// <None>"
|
||||||
|
|
||||||
|
|
||||||
## Trigger Macro List ##
|
## Trigger Macro List ##
|
||||||
self.fill_dict['TriggerMacroList'] = "const TriggerMacro TriggerMacroList[] = {\n"
|
self.fill_dict['TriggerMacroList'] = "const TriggerMacro TriggerMacroList[] = {\n"
|
||||||
|
|
||||||
# Iterate through each of the trigger macros
|
# Iterate through each of the trigger macros
|
||||||
# TODO Add simple macros
|
|
||||||
for trigger in range( 0, len( macros.triggersIndexSorted ) ):
|
for trigger in range( 0, len( macros.triggersIndexSorted ) ):
|
||||||
# Use TriggerMacro Index, and the corresponding ResultMacro Index
|
# Use TriggerMacro Index, and the corresponding ResultMacro Index
|
||||||
self.fill_dict['TriggerMacroList'] += "\tDefine_TM_{2}( {0}, {1} ),\n".format( trigger, macros.triggersIndexSorted[ trigger ][1], "Normal" )
|
# Check if this is a simple TriggerMacro
|
||||||
|
self.fill_dict['TriggerMacroList'] += "\tDefine_TM_{2}( {0}, {1} ),\n".format(
|
||||||
|
trigger, macros.triggersIndexSorted[ trigger ][1],
|
||||||
|
"Simple"
|
||||||
|
if trigger in simpleTriggerMacros else
|
||||||
|
"Normal"
|
||||||
|
)
|
||||||
self.fill_dict['TriggerMacroList'] += "};"
|
self.fill_dict['TriggerMacroList'] += "};"
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user