From 4f3bd1c95d493f07d7b8bc81d24962ef23a32813 Mon Sep 17 00:00:00 2001 From: Albert Y <76888457+filterpaper@users.noreply.github.com> Date: Sat, 8 Jul 2023 10:48:31 +0800 Subject: [PATCH] [Docs] Squeeze AVR with simplified magic config functions Add an additional section on simplifying bootmagic config placeholder functions if that feature is unused. --- docs/squeezing_avr.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/docs/squeezing_avr.md b/docs/squeezing_avr.md index ce9e43cdaea1..d5ced5738264 100644 --- a/docs/squeezing_avr.md +++ b/docs/squeezing_avr.md @@ -88,6 +88,21 @@ Or if you're not using layers at all, you can outright remove the functionality #define NO_ACTION_LAYER ``` +## Magic keycodes + +There are two `__attribute__ ((weak))` placeholder functions available to customize magic keycodes. If you are not using that feature to swap keycodes, such as backslash with backspace, add the following to your `keymap.c` or user space code: +```c +uint16_t keycode_config(uint16_t keycode) { + return keycode; +} +``` +Likewise, if you are not using magic keycodes to swap modifiers, such as Control with GUI, add the following to your `keymap.c` or user space code: +```c +uint8_t mod_config(uint8_t mod) { + return mod; +} +``` +Both of them will overwrite the placeholder functions with a simple return statement to reduce firmware size. ## OLED tweaks