From 9de9d719527c7a8cac71d0bc49ba1d2d4f63cf06 Mon Sep 17 00:00:00 2001 From: tmk Date: Sat, 22 Jun 2013 16:14:56 +0900 Subject: Add default layer config to bootmagic --- README.md | 9 +++++++++ common/action_layer.c | 4 ++-- common/action_layer.h | 2 +- common/bootmagic.c | 18 ++++++++++++++++++ common/bootmagic.h | 4 ++++ common/command.c | 4 ++-- common/eeconfig.c | 4 ++-- common/eeconfig.h | 4 ++-- 8 files changed, 40 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index f3cfacb47d..d4793e9bfb 100644 --- a/README.md +++ b/README.md @@ -149,6 +149,15 @@ Note that you must use keys of **Layer 0** as Magic keys. These settings are sto - Set Default Layer to 1(`1`) - Set Default Layer to 2(`2`) - Set Default Layer to 3(`3`) +- Set Default Layer to 4(`4`) +- Set Default Layer to 5(`5`) +- Set Default Layer to 6(`6`) +- Set Default Layer to 7(`7`) + +#### Caution +Unintentional use of this feature will cause user confusion. + +TODO: Magic key combination to avoid unintentional press during plug in **TBD** diff --git a/common/action_layer.c b/common/action_layer.c index d24aa2e19f..526e24d539 100644 --- a/common/action_layer.c +++ b/common/action_layer.c @@ -30,9 +30,9 @@ void default_layer_debug(void) dprintf("%08lX(%u)", default_layer_state, biton32(default_layer_state)); } -void default_layer_set(uint8_t layer) +void default_layer_set(uint32_t state) { - default_layer_state_set(1UL<. */ extern uint32_t default_layer_state; void default_layer_debug(void); -void default_layer_set(uint8_t layer); +void default_layer_set(uint32_t state); #ifndef NO_ACTION_LAYER /* bitwise operation */ diff --git a/common/bootmagic.c b/common/bootmagic.c index 716f5d956b..11eef3c3c6 100644 --- a/common/bootmagic.c +++ b/common/bootmagic.c @@ -74,6 +74,24 @@ void bootmagic(void) keymap_config.swap_backslash_backspace = !keymap_config.swap_backslash_backspace; } eeconfig_write_keymap(keymap_config.raw); + + /* default layer */ + uint8_t default_layer = 0; + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_0)) { default_layer |= (1<<0); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_1)) { default_layer |= (1<<1); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_2)) { default_layer |= (1<<2); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_3)) { default_layer |= (1<<3); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_4)) { default_layer |= (1<<4); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_5)) { default_layer |= (1<<5); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_6)) { default_layer |= (1<<6); } + if (bootmagic_scan_keycode(BOOTMAGIC_KEY_DEFAULT_LAYER_7)) { default_layer |= (1<<7); } + if (default_layer) { + eeconfig_write_default_layer(default_layer); + default_layer_set((uint32_t)default_layer); + } else { + default_layer = eeconfig_read_default_layer(); + default_layer_set((uint32_t)default_layer); + } } bool bootmagic_scan_keycode(uint8_t keycode) diff --git a/common/bootmagic.h b/common/bootmagic.h index 2e7496ebc5..68935e9706 100644 --- a/common/bootmagic.h +++ b/common/bootmagic.h @@ -41,6 +41,10 @@ #define BOOTMAGIC_KEY_DEFAULT_LAYER_1 KC_1 #define BOOTMAGIC_KEY_DEFAULT_LAYER_2 KC_2 #define BOOTMAGIC_KEY_DEFAULT_LAYER_3 KC_3 +#define BOOTMAGIC_KEY_DEFAULT_LAYER_4 KC_4 +#define BOOTMAGIC_KEY_DEFAULT_LAYER_5 KC_5 +#define BOOTMAGIC_KEY_DEFAULT_LAYER_6 KC_6 +#define BOOTMAGIC_KEY_DEFAULT_LAYER_7 KC_7 void bootmagic(void); diff --git a/common/command.c b/common/command.c index 74b7c5ebcf..73a72b4a1d 100644 --- a/common/command.c +++ b/common/command.c @@ -129,7 +129,7 @@ static void command_common_help(void) #ifdef BOOTMAGIC_ENABLE static void print_eeconfig(void) { - print("default_layer: "); print_dec(eeconfig_read_defalt_layer()); print("\n"); + print("default_layer: "); print_dec(eeconfig_read_default_layer()); print("\n"); debug_config_t dc; dc.raw = eeconfig_read_debug(); @@ -579,6 +579,6 @@ static void switch_default_layer(uint8_t layer) { print("switch_default_layer: "); print_dec(biton32(default_layer_state)); print(" to "); print_dec(layer); print("\n"); - default_layer_set(layer); + default_layer_set(1UL<