Make Swap Hands use PROGMEM (#12284)
This converts the array that the Swap Hands feature uses to use PROGMEM, and to read from that array, as such. Since this array never changes at runtime, there is no reason to keep it in memory. Especially for AVR boards, as memory is a precious resource.
This commit is contained in:
		
							parent
							
								
									40d1506527
								
							
						
					
					
						commit
						f0b30e0027
					
				| @ -7,7 +7,7 @@ The swap-hands action allows support for one-handed typing without requiring a s | ||||
| The configuration table is a simple 2-dimensional array to map from column/row to new column/row. Example `hand_swap_config` for Planck: | ||||
| 
 | ||||
| ```C | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|   {{11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|   {{11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -12,7 +12,7 @@ | ||||
| 設定テーブルは列/行から新しい列/行にマップするための単純な2次元配列です。Planck の `hand_swap_config` の例: | ||||
| 
 | ||||
| ```C | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|   {{11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|   {{11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -44,7 +44,7 @@ void led_set_kb(uint8_t usb_led) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	{{4, 5}, {3, 5}, {2, 5}, {1, 5}, {0, 5}}, | ||||
| 	{{4, 6}, {3, 6}, {2, 6}, {1, 6}, {0, 6}}, | ||||
| 	{{4, 7}, {3, 7}, {2, 7}, {1, 7}, {0, 7}}, | ||||
|  | ||||
| @ -44,7 +44,7 @@ void led_set_kb(uint8_t usb_led) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	{{2, 2}, {1, 2}, {0, 2}}, | ||||
| 	{{2, 3}, {1, 3}, {0, 3}}, | ||||
| 	{{0, 0}, {1, 0}, {2, 0}}, | ||||
|  | ||||
| @ -44,7 +44,7 @@ void led_set_kb(uint8_t usb_led) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	{{4, 3}, {3, 3}, {2, 3}, {1, 3}, {0, 3}}, | ||||
| 	{{4, 4}, {3, 4}, {2, 4}, {1, 4}, {0, 4}}, | ||||
| 	{{4, 5}, {3, 5}, {2, 5}, {1, 5}, {0, 5}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}, {6, 6}, {7, 6}}, | ||||
|   {{0, 7}, {1, 7}, {2, 7}, {3, 7}, {4, 7}, {5, 7}, {6, 7}, {7, 7}}, | ||||
|   {{0, 8}, {1, 8}, {2, 8}, {3, 8}, {4, 8}, {5, 8}, {6, 8}, {7, 8}}, | ||||
|  | ||||
| @ -5,21 +5,21 @@ void led_init(void) { | ||||
|     setPinOutput(C4); // Set red LED pin as output
 | ||||
|     setPinOutput(C5); // Set blue LED pin as output
 | ||||
|     setPinOutput(D1); // Set green LED pin as output
 | ||||
|      | ||||
| 
 | ||||
|     writePinHigh(C4); // Turn off red LED pin
 | ||||
|     writePinHigh(C5); // Turn off blue LED pin
 | ||||
|     writePinHigh(D1); // Turn off green LED pin
 | ||||
|      | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
|     setPinOutput(F4); // Set red LED pin as output
 | ||||
|     setPinOutput(F5); // Set blue LED pin as output
 | ||||
|     setPinOutput(D1); // Set green LED pin as output
 | ||||
|      | ||||
| 
 | ||||
|     writePinHigh(F4); // Turn off red LED pin
 | ||||
|     writePinHigh(F5); // Turn off blue LED pin
 | ||||
|     writePinHigh(D1); // Turn off green LED pin
 | ||||
|      | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| } | ||||
| @ -33,7 +33,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| {{9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
| {{9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
| {{9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -20,7 +20,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	// Left
 | ||||
| 	{{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}}, | ||||
| 	{{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
| @ -33,4 +33,3 @@ const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	{{0, 3}, {1, 3}, {2, 3}, {3, 3}, {4, 3}, {5, 3}} | ||||
| }; | ||||
| #endif | ||||
| 
 | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}, {6, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}, {6, 5}}, | ||||
|  | ||||
| @ -220,7 +220,7 @@ uint8_t ergodox_left_leds_update(void) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,13}, {1,13}, {2,13}, {3,13}, {4,13}, {5,13}}, | ||||
|     {{0,12}, {1,12}, {2,12}, {3,12}, {4,12}, {5,12}}, | ||||
|  | ||||
| @ -205,7 +205,7 @@ void ergodox_right_led_3_set(uint8_t n) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{0, 9}, {1, 9}, {2, 9}, {3, 9}, {4, 9}}, | ||||
|     {{0, 10}, {1, 10}, {2, 10}, {3, 10}, {4, 10}}, | ||||
|     {{0, 11}, {1, 11}, {2, 11}, {3, 11}, {4, 11}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
|     {{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}}, | ||||
|     {{0, 7}, {1, 7}, {2, 7}, {3, 7}, {4, 7}, {5, 7}}, | ||||
|  | ||||
| @ -65,7 +65,7 @@ out: | ||||
|     return mcp23018_status; | ||||
| } | ||||
| 
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     { {0,0}, {0,7}, {2,7}, {3,7} }, | ||||
|     { {0,8}, {1,8}, {2,8}, {3,8} }, | ||||
|     { {0,9}, {1,9}, {2,9}, {3,9} }, | ||||
|  | ||||
| @ -4,7 +4,7 @@ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{0,11}, {0,10}, {0,9},  {0,8},  {0,7},  {0,6},     {0,5},  {0,4},  {0,3},  {0,2},  {0,1},  {0,0}}, | ||||
|     {{1,11}, {1,11}, {1,9},  {1,8},  {1,7},  {1,6},     {1,5},  {1,4},  {1,3},  {1,2},  {1,1},  {1,0}}, | ||||
|     {{2,11}, {2,12}, {2,9},  {2,8},  {2,7},  {2,6},     {2,5},  {2,4},  {2,3},  {2,2},  {2,1},  {2,0}}, | ||||
|  | ||||
| @ -206,7 +206,7 @@ void pointing_device_send(void) { | ||||
| #endif | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{5, 6}, {4, 6}, {3, 6}, {2, 6}, {1, 6}, {0, 6}}, | ||||
|     {{5, 7}, {4, 7}, {3, 7}, {2, 7}, {1, 7}, {0, 7}}, | ||||
|  | ||||
| @ -3,7 +3,7 @@ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{0,11}, {0,10}, {0,9},  {0,8},  {0,7},  {0,6},     {0,5},  {0,4},  {0,3},  {0,2},  {0,1},  {0,0}}, | ||||
|     {{1,11}, {1,11}, {1,9},  {1,8},  {1,7},  {1,6},     {1,5},  {1,4},  {1,3},  {1,2},  {1,1},  {1,0}}, | ||||
|     {{2,11}, {2,12}, {2,9},  {2,8},  {2,7},  {2,6},     {2,5},  {2,4},  {2,3},  {2,2},  {2,1},  {2,0}}, | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| #include "handwired.h" | ||||
| 
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{13, 0}, {12, 0}, {11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|   {{13, 1}, {12, 1}, {11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|   {{13, 2}, {12, 2}, {11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
|   {{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}, {6, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}, {6, 5}}, | ||||
|   {{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}, {6, 6}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
|   {{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}}, | ||||
|  | ||||
| @ -10,7 +10,7 @@ void led_set_kb(uint8_t usb_led) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,5}, {1,5}, {2,5}, {3,5}, {4,5}, {5,5}}, | ||||
|     {{0,6}, {1,6}, {2,6}, {3,6}, {4,6}, {5,6}}, | ||||
|  | ||||
| @ -10,7 +10,7 @@ void led_set_kb(uint8_t usb_led) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,5}, {1,5}, {2,5}, {3,5}, {4,5}, {5,5}}, | ||||
|     {{0,6}, {1,6}, {2,6}, {3,6}, {4,6}, {5,6}}, | ||||
|  | ||||
| @ -3,7 +3,7 @@ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,5}, {1,5}, {2,5}, {3,5}, {4,5}, {5,5}}, | ||||
|     {{0,6}, {1,6}, {2,6}, {3,6}, {4,6}, {5,6}}, | ||||
|  | ||||
| @ -3,7 +3,7 @@ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,5}, {1,5}, {2,5}, {3,5}, {4,5}, {5,5}}, | ||||
|     {{0,6}, {1,6}, {2,6}, {3,6}, {4,6}, {5,6}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{5, 4}, {4, 4}, {3, 4}, {2, 4}, {1, 4}, {0, 4}}, | ||||
|   {{5, 5}, {4, 5}, {3, 5}, {2, 5}, {1, 5}, {0, 5}}, | ||||
|  | ||||
| @ -15,7 +15,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{5, 4}, {4, 4}, {3, 4}, {2, 4}, {1, 4}, {0, 4}}, | ||||
|   {{5, 5}, {4, 5}, {3, 5}, {2, 5}, {1, 5}, {0, 5}}, | ||||
|  | ||||
| @ -3,7 +3,7 @@ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| 
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	{{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}, {6, 4}, {7, 4}}, | ||||
| 	{{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}, {6, 5}, {7, 5}}, | ||||
| 	{{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}, {6, 6}, {7, 6}}, | ||||
| @ -12,6 +12,6 @@ const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	{{0, 1}, {1, 1}, {2, 1}, {3, 1}, {4, 1}, {5, 1}, {6, 1}, {7, 1}}, | ||||
| 	{{0, 2}, {1, 2}, {2, 2}, {3, 2}, {4, 2}, {5, 2}, {6, 2}, {7, 2}}, | ||||
| 	{{0, 3}, {1, 3}, {2, 3}, {3, 3}, {4, 3}, {5, 3}, {6, 3}, {7, 3}} | ||||
| };	 | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
|  | ||||
| @ -16,7 +16,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| {{9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
| {{9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
| {{9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -370,7 +370,7 @@ bool music_mask_kb(uint16_t keycode) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| // clang-format off
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{6,6}, {5,6}, {4,6}, {3,6}, {2,6}, {1,6},{0,6}}, | ||||
|     {{6,7}, {5,7}, {4,7}, {3,7}, {2,7}, {1,7},{0,7}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|     {{11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|     {{11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -37,7 +37,7 @@ void matrix_init_kb(void) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,3}, {1,3}, {2,3}, {3,3}, {4,3}, {5,3}, {6,3}, {7,3}, {8,3}}, | ||||
|     {{0,4}, {1,4}, {2,4}, {3,4}, {4,4}, {5,4}, {6,4}, {7,4}, {8,4}}, | ||||
|  | ||||
| @ -37,7 +37,7 @@ void matrix_init_kb(void) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,3}, {1,3}, {2,3}, {3,3}, {4,3}, {5,3}, {6,3}, {7,3}, {8,3}}, | ||||
|     {{0,4}, {1,4}, {2,4}, {3,4}, {4,4}, {5,4}, {6,4}, {7,4}, {8,4}}, | ||||
|  | ||||
| @ -37,7 +37,7 @@ void matrix_init_kb(void) { | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| // swap-hands action needs a matrix to define the swap
 | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     /* Left hand, matrix positions */ | ||||
|     {{0,3}, {1,3}, {2,3}, {3,3}, {4,3}, {5,3}, {6,3}, {7,3}, {8,3}}, | ||||
|     {{0,4}, {1,4}, {2,4}, {3,4}, {4,4}, {5,4}, {6,4}, {7,4}, {8,4}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   {{11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|   {{11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|   {{11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -26,7 +26,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
|   __attribute__ ((weak)) | ||||
|   const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|     {{11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|     {{11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -26,7 +26,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
|   __attribute__ ((weak)) | ||||
|   const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
|     {{11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
|     {{11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -63,7 +63,7 @@ void dip_switch_update_user(uint8_t index, bool active) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     {{5, 4}, {4, 4}, {3, 4}, {2, 4}, {1, 4}, {0, 4}}, | ||||
|     {{5, 5}, {4, 5}, {3, 5}, {2, 5}, {1, 5}, {0, 5}}, | ||||
|     {{5, 6}, {4, 6}, {3, 6}, {2, 6}, {1, 6}, {0, 6}}, | ||||
|  | ||||
| @ -17,7 +17,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef ONEHAND_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| {{13, 0}, {12, 0}, {11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
| {{13, 1}, {12, 1}, {11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
| {{13, 2}, {12, 2}, {11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -19,7 +19,7 @@ void matrix_init_kb(void) { | ||||
| /*
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| {{9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
| {{9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
| {{9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -19,7 +19,7 @@ void matrix_init_kb(void) { | ||||
| /*
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| {{9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
| {{9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
| {{9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -19,7 +19,7 @@ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| // clang-format off
 | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}, {6, 5}}, | ||||
|   {{0, 6}, {1, 6}, {2, 6}, {3, 6}, {4, 6}, {5, 6}, {6, 6}}, | ||||
|  | ||||
| @ -17,7 +17,7 @@ void matrix_init_kb(void) { | ||||
| 
 | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| {{12, 0}, {11, 0}, {10, 0}, {9, 0}, {8, 0}, {7, 0}, {6, 0}, {5, 0}, {4, 0}, {3, 0}, {2, 0}, {1, 0}, {0, 0}}, | ||||
| {{12, 1}, {11, 1}, {10, 1}, {9, 1}, {8, 1}, {7, 1}, {6, 1}, {5, 1}, {4, 1}, {3, 1}, {2, 1}, {1, 1}, {0, 1}}, | ||||
| {{12, 2}, {11, 2}, {10, 2}, {9, 2}, {8, 2}, {7, 2}, {6, 2}, {5, 2}, {4, 2}, {3, 2}, {2, 2}, {1, 2}, {0, 2}}, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| #ifdef ONEHAND_ENABLE | ||||
| __attribute__ ((weak)) | ||||
| const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|   {{0, 4}, {1, 4}, {2, 4}, {3, 4}, {4, 4}, {5, 4}}, | ||||
|   {{0, 5}, {1, 5}, {2, 5}, {3, 5}, {4, 5}, {5, 5}}, | ||||
|  | ||||
| @ -133,7 +133,8 @@ void process_hand_swap(keyevent_t *event) { | ||||
|     bool             do_swap = event->pressed ? swap_hands : swap_state[pos.row] & (col_bit); | ||||
| 
 | ||||
|     if (do_swap) { | ||||
|         event->key = hand_swap_config[pos.row][pos.col]; | ||||
|         event->key.row = pgm_read_byte(&hand_swap_config[pos.row][pos.col].row); | ||||
|         event->key.col = pgm_read_byte(&hand_swap_config[pos.row][pos.col].col); | ||||
|         swap_state[pos.row] |= col_bit; | ||||
|     } else { | ||||
|         swap_state[pos.row] &= ~(col_bit); | ||||
|  | ||||
| @ -78,7 +78,7 @@ extern bool disable_action_cache; | ||||
| /* Code for handling one-handed key modifiers. */ | ||||
| #ifdef SWAP_HANDS_ENABLE | ||||
| extern bool           swap_hands; | ||||
| extern const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS]; | ||||
| extern const keypos_t PROGMEM hand_swap_config[MATRIX_ROWS][MATRIX_COLS]; | ||||
| #    if (MATRIX_COLS <= 8) | ||||
| typedef uint8_t swap_state_row_t; | ||||
| #    elif (MATRIX_COLS <= 16) | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user