Splitting out structures and macros from the generated keymap.
- Preparation to integrating the compiler
This commit is contained in:
parent
b2eaf0c893
commit
121525e2cb
@ -21,97 +21,12 @@
|
|||||||
|
|
||||||
// ----- Includes -----
|
// ----- Includes -----
|
||||||
|
|
||||||
// Project Includes
|
// KLL Include
|
||||||
#include <print.h>
|
#include <kll.h>
|
||||||
#include <scan_loop.h>
|
|
||||||
#include <macro.h>
|
|
||||||
#include <output_com.h>
|
|
||||||
|
|
||||||
// USB HID Keymap list
|
|
||||||
#include <usb_hid.h>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ----- Structs -----
|
// ----- Capabilities -----
|
||||||
|
|
||||||
// -- Result Macro
|
|
||||||
// Defines the sequence of combinations to as the Result of Trigger Macro
|
|
||||||
//
|
|
||||||
// Capability + args per USB send
|
|
||||||
// Default Args (always sent): key state/analog of last key
|
|
||||||
// Combo Length of 0 signifies end of sequence
|
|
||||||
//
|
|
||||||
// ResultMacro.guide -> [<combo length>|<capability index>|<arg1>|<argn>|<capability index>|...|<combo length>|...|0]
|
|
||||||
// ResultMacro.pos -> <current combo position>
|
|
||||||
// ResultMacro.state -> <last key state>
|
|
||||||
// ResultMacro.stateType -> <last key state type>
|
|
||||||
|
|
||||||
// ResultMacro struct, one is created per ResultMacro, no duplicates
|
|
||||||
typedef struct ResultMacro {
|
|
||||||
const uint8_t *guide;
|
|
||||||
unsigned int pos;
|
|
||||||
uint8_t state;
|
|
||||||
uint8_t stateType;
|
|
||||||
} ResultMacro;
|
|
||||||
|
|
||||||
// Guide, key element
|
|
||||||
#define ResultGuideSize( guidePtr ) sizeof( ResultGuide ) - 1 + CapabilitiesList[ (guidePtr)->index ].argCount
|
|
||||||
typedef struct ResultGuide {
|
|
||||||
uint8_t index;
|
|
||||||
uint8_t args; // This is used as an array pointer (but for packing purposes, must be 8 bit)
|
|
||||||
} ResultGuide;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// -- Trigger Macro
|
|
||||||
// Defines the sequence of combinations to Trigger a Result Macro
|
|
||||||
// Key Types:
|
|
||||||
// * 0x00 Normal (Press/Hold/Release)
|
|
||||||
// * 0x01 LED State (On/Off)
|
|
||||||
// * 0x02 Analog (Threshold)
|
|
||||||
// * 0x03-0xFE Reserved
|
|
||||||
// * 0xFF Debug State
|
|
||||||
//
|
|
||||||
// Key State:
|
|
||||||
// * Off - 0x00 (all flag states)
|
|
||||||
// * On - 0x01
|
|
||||||
// * Press/Hold/Release - 0x01/0x02/0x03
|
|
||||||
// * Threshold (Range) - 0x01 (Released), 0x10 (Light press), 0xFF (Max press)
|
|
||||||
// * Debug - 0xFF (Print capability name)
|
|
||||||
//
|
|
||||||
// Combo Length of 0 signifies end of sequence
|
|
||||||
//
|
|
||||||
// TriggerMacro.guide -> [<combo length>|<key1 type>|<key1 state>|<key1>...<keyn type>|<keyn state>|<keyn>|<combo length>...|0]
|
|
||||||
// TriggerMacro.result -> <index to result macro>
|
|
||||||
// TriggerMacro.pos -> <current combo position>
|
|
||||||
// TriggerMacro.state -> <status of the macro pos>
|
|
||||||
|
|
||||||
// TriggerMacro states
|
|
||||||
typedef enum TriggerMacroState {
|
|
||||||
TriggerMacro_Press, // Combo in sequence is passing
|
|
||||||
TriggerMacro_Release, // Move to next combo in sequence (or finish if at end of sequence)
|
|
||||||
TriggerMacro_Waiting, // Awaiting user input
|
|
||||||
} TriggerMacroState;
|
|
||||||
|
|
||||||
// TriggerMacro struct, one is created per TriggerMacro, no duplicates
|
|
||||||
typedef struct TriggerMacro {
|
|
||||||
const uint8_t *guide;
|
|
||||||
unsigned int result;
|
|
||||||
unsigned int pos;
|
|
||||||
TriggerMacroState state;
|
|
||||||
} TriggerMacro;
|
|
||||||
|
|
||||||
// Guide, key element
|
|
||||||
#define TriggerGuideSize sizeof( TriggerGuide )
|
|
||||||
typedef struct TriggerGuide {
|
|
||||||
uint8_t type;
|
|
||||||
uint8_t state;
|
|
||||||
uint8_t scanCode;
|
|
||||||
} TriggerGuide;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ----- Macros -----
|
|
||||||
|
|
||||||
void debugPrint_capability( uint8_t state, uint8_t stateType, uint8_t *args )
|
void debugPrint_capability( uint8_t state, uint8_t stateType, uint8_t *args )
|
||||||
{
|
{
|
||||||
@ -153,15 +68,6 @@ void debugPrint2_capability( uint8_t state, uint8_t stateType, uint8_t *args )
|
|||||||
print(" )");
|
print(" )");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Capability
|
|
||||||
typedef struct Capability {
|
|
||||||
void *func;
|
|
||||||
uint8_t argCount;
|
|
||||||
} Capability;
|
|
||||||
|
|
||||||
// Total Number of Capabilities
|
|
||||||
#define CapabilitiesNum sizeof( CapabilitiesList ) / sizeof( Capability )
|
|
||||||
|
|
||||||
// Indexed Capabilities Table
|
// Indexed Capabilities Table
|
||||||
// TODO Generated from .kll files in each module
|
// TODO Generated from .kll files in each module
|
||||||
const Capability CapabilitiesList[] = {
|
const Capability CapabilitiesList[] = {
|
||||||
@ -174,16 +80,6 @@ const Capability CapabilitiesList[] = {
|
|||||||
|
|
||||||
// -- Result Macros
|
// -- Result Macros
|
||||||
|
|
||||||
// Guide_RM / Define_RM Pair
|
|
||||||
// Guide_RM( index ) = result;
|
|
||||||
// * index - Result Macro index number
|
|
||||||
// * result - Result Macro guide (see ResultMacro)
|
|
||||||
// Define_RM( index );
|
|
||||||
// * index - Result Macro index number
|
|
||||||
// Must be used after Guide_RM
|
|
||||||
#define Guide_RM( index ) const uint8_t rm##index##_guide[]
|
|
||||||
#define Define_RM( index ) { rm##index##_guide, 0, 0, 0 }
|
|
||||||
|
|
||||||
Guide_RM( 0 ) = { 1, 0, 0xDA, 0 };
|
Guide_RM( 0 ) = { 1, 0, 0xDA, 0 };
|
||||||
Guide_RM( 1 ) = { 1, 0, 0xBE, 1, 0, 0xEF, 0 };
|
Guide_RM( 1 ) = { 1, 0, 0xBE, 1, 0, 0xEF, 0 };
|
||||||
Guide_RM( 2 ) = { 2, 0, 0xFA, 0, 0xAD, 0 };
|
Guide_RM( 2 ) = { 2, 0, 0xFA, 0, 0xAD, 0 };
|
||||||
@ -193,10 +89,6 @@ Guide_RM( 4 ) = { 1, 0, 0xDA, 0 };
|
|||||||
|
|
||||||
// -- Result Macro List
|
// -- Result Macro List
|
||||||
|
|
||||||
// Total number of result macros (rm's)
|
|
||||||
// Used to create pending rm's table
|
|
||||||
#define ResultMacroNum sizeof( ResultMacroList ) / sizeof( ResultMacro )
|
|
||||||
|
|
||||||
// Indexed Table of Result Macros
|
// Indexed Table of Result Macros
|
||||||
ResultMacro ResultMacroList[] = {
|
ResultMacro ResultMacroList[] = {
|
||||||
Define_RM( 0 ),
|
Define_RM( 0 ),
|
||||||
@ -209,16 +101,6 @@ ResultMacro ResultMacroList[] = {
|
|||||||
|
|
||||||
// -- Trigger Macros
|
// -- Trigger Macros
|
||||||
|
|
||||||
// Guide_TM / Define_TM Trigger Setup
|
|
||||||
// Guide_TM( index ) = trigger;
|
|
||||||
// * index - Trigger Macro index number
|
|
||||||
// * trigger - Trigger Macro guide (see TriggerMacro)
|
|
||||||
// Define_TM( index, result );
|
|
||||||
// * index - Trigger Macro index number
|
|
||||||
// * result - Result Macro index number which is triggered by this Trigger Macro
|
|
||||||
#define Guide_TM( index ) const uint8_t tm##index##_guide[]
|
|
||||||
#define Define_TM( index, result ) { tm##index##_guide, result, 0, TriggerMacro_Waiting }
|
|
||||||
|
|
||||||
Guide_TM( 0 ) = { 1, 0x00, 0x01, 0x73, 0 };
|
Guide_TM( 0 ) = { 1, 0x00, 0x01, 0x73, 0 };
|
||||||
Guide_TM( 1 ) = { 1, 0x00, 0x01, 0x73, 1, 0x00, 0x01, 0x75, 0 };
|
Guide_TM( 1 ) = { 1, 0x00, 0x01, 0x73, 1, 0x00, 0x01, 0x75, 0 };
|
||||||
Guide_TM( 2 ) = { 2, 0x00, 0x01, 0x73, 0x00, 0x01, 0x74, 0 };
|
Guide_TM( 2 ) = { 2, 0x00, 0x01, 0x73, 0x00, 0x01, 0x74, 0 };
|
||||||
@ -234,10 +116,6 @@ Guide_TM( 10 ) = { 1, 0x00, 0x01, 0x2B, 0 };
|
|||||||
|
|
||||||
// -- Trigger Macro List
|
// -- Trigger Macro List
|
||||||
|
|
||||||
// Total number of trigger macros (tm's)
|
|
||||||
// Used to create pending tm's table
|
|
||||||
#define TriggerMacroNum sizeof( TriggerMacroList ) / sizeof( TriggerMacro )
|
|
||||||
|
|
||||||
// Indexed Table of Trigger Macros
|
// Indexed Table of Trigger Macros
|
||||||
TriggerMacro TriggerMacroList[] = {
|
TriggerMacro TriggerMacroList[] = {
|
||||||
Define_TM( 0, 0 ),
|
Define_TM( 0, 0 ),
|
||||||
@ -264,12 +142,6 @@ TriggerMacro TriggerMacroList[] = {
|
|||||||
// - Increasing it beyond the keyboard's capabilities is just a waste of ram...
|
// - Increasing it beyond the keyboard's capabilities is just a waste of ram...
|
||||||
#define MaxScanCode 0x100
|
#define MaxScanCode 0x100
|
||||||
|
|
||||||
// Define_TL( layer, scanCode ) = triggerList;
|
|
||||||
// * layer - basename of the layer
|
|
||||||
// * scanCode - Hex value of the scanCode
|
|
||||||
// * triggerList - Trigger List (see Trigger Lists)
|
|
||||||
#define Define_TL( layer, scanCode ) const unsigned int layer##_tl_##scanCode[]
|
|
||||||
|
|
||||||
// -- Trigger Lists
|
// -- Trigger Lists
|
||||||
//
|
//
|
||||||
// Index 0: # of triggers in list
|
// Index 0: # of triggers in list
|
||||||
@ -578,36 +450,6 @@ const unsigned int *myname2_scanMap[] = {
|
|||||||
|
|
||||||
// ----- Layer Index -----
|
// ----- Layer Index -----
|
||||||
|
|
||||||
// Defines each map of trigger macro lists
|
|
||||||
// Layer 0 is always the default map
|
|
||||||
// Layer States:
|
|
||||||
// * Off - 0x00
|
|
||||||
// * Shift - 0x01
|
|
||||||
// * Latch - 0x02
|
|
||||||
// * Lock - 0x04
|
|
||||||
//
|
|
||||||
// Except for Off, all states an exist simultaneously for each layer
|
|
||||||
// For example:
|
|
||||||
// state -> 0x04 + 0x01 = 0x05 (Shift + Lock), which is effectively Off (0x00)
|
|
||||||
//
|
|
||||||
// Max defines the maximum number of keys in the map, maximum of 0xFF
|
|
||||||
// - Compiler calculates this
|
|
||||||
//
|
|
||||||
// The name is defined for cli debugging purposes (Null terminated string)
|
|
||||||
|
|
||||||
typedef struct Layer {
|
|
||||||
const unsigned int **triggerMap;
|
|
||||||
const char *name;
|
|
||||||
const uint8_t max;
|
|
||||||
uint8_t state;
|
|
||||||
} Layer;
|
|
||||||
|
|
||||||
|
|
||||||
// Layer_IN( map, name );
|
|
||||||
// * map - Trigger map
|
|
||||||
// * name - Name of the trigger map
|
|
||||||
#define Layer_IN( map, name ) { map, name, sizeof( map ) / 4 - 1, 0 }
|
|
||||||
|
|
||||||
// -- Layer Index List
|
// -- Layer Index List
|
||||||
//
|
//
|
||||||
// Index 0: Default map
|
// Index 0: Default map
|
||||||
@ -618,9 +460,6 @@ Layer LayerIndex[] = {
|
|||||||
Layer_IN( myname2_scanMap, "myname2" ),
|
Layer_IN( myname2_scanMap, "myname2" ),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Total number of layers
|
|
||||||
#define LayerNum sizeof( LayerIndex ) / sizeof( Layer )
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif // __generatedKeymap_h
|
#endif // __generatedKeymap_h
|
||||||
|
213
Macro/PartialMap/kll.h
Normal file
213
Macro/PartialMap/kll.h
Normal file
@ -0,0 +1,213 @@
|
|||||||
|
/* Copyright (C) 2014 by Jacob Alexander
|
||||||
|
*
|
||||||
|
* This file is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This file is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this file. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __kll_h
|
||||||
|
#define __kll_h
|
||||||
|
|
||||||
|
// ----- Includes -----
|
||||||
|
|
||||||
|
// Project Includes
|
||||||
|
#include <print.h>
|
||||||
|
#include <scan_loop.h>
|
||||||
|
#include <macro.h>
|
||||||
|
#include <output_com.h>
|
||||||
|
|
||||||
|
// USB HID Keymap list
|
||||||
|
#include <usb_hid.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Structs -----
|
||||||
|
|
||||||
|
// -- Result Macro
|
||||||
|
// Defines the sequence of combinations to as the Result of Trigger Macro
|
||||||
|
//
|
||||||
|
// Capability + args per USB send
|
||||||
|
// Default Args (always sent): key state/analog of last key
|
||||||
|
// Combo Length of 0 signifies end of sequence
|
||||||
|
//
|
||||||
|
// ResultMacro.guide -> [<combo length>|<capability index>|<arg1>|<argn>|<capability index>|...|<combo length>|...|0]
|
||||||
|
// ResultMacro.pos -> <current combo position>
|
||||||
|
// ResultMacro.state -> <last key state>
|
||||||
|
// ResultMacro.stateType -> <last key state type>
|
||||||
|
|
||||||
|
// ResultMacro struct, one is created per ResultMacro, no duplicates
|
||||||
|
typedef struct ResultMacro {
|
||||||
|
const uint8_t *guide;
|
||||||
|
unsigned int pos;
|
||||||
|
uint8_t state;
|
||||||
|
uint8_t stateType;
|
||||||
|
} ResultMacro;
|
||||||
|
|
||||||
|
// Guide, key element
|
||||||
|
#define ResultGuideSize( guidePtr ) sizeof( ResultGuide ) - 1 + CapabilitiesList[ (guidePtr)->index ].argCount
|
||||||
|
typedef struct ResultGuide {
|
||||||
|
uint8_t index;
|
||||||
|
uint8_t args; // This is used as an array pointer (but for packing purposes, must be 8 bit)
|
||||||
|
} ResultGuide;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// -- Trigger Macro
|
||||||
|
// Defines the sequence of combinations to Trigger a Result Macro
|
||||||
|
// Key Types:
|
||||||
|
// * 0x00 Normal (Press/Hold/Release)
|
||||||
|
// * 0x01 LED State (On/Off)
|
||||||
|
// * 0x02 Analog (Threshold)
|
||||||
|
// * 0x03-0xFE Reserved
|
||||||
|
// * 0xFF Debug State
|
||||||
|
//
|
||||||
|
// Key State:
|
||||||
|
// * Off - 0x00 (all flag states)
|
||||||
|
// * On - 0x01
|
||||||
|
// * Press/Hold/Release - 0x01/0x02/0x03
|
||||||
|
// * Threshold (Range) - 0x01 (Released), 0x10 (Light press), 0xFF (Max press)
|
||||||
|
// * Debug - 0xFF (Print capability name)
|
||||||
|
//
|
||||||
|
// Combo Length of 0 signifies end of sequence
|
||||||
|
//
|
||||||
|
// TriggerMacro.guide -> [<combo length>|<key1 type>|<key1 state>|<key1>...<keyn type>|<keyn state>|<keyn>|<combo length>...|0]
|
||||||
|
// TriggerMacro.result -> <index to result macro>
|
||||||
|
// TriggerMacro.pos -> <current combo position>
|
||||||
|
// TriggerMacro.state -> <status of the macro pos>
|
||||||
|
|
||||||
|
// TriggerMacro states
|
||||||
|
typedef enum TriggerMacroState {
|
||||||
|
TriggerMacro_Press, // Combo in sequence is passing
|
||||||
|
TriggerMacro_Release, // Move to next combo in sequence (or finish if at end of sequence)
|
||||||
|
TriggerMacro_Waiting, // Awaiting user input
|
||||||
|
} TriggerMacroState;
|
||||||
|
|
||||||
|
// TriggerMacro struct, one is created per TriggerMacro, no duplicates
|
||||||
|
typedef struct TriggerMacro {
|
||||||
|
const uint8_t *guide;
|
||||||
|
unsigned int result;
|
||||||
|
unsigned int pos;
|
||||||
|
TriggerMacroState state;
|
||||||
|
} TriggerMacro;
|
||||||
|
|
||||||
|
// Guide, key element
|
||||||
|
#define TriggerGuideSize sizeof( TriggerGuide )
|
||||||
|
typedef struct TriggerGuide {
|
||||||
|
uint8_t type;
|
||||||
|
uint8_t state;
|
||||||
|
uint8_t scanCode;
|
||||||
|
} TriggerGuide;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Capabilities -----
|
||||||
|
|
||||||
|
// Capability
|
||||||
|
typedef struct Capability {
|
||||||
|
void *func;
|
||||||
|
uint8_t argCount;
|
||||||
|
} Capability;
|
||||||
|
|
||||||
|
// Total Number of Capabilities
|
||||||
|
#define CapabilitiesNum sizeof( CapabilitiesList ) / sizeof( Capability )
|
||||||
|
|
||||||
|
|
||||||
|
// -- Result Macros
|
||||||
|
|
||||||
|
// Guide_RM / Define_RM Pair
|
||||||
|
// Guide_RM( index ) = result;
|
||||||
|
// * index - Result Macro index number
|
||||||
|
// * result - Result Macro guide (see ResultMacro)
|
||||||
|
// Define_RM( index );
|
||||||
|
// * index - Result Macro index number
|
||||||
|
// Must be used after Guide_RM
|
||||||
|
#define Guide_RM( index ) const uint8_t rm##index##_guide[]
|
||||||
|
#define Define_RM( index ) { rm##index##_guide, 0, 0, 0 }
|
||||||
|
|
||||||
|
|
||||||
|
// -- Result Macro List
|
||||||
|
|
||||||
|
// Total number of result macros (rm's)
|
||||||
|
// Used to create pending rm's table
|
||||||
|
#define ResultMacroNum sizeof( ResultMacroList ) / sizeof( ResultMacro )
|
||||||
|
|
||||||
|
|
||||||
|
// -- Trigger Macros
|
||||||
|
|
||||||
|
// Guide_TM / Define_TM Trigger Setup
|
||||||
|
// Guide_TM( index ) = trigger;
|
||||||
|
// * index - Trigger Macro index number
|
||||||
|
// * trigger - Trigger Macro guide (see TriggerMacro)
|
||||||
|
// Define_TM( index, result );
|
||||||
|
// * index - Trigger Macro index number
|
||||||
|
// * result - Result Macro index number which is triggered by this Trigger Macro
|
||||||
|
#define Guide_TM( index ) const uint8_t tm##index##_guide[]
|
||||||
|
#define Define_TM( index, result ) { tm##index##_guide, result, 0, TriggerMacro_Waiting }
|
||||||
|
|
||||||
|
|
||||||
|
// -- Trigger Macro List
|
||||||
|
|
||||||
|
// Total number of trigger macros (tm's)
|
||||||
|
// Used to create pending tm's table
|
||||||
|
#define TriggerMacroNum sizeof( TriggerMacroList ) / sizeof( TriggerMacro )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Trigger Maps -----
|
||||||
|
|
||||||
|
// Define_TL( layer, scanCode ) = triggerList;
|
||||||
|
// * layer - basename of the layer
|
||||||
|
// * scanCode - Hex value of the scanCode
|
||||||
|
// * triggerList - Trigger List (see Trigger Lists)
|
||||||
|
#define Define_TL( layer, scanCode ) const unsigned int layer##_tl_##scanCode[]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ----- Layer Index -----
|
||||||
|
|
||||||
|
// Defines each map of trigger macro lists
|
||||||
|
// Layer 0 is always the default map
|
||||||
|
// Layer States:
|
||||||
|
// * Off - 0x00
|
||||||
|
// * Shift - 0x01
|
||||||
|
// * Latch - 0x02
|
||||||
|
// * Lock - 0x04
|
||||||
|
//
|
||||||
|
// Except for Off, all states an exist simultaneously for each layer
|
||||||
|
// For example:
|
||||||
|
// state -> 0x04 + 0x01 = 0x05 (Shift + Lock), which is effectively Off (0x00)
|
||||||
|
//
|
||||||
|
// Max defines the maximum number of keys in the map, maximum of 0xFF
|
||||||
|
// - Compiler calculates this
|
||||||
|
//
|
||||||
|
// The name is defined for cli debugging purposes (Null terminated string)
|
||||||
|
|
||||||
|
typedef struct Layer {
|
||||||
|
const unsigned int **triggerMap;
|
||||||
|
const char *name;
|
||||||
|
const uint8_t max;
|
||||||
|
uint8_t state;
|
||||||
|
} Layer;
|
||||||
|
|
||||||
|
|
||||||
|
// Layer_IN( map, name );
|
||||||
|
// * map - Trigger map
|
||||||
|
// * name - Name of the trigger map
|
||||||
|
#define Layer_IN( map, name ) { map, name, sizeof( map ) / 4 - 1, 0 }
|
||||||
|
|
||||||
|
// Total number of layers
|
||||||
|
#define LayerNum sizeof( LayerIndex ) / sizeof( Layer )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __kll_h
|
||||||
|
|
Reference in New Issue
Block a user