[Keymap] Drashna keymap updates for 0.18.0 (#18184)
Co-authored-by: Ryan <fauxpark@gmail.com>master
parent
d4a6ee1cad
commit
fa08cb2478
|
@ -16,6 +16,9 @@
|
||||||
*/
|
*/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#undef PRODUCT
|
||||||
|
#define PRODUCT "Charybdis (4x6) Blackpill"
|
||||||
|
|
||||||
#undef MATRIX_COL_PINS
|
#undef MATRIX_COL_PINS
|
||||||
#define MATRIX_COL_PINS \
|
#define MATRIX_COL_PINS \
|
||||||
{ B0, B1, B12, B3, B4, B5 }
|
{ B0, B1, B12, B3, B4, B5 }
|
||||||
|
@ -34,7 +37,7 @@
|
||||||
#define DIODE_DIRECTION ROW2COL
|
#define DIODE_DIRECTION ROW2COL
|
||||||
#define SPLIT_HAND_PIN A3
|
#define SPLIT_HAND_PIN A3
|
||||||
#undef MASTER_RIGHT
|
#undef MASTER_RIGHT
|
||||||
// #define USB_VBUS_PIN B10
|
#define USB_VBUS_PIN B10
|
||||||
|
|
||||||
#undef RGB_DI_PIN
|
#undef RGB_DI_PIN
|
||||||
#define RGB_DI_PIN A1
|
#define RGB_DI_PIN A1
|
||||||
|
@ -55,6 +58,8 @@
|
||||||
#define AUDIO_PWM_PAL_MODE 2
|
#define AUDIO_PWM_PAL_MODE 2
|
||||||
#define AUDIO_STATE_TIMER GPTD3
|
#define AUDIO_STATE_TIMER GPTD3
|
||||||
#define AUDIO_INIT_DELAY
|
#define AUDIO_INIT_DELAY
|
||||||
|
#define AUDIO_ENABLE_TONE_MULTIPLEXING
|
||||||
|
#define AUDIO_TONE_MULTIPLEXING_RATE_DEFAULT 10
|
||||||
|
|
||||||
#undef SOFT_SERIAL_PIN
|
#undef SOFT_SERIAL_PIN
|
||||||
// #define SERIAL_USART_FULL_DUPLEX // Enable full duplex operation mode.
|
// #define SERIAL_USART_FULL_DUPLEX // Enable full duplex operation mode.
|
||||||
|
@ -64,12 +69,8 @@
|
||||||
// #define SERIAL_USART_TX_PAL_MODE 7 // Pin "alternate function", see the respective datasheet for the appropriate values for your MCU. default: 7
|
// #define SERIAL_USART_TX_PAL_MODE 7 // Pin "alternate function", see the respective datasheet for the appropriate values for your MCU. default: 7
|
||||||
// #define SERIAL_USART_RX_PAL_MODE 7 // Pin "alternate function", see the respective datasheet for the appropriate values for your MCU. default: 7
|
// #define SERIAL_USART_RX_PAL_MODE 7 // Pin "alternate function", see the respective datasheet for the appropriate values for your MCU. default: 7
|
||||||
// #define SERIAL_USART_TIMEOUT 100 // USART driver timeout. default 100
|
// #define SERIAL_USART_TIMEOUT 100 // USART driver timeout. default 100
|
||||||
// // #define SERIAL_USART_PIN_SWAP // swap RX and TX pins on master
|
// #define SERIAL_USART_SPEED 921600
|
||||||
// // To use the highest possible baudrate (3.75Mbit/s) uncomment the following
|
#define SERIAL_USART_SPEED (1.5 * 1024 * 1024)
|
||||||
// // line, this can result in dropped communications so lower the speed if there
|
|
||||||
// // are many timeouts.
|
|
||||||
// // #define SERIAL_USART_SPEED (STM32_PCLK2 >> 4)
|
|
||||||
#define SERIAL_USART_SPEED 921600
|
|
||||||
|
|
||||||
#define CRC8_USE_TABLE
|
#define CRC8_USE_TABLE
|
||||||
#define CRC8_OPTIMIZE_SPEED
|
#define CRC8_OPTIMIZE_SPEED
|
||||||
|
@ -103,3 +104,12 @@
|
||||||
#define RGB_MATRIX_MAXIMUM_BRIGHTNESS 150
|
#define RGB_MATRIX_MAXIMUM_BRIGHTNESS 150
|
||||||
|
|
||||||
#define CHARYBDIS_CONFIG_SYNC
|
#define CHARYBDIS_CONFIG_SYNC
|
||||||
|
|
||||||
|
#define BOOTMAGIC_LITE_ROW 0
|
||||||
|
#define BOOTMAGIC_LITE_COLUMN 0
|
||||||
|
#define BOOTMAGIC_LITE_ROW_RIGHT 5
|
||||||
|
#define BOOTMAGIC_LITE_COLUMN_RIGHT 0
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_ROW 1
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_COLUMN 0
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_ROW_RIGHT 1
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT 0
|
||||||
|
|
|
@ -26,8 +26,8 @@
|
||||||
KC_ESC, ________________NUMBER_LEFT________________, ________________NUMBER_RIGHT_______________, UC_CLUE, \
|
KC_ESC, ________________NUMBER_LEFT________________, ________________NUMBER_RIGHT_______________, UC_CLUE, \
|
||||||
SH_TT, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, SH_TT, \
|
SH_TT, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, SH_TT, \
|
||||||
LALT_T(KC_TAB), K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, RALT_T(K1B), \
|
LALT_T(KC_TAB), K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, RALT_T(K1B), \
|
||||||
OS_LSFT,CTL_T(K21),ALT_T(K22),GUI_T(K23),K24,K25, K26,K27,RGUI_T(K28),RALT_T(K29),RCTL_T(K2A), OS_RSFT, \
|
OS_LSFT,CTL_T(K21), K22, K23, K24, K25, K26,K27,RGUI_T(K28),RALT_T(K29),RCTL_T(K2A), OS_RSFT, \
|
||||||
SFT_T(KC_GRV), UC_IRNY, OS_LGUI, TT(_MOUSE), KC_ENT, \
|
SFT_T(KC_GRV), OS_LALT, OS_LGUI, TT(_MOUSE), KC_ENT, \
|
||||||
KC_SPC, BK_LWER, DL_RAIS \
|
KC_SPC, BK_LWER, DL_RAIS \
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -31,3 +31,4 @@ TAP_DANCE_ENABLE = yes
|
||||||
DEBOUNCE_TYPE = asym_eager_defer_pk
|
DEBOUNCE_TYPE = asym_eager_defer_pk
|
||||||
WPM_ENABLE = yes
|
WPM_ENABLE = yes
|
||||||
LTO_ENABLE = no
|
LTO_ENABLE = no
|
||||||
|
# OPT = 3
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
// Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#define CIRQUE_PINNACLE_TAP_ENABLE
|
||||||
|
#define POINTING_DEVICE_GESTURES_CURSOR_GLIDE_ENABLE
|
||||||
|
#define POINTING_DEVICE_GESTURES_SCROLL_ENABLE
|
|
@ -0,0 +1,160 @@
|
||||||
|
/**
|
||||||
|
* Copyright 2022 Charly Delay <charly@codesink.dev> (@0xcharly)
|
||||||
|
*
|
||||||
|
* This program 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 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "drashna.h"
|
||||||
|
|
||||||
|
// clang-format off
|
||||||
|
#define LAYOUT_split_3x5_2_wrapper(...) LAYOUT_split_3x5_2(__VA_ARGS__)
|
||||||
|
#define LAYOUT_split_3x5_2_base( \
|
||||||
|
K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, \
|
||||||
|
K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, \
|
||||||
|
K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A \
|
||||||
|
) \
|
||||||
|
LAYOUT_split_3x5_2 ( \
|
||||||
|
K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, \
|
||||||
|
ALT_T(K11), K12, K13, K14, GUI_T(K15), LGUI_T(K16), K17, K18, K19, LALT_T(K1A), \
|
||||||
|
CTL_T(K21), K22, K23, K24, K25, K26, K27, K28, K29, RCTL_T(K2A), \
|
||||||
|
KC_SPC, BK_LWER, DL_RAIS, RSFT_T(KC_ENT) \
|
||||||
|
)
|
||||||
|
|
||||||
|
#define LAYOUT_split_3x5_2_base_wrapper(...) LAYOUT_split_3x5_2_base(__VA_ARGS__)
|
||||||
|
|
||||||
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
|
|
||||||
|
[_DEFAULT_LAYER_1] = LAYOUT_split_3x5_2_base_wrapper(
|
||||||
|
_________________QWERTY_L1_________________, _________________QWERTY_R1_________________,
|
||||||
|
_________________QWERTY_L2_________________, _________________QWERTY_R2_________________,
|
||||||
|
_________________QWERTY_L3_________________, _________________QWERTY_R3_________________
|
||||||
|
),
|
||||||
|
|
||||||
|
[_DEFAULT_LAYER_2] = LAYOUT_split_3x5_2_base_wrapper(
|
||||||
|
______________COLEMAK_MOD_DH_L1____________, ______________COLEMAK_MOD_DH_R1____________,
|
||||||
|
______________COLEMAK_MOD_DH_L2____________, ______________COLEMAK_MOD_DH_R2____________,
|
||||||
|
______________COLEMAK_MOD_DH_L3____________, ______________COLEMAK_MOD_DH_R3____________
|
||||||
|
),
|
||||||
|
[_DEFAULT_LAYER_3] = LAYOUT_split_3x5_2_base_wrapper(
|
||||||
|
_________________COLEMAK_L1________________, _________________COLEMAK_R1________________,
|
||||||
|
_________________COLEMAK_L2________________, _________________COLEMAK_R2________________,
|
||||||
|
_________________COLEMAK_L3________________, _________________COLEMAK_R3________________
|
||||||
|
),
|
||||||
|
|
||||||
|
[_DEFAULT_LAYER_4] = LAYOUT_split_3x5_2_base_wrapper(
|
||||||
|
_________________DVORAK_L1_________________, _________________DVORAK_R1_________________,
|
||||||
|
_________________DVORAK_L2_________________, _________________DVORAK_R2_________________,
|
||||||
|
_________________DVORAK_L3_________________, _________________DVORAK_R3_________________
|
||||||
|
),
|
||||||
|
|
||||||
|
[_MOUSE] = LAYOUT_split_3x5_2(
|
||||||
|
_______, _______, _______, _______, _______, KC_WH_U, DPI_RMOD,DPI_MOD, S_D_RMOD,S_D_MOD,
|
||||||
|
_______, _______, _______, _______, _______, KC_WH_D, KC_BTN1, KC_BTN3, KC_BTN2, KC_BTN6,
|
||||||
|
_______, _______, _______, _______, _______, KC_BTN7, KC_BTN4, KC_BTN5, KC_BTN8, _______,
|
||||||
|
SNIPING, _______, _______, _______
|
||||||
|
),
|
||||||
|
[_LOWER] = LAYOUT_split_3x5_2_wrapper(
|
||||||
|
_________________LOWER_L1__________________, _________________LOWER_R1__________________,
|
||||||
|
_________________LOWER_L2__________________, _________________LOWER_R2__________________,
|
||||||
|
_________________LOWER_L3__________________, _________________LOWER_R3__________________,
|
||||||
|
_______, _______, _______, AUTO_CTN
|
||||||
|
),
|
||||||
|
[_RAISE] = LAYOUT_split_3x5_2_wrapper(
|
||||||
|
_________________RAISE_L1__________________, _________________RAISE_R1__________________,
|
||||||
|
_________________RAISE_L2__________________, _________________RAISE_R2__________________,
|
||||||
|
_________________RAISE_L3__________________, _________________RAISE_R3__________________,
|
||||||
|
_______, _______, _______, _______
|
||||||
|
),
|
||||||
|
[_ADJUST] = LAYOUT_split_3x5_2_wrapper(
|
||||||
|
_________________ADJUST_L1_________________, _________________ADJUST_R1_________________,
|
||||||
|
_________________ADJUST_L2_________________, _________________ADJUST_R2_________________,
|
||||||
|
_________________ADJUST_L3_________________, _________________ADJUST_R3_________________,
|
||||||
|
KC_NUKE, _______, _______, QK_BOOT
|
||||||
|
),
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
void matrix_output_unselect_delay(uint8_t line, bool key_pressed) {
|
||||||
|
for (int32_t i = 0; i < 40; i++) {
|
||||||
|
__asm__ volatile("nop" ::: "memory");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(OLED_ENABLE) && defined(OLED_DISPLAY_128X128)
|
||||||
|
# ifdef UNICODE_COMMON_ENABLE
|
||||||
|
# include "process_unicode_common.h"
|
||||||
|
# include "keyrecords/unicode.h"
|
||||||
|
# endif
|
||||||
|
|
||||||
|
extern const char PROGMEM display_border[3];
|
||||||
|
|
||||||
|
|
||||||
|
extern uint32_t oled_timer;
|
||||||
|
extern bool is_oled_enabled;
|
||||||
|
|
||||||
|
|
||||||
|
bool oled_task_keymap(void) {
|
||||||
|
static const char PROGMEM header_image[] = {
|
||||||
|
0, 192, 32, 16, 8, 4, 2, 1, 1, 1, 1, 1, 1, 1, 1, 3, 7, 15, 31, 63, 127, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 127, 63, 31, 15, 7, 3, 1, 1, 1, 1, 1, 1, 1, 1, 2, 4, 8, 16, 32, 192, 0,
|
||||||
|
// 0,255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 7, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 7, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 0
|
||||||
|
};
|
||||||
|
oled_write_raw_P(header_image, sizeof(header_image));
|
||||||
|
oled_set_cursor(7, 0);
|
||||||
|
oled_write_P(PSTR("Rock On"), true);
|
||||||
|
|
||||||
|
render_default_layer_state(1, 1);
|
||||||
|
render_layer_state(1, 2);
|
||||||
|
render_kitty(0, 5);
|
||||||
|
render_wpm(1, 7, 5);
|
||||||
|
# if defined(POINTING_DEVICE_ENABLE)
|
||||||
|
render_pointing_dpi_status(dilemma_get_pointer_sniping_enabled() ? dilemma_get_pointer_sniping_dpi() : dilemma_get_pointer_default_dpi(), 1, 7, 6);
|
||||||
|
render_mouse_mode(17, 6);
|
||||||
|
# elif defined(WPM_ENABLE) && defined(DEBUG_MATRIX_SCAN_RATE)
|
||||||
|
render_matrix_scan_rate(1, 7, 6);
|
||||||
|
# endif
|
||||||
|
render_bootmagic_status(7, 7);
|
||||||
|
render_user_status(1, 9);
|
||||||
|
|
||||||
|
render_mod_status(get_mods() | get_oneshot_mods(), 1, 10);
|
||||||
|
render_keylock_status(host_keyboard_led_state(), 1, 11);
|
||||||
|
render_unicode_mode(1, 12);
|
||||||
|
|
||||||
|
// render_rgb_hsv(1, 13);
|
||||||
|
oled_set_cursor(1, 13);
|
||||||
|
// oled_write_P(PSTR("Timer:"), false);
|
||||||
|
// oled_write(get_u8_str((uint8_t)(timer_elapsed32(oled_timer) / 1000), ' '), false);
|
||||||
|
oled_write_P(PSTR("Status: "), false);
|
||||||
|
if (is_oled_enabled) {
|
||||||
|
oled_write_P(PSTR("on "), false);
|
||||||
|
} else {
|
||||||
|
oled_write_P(PSTR("off"), false);
|
||||||
|
}
|
||||||
|
|
||||||
|
render_keylogger_status(1, 14);
|
||||||
|
|
||||||
|
for (uint8_t i = 1; i < 15; i++) {
|
||||||
|
oled_set_cursor(0, i);
|
||||||
|
oled_write_raw_P(display_border, sizeof(display_border));
|
||||||
|
oled_set_cursor(21, i);
|
||||||
|
oled_write_raw_P(display_border, sizeof(display_border));
|
||||||
|
}
|
||||||
|
|
||||||
|
static const char PROGMEM footer_image[] = {0, 3, 4, 8, 16, 32, 64, 128, 128, 128, 128, 128, 128, 128, 192, 224, 240, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 240, 224, 192, 128, 128, 128, 128, 128, 128, 128, 64, 32, 16, 8, 4, 3, 0};
|
||||||
|
oled_set_cursor(0, 15);
|
||||||
|
oled_write_raw_P(footer_image, sizeof(footer_image));
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -0,0 +1,8 @@
|
||||||
|
SWAP_HANDS_ENABLE = no
|
||||||
|
AUTOCORRECTION_ENABLE = yes
|
||||||
|
CAPS_WORD_ENABLE = yes
|
||||||
|
CONSOLE_ENABLE = yes
|
||||||
|
KEYLOGGER_ENABLE = no
|
||||||
|
WPM_ENABLE = yes
|
||||||
|
OLED_ENABLE = yes
|
||||||
|
OLED_DRIVER = custom
|
|
@ -75,7 +75,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#define I2C1_SCL_PAL_MODE 4
|
#define I2C1_SCL_PAL_MODE 4
|
||||||
#define I2C1_SDA_PAL_MODE 4
|
#define I2C1_SDA_PAL_MODE 4
|
||||||
#define I2C1_CLOCK_SPEED 400000
|
#define I2C1_CLOCK_SPEED 400000
|
||||||
#define I2C1_DUTY_CYCLE FAST_DUTY_CYCLE_2
|
#define I2C1_DUTY_CYCLE FAST_DUTY_CYCLE_16_9
|
||||||
|
|
||||||
/* encoder config */
|
/* encoder config */
|
||||||
#define ENCODERS_PAD_A \
|
#define ENCODERS_PAD_A \
|
||||||
|
|
|
@ -24,7 +24,7 @@ void matrix_scan_sub_kb(void) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void bootmagic_lite(void) {
|
__attribute__((weak)) void bootmagic_lite(void) {
|
||||||
// We need multiple scans because debouncing can't be turned off.
|
// We need multiple scans because debouncing can't be turned off.
|
||||||
matrix_scan();
|
matrix_scan();
|
||||||
#if defined(DEBOUNCE) && DEBOUNCE > 0
|
#if defined(DEBOUNCE) && DEBOUNCE > 0
|
||||||
|
|
|
@ -28,3 +28,9 @@
|
||||||
#define CHARYBDIS_SNIPING_DPI_CONFIG_STEP 200
|
#define CHARYBDIS_SNIPING_DPI_CONFIG_STEP 200
|
||||||
|
|
||||||
#define ENCODER_DEFAULT_POS 0x3
|
#define ENCODER_DEFAULT_POS 0x3
|
||||||
|
|
||||||
|
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_ROW 1
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_COLUMN 0
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_ROW_RIGHT 7
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT 5
|
||||||
|
|
|
@ -19,14 +19,16 @@
|
||||||
|
|
||||||
// safe range starts at `PLOOPY_SAFE_RANGE` instead.
|
// safe range starts at `PLOOPY_SAFE_RANGE` instead.
|
||||||
|
|
||||||
|
// clang-format off
|
||||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
[0] = LAYOUT(/* Base */
|
[0] = LAYOUT(
|
||||||
C(KC_C), KC_BTN1, KC_BTN3, KC_BTN2, MO(1), KC_BTN4, KC_BTN5, DPI_CONFIG),
|
C(KC_C), KC_BTN1, KC_BTN3, KC_BTN2, MO(1), KC_BTN4, KC_BTN5, DPI_CONFIG),
|
||||||
[1] = LAYOUT(/* Base */
|
[1] = LAYOUT(
|
||||||
RGB_HUI, RGB_MOD, RGB_TOG, RGB_RMOD, MO(1), KC_VOLU, KC_VOLD, QK_BOOT)
|
RGB_HUI, RGB_MOD, RGB_TOG, RGB_RMOD, MO(1), KC_VOLU, KC_VOLD, QK_BOOT)
|
||||||
|
|
||||||
};
|
};
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
|
#ifdef RGBLIGHT_ENABLE
|
||||||
void eeconkfig_init_user(void) {
|
void eeconkfig_init_user(void) {
|
||||||
rgblight_enable();
|
rgblight_enable();
|
||||||
# ifdef RGBLIGHT_EFFECT_TWINKLE
|
# ifdef RGBLIGHT_EFFECT_TWINKLE
|
||||||
|
@ -36,3 +38,4 @@ void eeconkfig_init_user(void) {
|
||||||
# endif
|
# endif
|
||||||
rgblight_sethsv(HSV_MAGENTA);
|
rgblight_sethsv(HSV_MAGENTA);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
USER_NAME := not_drashna
|
USER_NAME := not_drashna
|
||||||
|
BOOTLOADER = qmk-hid
|
||||||
|
|
||||||
RGBLIGHT_ENABLE = yes
|
RGBLIGHT_ENABLE = yes
|
||||||
CONSOLE_ENABLE = no
|
CONSOLE_ENABLE = no
|
||||||
|
|
|
@ -46,4 +46,9 @@
|
||||||
#define BOOTMAGIC_LITE_ROW_RIGHT 4
|
#define BOOTMAGIC_LITE_ROW_RIGHT 4
|
||||||
#define BOOTMAGIC_LITE_COLUMN_RIGHT 7
|
#define BOOTMAGIC_LITE_COLUMN_RIGHT 7
|
||||||
|
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_ROW 1
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_COLUMN 7
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_ROW_RIGHT 5
|
||||||
|
#define BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT 7
|
||||||
|
|
||||||
#define SERIAL_USART_SPEED 921600
|
#define SERIAL_USART_SPEED 921600
|
||||||
|
|
|
@ -1,5 +1,93 @@
|
||||||
#if __has_include("../qmk_secrets/autocorrection_data.h")
|
#if __has_include("../qmk_secrets/autocorrection_data.h")
|
||||||
|
# pragma message "Loading custom library"
|
||||||
# include "../qmk_secrets/autocorrection_data.h"
|
# include "../qmk_secrets/autocorrection_data.h"
|
||||||
|
# define AUTOCORRECTION_MIN_LENGTH AUTOCORRECT_MIN_LENGTH
|
||||||
|
# define AUTOCORRECTION_MAX_LENGTH AUTOCORRECT_MAX_LENGTH
|
||||||
|
|
||||||
#else
|
#else
|
||||||
# include "autocorrect_data_default.h"
|
// Generated code.
|
||||||
|
|
||||||
|
// Autocorrection dictionary (70 entries):
|
||||||
|
// :guage -> gauge
|
||||||
|
// :the:the: -> the
|
||||||
|
// :thier -> their
|
||||||
|
// :ture -> true
|
||||||
|
// accomodate -> accommodate
|
||||||
|
// acommodate -> accommodate
|
||||||
|
// aparent -> apparent
|
||||||
|
// aparrent -> apparent
|
||||||
|
// apparant -> apparent
|
||||||
|
// apparrent -> apparent
|
||||||
|
// aquire -> acquire
|
||||||
|
// becuase -> because
|
||||||
|
// cauhgt -> caught
|
||||||
|
// cheif -> chief
|
||||||
|
// choosen -> chosen
|
||||||
|
// cieling -> ceiling
|
||||||
|
// collegue -> colleague
|
||||||
|
// concensus -> consensus
|
||||||
|
// contians -> contains
|
||||||
|
// cosnt -> const
|
||||||
|
// dervied -> derived
|
||||||
|
// fales -> false
|
||||||
|
// fasle -> false
|
||||||
|
// fitler -> filter
|
||||||
|
// flase -> false
|
||||||
|
// foward -> forward
|
||||||
|
// frequecy -> frequency
|
||||||
|
// gaurantee -> guarantee
|
||||||
|
// guaratee -> guarantee
|
||||||
|
// heigth -> height
|
||||||
|
// heirarchy -> hierarchy
|
||||||
|
// inclued -> include
|
||||||
|
// interator -> iterator
|
||||||
|
// intput -> input
|
||||||
|
// invliad -> invalid
|
||||||
|
// lenght -> length
|
||||||
|
// liasion -> liaison
|
||||||
|
// libary -> library
|
||||||
|
// listner -> listener
|
||||||
|
// looses: -> loses
|
||||||
|
// looup -> lookup
|
||||||
|
// manefist -> manifest
|
||||||
|
// namesapce -> namespace
|
||||||
|
// namespcae -> namespace
|
||||||
|
// occassion -> occasion
|
||||||
|
// occured -> occurred
|
||||||
|
// ouptut -> output
|
||||||
|
// ouput -> output
|
||||||
|
// overide -> override
|
||||||
|
// postion -> position
|
||||||
|
// priviledge -> privilege
|
||||||
|
// psuedo -> pseudo
|
||||||
|
// recieve -> receive
|
||||||
|
// refered -> referred
|
||||||
|
// relevent -> relevant
|
||||||
|
// repitition -> repetition
|
||||||
|
// retrun -> return
|
||||||
|
// retun -> return
|
||||||
|
// reuslt -> result
|
||||||
|
// reutrn -> return
|
||||||
|
// saftey -> safety
|
||||||
|
// seperate -> separate
|
||||||
|
// singed -> signed
|
||||||
|
// stirng -> string
|
||||||
|
// strign -> string
|
||||||
|
// swithc -> switch
|
||||||
|
// swtich -> switch
|
||||||
|
// thresold -> threshold
|
||||||
|
// udpate -> update
|
||||||
|
// widht -> width
|
||||||
|
|
||||||
|
#define AUTOCORRECT_MIN_LENGTH 5 // ":ture"
|
||||||
|
#define AUTOCORRECT_MAX_LENGTH 10 // "accomodate"
|
||||||
|
|
||||||
|
#define DICTIONARY_SIZE 1104
|
||||||
|
|
||||||
|
static const uint8_t autocorrect_data[DICTIONARY_SIZE] PROGMEM = {108, 43, 0, 6, 71, 0, 7, 81, 0, 8, 199, 0, 9, 240, 1, 10, 250, 1, 11, 26, 2, 17, 53, 2, 18, 190, 2, 19, 202, 2, 21, 212, 2, 22, 20, 3, 23, 67, 3, 28, 16, 4, 0, 72, 50, 0, 22, 60, 0, 0, 11, 23, 44, 8, 11, 23, 44, 0, 132, 0, 8, 22, 18, 18, 15, 0, 132, 115, 101, 115, 0, 11, 23, 12, 26, 22, 0, 129, 99, 104, 0, 68, 94, 0, 8, 106, 0, 15, 174, 0, 21, 187, 0, 0, 12, 15, 25, 17, 12, 0, 131, 97, 108, 105, 100, 0, 74, 119, 0, 12, 129, 0, 21, 140, 0, 24, 165, 0, 0, 17, 12, 22, 0, 131, 103, 110, 101, 100, 0, 25, 21, 8, 7, 0, 131, 105, 118, 101, 100, 0, 72, 147, 0, 24, 156, 0, 0, 9, 8, 21, 0, 129, 114, 101, 100, 0, 6, 6, 18, 0, 129, 114, 101, 100, 0, 15, 6, 17, 12, 0, 129, 100, 101, 0, 18, 22, 8, 21, 11, 23, 0, 130, 104, 111,
|
||||||
|
108, 100, 0, 4, 26, 18, 9, 0, 131, 114, 119, 97, 114, 100, 0, 68, 233, 0, 6, 246, 0, 7, 4, 1, 8, 16, 1, 10, 52, 1, 15, 81, 1, 21, 90, 1, 22, 117, 1, 23, 144, 1, 24, 215, 1, 25, 228, 1, 0, 6, 19, 22, 8, 16, 4, 17, 0, 130, 97, 99, 101, 0, 19, 4, 22, 8, 16, 4, 17, 0, 131, 112, 97, 99, 101, 0, 12, 21, 8, 25, 18, 0, 130, 114, 105, 100, 101, 0, 23, 0, 68, 25, 1, 17, 36, 1, 0, 21, 4, 24, 10, 0, 130, 110, 116, 101, 101, 0, 4, 21, 24, 4, 10, 0, 135, 117, 97, 114, 97, 110, 116, 101, 101, 0, 68, 59, 1, 7, 69, 1, 0, 24, 10, 44, 0, 131, 97, 117, 103, 101, 0, 8, 15, 12, 25, 12, 21, 19, 0, 130, 103, 101, 0, 22, 4, 9, 0, 130, 108, 115, 101, 0, 76, 97, 1, 24, 109, 1, 0, 24, 20, 4, 0, 132, 99, 113, 117, 105, 114, 101, 0, 23, 44, 0,
|
||||||
|
130, 114, 117, 101, 0, 4, 0, 79, 126, 1, 24, 134, 1, 0, 9, 0, 131, 97, 108, 115, 101, 0, 6, 8, 5, 0, 131, 97, 117, 115, 101, 0, 4, 0, 71, 156, 1, 19, 193, 1, 21, 203, 1, 0, 18, 16, 0, 80, 166, 1, 18, 181, 1, 0, 18, 6, 4, 0, 135, 99, 111, 109, 109, 111, 100, 97, 116, 101, 0, 6, 6, 4, 0, 132, 109, 111, 100, 97, 116, 101, 0, 7, 24, 0, 132, 112, 100, 97, 116, 101, 0, 8, 19, 8, 22, 0, 132, 97, 114, 97, 116, 101, 0, 10, 8, 15, 15, 18, 6, 0, 130, 97, 103, 117, 101, 0, 8, 12, 6, 8, 21, 0, 131, 101, 105, 118, 101, 0, 12, 8, 11, 6, 0, 130, 105, 101, 102, 0, 17, 0, 76, 3, 2, 21, 16, 2, 0, 15, 8, 12, 6, 0, 133, 101, 105, 108, 105, 110, 103, 0, 12, 23, 22, 0, 131, 114, 105, 110, 103, 0, 70, 33, 2, 23, 44, 2, 0, 12, 23, 26, 22, 0, 131, 105,
|
||||||
|
116, 99, 104, 0, 10, 12, 8, 11, 0, 129, 104, 116, 0, 72, 69, 2, 10, 80, 2, 18, 89, 2, 21, 156, 2, 24, 167, 2, 0, 22, 18, 18, 11, 6, 0, 131, 115, 101, 110, 0, 12, 21, 23, 22, 0, 129, 110, 103, 0, 12, 0, 86, 98, 2, 23, 124, 2, 0, 68, 105, 2, 22, 114, 2, 0, 12, 15, 0, 131, 105, 115, 111, 110, 0, 4, 6, 6, 18, 0, 131, 105, 111, 110, 0, 76, 131, 2, 22, 146, 2, 0, 23, 12, 19, 8, 21, 0, 134, 101, 116, 105, 116, 105, 111, 110, 0, 18, 19, 0, 131, 105, 116, 105, 111, 110, 0, 23, 24, 8, 21, 0, 131, 116, 117, 114, 110, 0, 85, 174, 2, 23, 183, 2, 0, 23, 8, 21, 0, 130, 117, 114, 110, 0, 8, 21, 0, 128, 114, 110, 0, 7, 8, 24, 22, 19, 0, 131, 101, 117, 100, 111, 0, 24, 18, 18, 15, 0, 129, 107, 117, 112, 0, 72, 219, 2, 18, 3, 3, 0, 76, 229, 2, 15, 238,
|
||||||
|
2, 17, 248, 2, 0, 11, 23, 44, 0, 130, 101, 105, 114, 0, 23, 12, 9, 0, 131, 108, 116, 101, 114, 0, 23, 22, 12, 15, 0, 130, 101, 110, 101, 114, 0, 23, 4, 21, 8, 23, 17, 12, 0, 135, 116, 101, 114, 97, 116, 111, 114, 0, 72, 30, 3, 17, 38, 3, 24, 51, 3, 0, 15, 4, 9, 0, 129, 115, 101, 0, 4, 12, 23, 17, 18, 6, 0, 131, 97, 105, 110, 115, 0, 22, 17, 8, 6, 17, 18, 6, 0, 133, 115, 101, 110, 115, 117, 115, 0, 74, 86, 3, 11, 96, 3, 15, 118, 3, 17, 129, 3, 22, 218, 3, 24, 232, 3, 0, 11, 24, 4, 6, 0, 130, 103, 104, 116, 0, 71, 103, 3, 10, 110, 3, 0, 12, 26, 0, 129, 116, 104, 0, 17, 8, 15, 0, 129, 116, 104, 0, 22, 24, 8, 21, 0, 131, 115, 117, 108, 116, 0, 68, 139, 3, 8, 150, 3, 22, 210, 3, 0, 21, 4, 19, 19, 4, 0, 130, 101, 110, 116, 0, 85, 157,
|
||||||
|
3, 25, 200, 3, 0, 68, 164, 3, 21, 175, 3, 0, 19, 4, 0, 132, 112, 97, 114, 101, 110, 116, 0, 4, 19, 0, 68, 185, 3, 19, 193, 3, 0, 133, 112, 97, 114, 101, 110, 116, 0, 4, 0, 131, 101, 110, 116, 0, 8, 15, 8, 21, 0, 130, 97, 110, 116, 0, 18, 6, 0, 130, 110, 115, 116, 0, 12, 9, 8, 17, 4, 16, 0, 132, 105, 102, 101, 115, 116, 0, 83, 239, 3, 23, 6, 4, 0, 87, 246, 3, 24, 254, 3, 0, 17, 12, 0, 131, 112, 117, 116, 0, 18, 0, 130, 116, 112, 117, 116, 0, 19, 24, 18, 0, 131, 116, 112, 117, 116, 0, 70, 29, 4, 8, 41, 4, 11, 51, 4, 21, 69, 4, 0, 8, 24, 20, 8, 21, 9, 0, 129, 110, 99, 121, 0, 23, 9, 4, 22, 0, 130, 101, 116, 121, 0, 6, 21, 4, 21, 12, 8, 11, 0, 135, 105, 101, 114, 97, 114, 99, 104, 121, 0, 4, 5, 12, 15, 0, 130, 114, 97, 114, 121, 0};
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -3,6 +3,12 @@
|
||||||
|
|
||||||
#include "drashna.h"
|
#include "drashna.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef I2C_SCANNER_ENABLE
|
||||||
|
void matrix_scan_i2c(void);
|
||||||
|
void keyboard_post_init_i2c(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
__attribute__((weak)) void keyboard_pre_init_keymap(void) {}
|
__attribute__((weak)) void keyboard_pre_init_keymap(void) {}
|
||||||
void keyboard_pre_init_user(void) {
|
void keyboard_pre_init_user(void) {
|
||||||
userspace_config.raw = eeconfig_read_user();
|
userspace_config.raw = eeconfig_read_user();
|
||||||
|
@ -42,6 +48,10 @@ void keyboard_post_init_user(void) {
|
||||||
#if defined(SPLIT_KEYBOARD) && defined(SPLIT_TRANSACTION_IDS_USER)
|
#if defined(SPLIT_KEYBOARD) && defined(SPLIT_TRANSACTION_IDS_USER)
|
||||||
keyboard_post_init_transport_sync();
|
keyboard_post_init_transport_sync();
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef I2C_SCANNER_ENABLE
|
||||||
|
matrix_scan_i2c();
|
||||||
|
#endif
|
||||||
|
|
||||||
keyboard_post_init_keymap();
|
keyboard_post_init_keymap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,10 +64,10 @@ void shutdown_user(void) {
|
||||||
#ifdef RGBLIGHT_ENABLE
|
#ifdef RGBLIGHT_ENABLE
|
||||||
rgblight_enable_noeeprom();
|
rgblight_enable_noeeprom();
|
||||||
rgblight_mode_noeeprom(1);
|
rgblight_mode_noeeprom(1);
|
||||||
rgblight_setrgb_red();
|
rgblight_setrgb(rgblight_get_val(), 0x00, 0x00);
|
||||||
#endif // RGBLIGHT_ENABLE
|
#endif // RGBLIGHT_ENABLE
|
||||||
#ifdef RGB_MATRIX_ENABLE
|
#ifdef RGB_MATRIX_ENABLE
|
||||||
rgb_matrix_set_color_all(0xFF, 0x00, 0x00);
|
rgb_matrix_set_color_all(rgb_matrix_get_val(), 0x00, 0x00);
|
||||||
rgb_matrix_update_pwm_buffers();
|
rgb_matrix_update_pwm_buffers();
|
||||||
#endif // RGB_MATRIX_ENABLE
|
#endif // RGB_MATRIX_ENABLE
|
||||||
#ifdef OLED_ENABLE
|
#ifdef OLED_ENABLE
|
||||||
|
@ -112,6 +122,12 @@ void matrix_scan_user(void) {
|
||||||
#endif
|
#endif
|
||||||
#if defined(CUSTOM_RGB_MATRIX)
|
#if defined(CUSTOM_RGB_MATRIX)
|
||||||
matrix_scan_rgb_matrix();
|
matrix_scan_rgb_matrix();
|
||||||
|
#endif
|
||||||
|
#ifdef I2C_SCANNER_ENABLE
|
||||||
|
matrix_scan_i2c();
|
||||||
|
#endif
|
||||||
|
#ifdef CUSTOM_OLED_DRIVER
|
||||||
|
matrix_scan_oled();
|
||||||
#endif
|
#endif
|
||||||
matrix_scan_secret();
|
matrix_scan_secret();
|
||||||
|
|
||||||
|
|
|
@ -11,26 +11,20 @@
|
||||||
#endif
|
#endif
|
||||||
#define IS_COMMAND() (((get_mods() | get_oneshot_mods()) & MOD_MASK_SHIFT) == MOD_MASK_SHIFT)
|
#define IS_COMMAND() (((get_mods() | get_oneshot_mods()) & MOD_MASK_SHIFT) == MOD_MASK_SHIFT)
|
||||||
|
|
||||||
/* Set Polling rate to 1000Hz */
|
|
||||||
#define USB_POLLING_INTERVAL_MS 1
|
|
||||||
|
|
||||||
#if defined(SPLIT_KEYBOARD)
|
#if defined(SPLIT_KEYBOARD)
|
||||||
// # define SPLIT_TRANSPORT_MIRROR
|
# include "split/split_config.h"
|
||||||
# define SPLIT_LAYER_STATE_ENABLE
|
|
||||||
# define SPLIT_LED_STATE_ENABLE
|
|
||||||
# define SPLIT_MODS_ENABLE
|
|
||||||
# ifdef WPM_ENABLE
|
|
||||||
# define SPLIT_WPM_ENABLE
|
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef RGBLIGHT_ENABLE
|
||||||
|
# include "rgb/rgblight_config.h"
|
||||||
|
#endif // RGBLIGHT_ENABLE
|
||||||
|
|
||||||
|
#ifdef RGB_MATRIX_ENABLE
|
||||||
|
# include "rgb/rgb_matrix_config.h"
|
||||||
|
#endif // RGB_MATRIX_ENABLE
|
||||||
|
|
||||||
#ifdef OLED_ENABLE
|
#ifdef OLED_ENABLE
|
||||||
# define SPLIT_OLED_ENABLE
|
# include "oled/oled_config.h"
|
||||||
# endif
|
|
||||||
# if defined(__AVR__) && !defined(SELECT_SOFT_SERIAL_SPEED)
|
|
||||||
# define SELECT_SOFT_SERIAL_SPEED 1
|
|
||||||
# endif
|
|
||||||
# ifdef CUSTOM_SPLIT_TRANSPORT_SYNC
|
|
||||||
# define SPLIT_TRANSACTION_IDS_USER RPC_ID_USER_STATE_SYNC, RPC_ID_USER_KEYMAP_SYNC, RPC_ID_USER_CONFIG_SYNC, RPC_ID_USER_WATCHDOG_SYNC, RPC_ID_USER_KEYLOG_STR
|
|
||||||
# endif
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(WPM_ENABLE)
|
#if defined(WPM_ENABLE)
|
||||||
|
@ -71,157 +65,6 @@
|
||||||
|
|
||||||
#define UNICODE_SELECTED_MODES UC_WINC, UC_MAC
|
#define UNICODE_SELECTED_MODES UC_WINC, UC_MAC
|
||||||
|
|
||||||
#ifdef RGBLIGHT_ENABLE
|
|
||||||
# define RGBLIGHT_SLEEP
|
|
||||||
# define RGBLIGHT_EFFECT_TWINKLE_LIFE 250
|
|
||||||
# define RGBLIGHT_EFFECT_TWINKLE_PROBABILITY 1 / 24
|
|
||||||
#endif // RGBLIGHT_ENABLE
|
|
||||||
|
|
||||||
#ifdef RGB_MATRIX_ENABLE
|
|
||||||
# define RGB_MATRIX_KEYPRESSES // reacts to keypresses (will slow down matrix scan by a lot)
|
|
||||||
// # define RGB_MATRIX_KEYRELEASES // reacts to keyreleases (not recommened)
|
|
||||||
# define RGB_MATRIX_FRAMEBUFFER_EFFECTS
|
|
||||||
// # define RGB_DISABLE_AFTER_TIMEOUT 0 // number of ticks to wait until disabling effects
|
|
||||||
// # define RGB_DISABLE_WHEN_USB_SUSPENDED // turn off effects when suspended
|
|
||||||
|
|
||||||
# undef ENABLE_RGB_MATRIX_ALPHAS_MODS
|
|
||||||
# undef ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN
|
|
||||||
# undef ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT
|
|
||||||
# undef ENABLE_RGB_MATRIX_BREATHING
|
|
||||||
# undef ENABLE_RGB_MATRIX_BAND_SAT
|
|
||||||
# undef ENABLE_RGB_MATRIX_BAND_VAL
|
|
||||||
# undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
|
|
||||||
# undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
|
|
||||||
# undef ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT
|
|
||||||
# undef ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_ALL
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_UP_DOWN
|
|
||||||
# undef ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_PINWHEEL
|
|
||||||
# undef ENABLE_RGB_MATRIX_CYCLE_SPIRAL
|
|
||||||
# undef ENABLE_RGB_MATRIX_DUAL_BEACON
|
|
||||||
# undef ENABLE_RGB_MATRIX_RAINBOW_BEACON
|
|
||||||
# undef ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS
|
|
||||||
# undef ENABLE_RGB_MATRIX_RAINDROPS
|
|
||||||
# undef ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
|
|
||||||
# undef ENABLE_RGB_MATRIX_HUE_BREATHING
|
|
||||||
# undef ENABLE_RGB_MATRIX_HUE_PENDULUM
|
|
||||||
# undef ENABLE_RGB_MATRIX_HUE_WAVE
|
|
||||||
# undef ENABLE_RGB_MATRIX_PIXEL_RAIN
|
|
||||||
# undef ENABLE_RGB_MATRIX_PIXEL_FLOW
|
|
||||||
# undef ENABLE_RGB_MATRIX_PIXEL_FRACTAL
|
|
||||||
// enabled only if RGB_MATRIX_FRAMEBUFFER_EFFECTS is defined
|
|
||||||
# undef ENABLE_RGB_MATRIX_TYPING_HEATMAP
|
|
||||||
# undef ENABLE_RGB_MATRIX_DIGITAL_RAIN
|
|
||||||
// enabled only of RGB_MATRIX_KEYPRESSES or RGB_MATRIX_KEYRELEASES is defined
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
|
|
||||||
# undef ENABLE_RGB_MATRIX_SPLASH
|
|
||||||
# undef ENABLE_RGB_MATRIX_MULTISPLASH
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_SPLASH
|
|
||||||
# undef ENABLE_RGB_MATRIX_SOLID_MULTISPLASH
|
|
||||||
|
|
||||||
# define ENABLE_RGB_MATRIX_TYPING_HEATMAP
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
|
|
||||||
# if !defined(SPLIT_KEYBOARD) && !defined(KEYBOARD_ergodox_ez) && !defined(KEYBOARD_moonlander)
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_OUT_IN
|
|
||||||
# endif
|
|
||||||
# if defined(__arm__) || defined(__AVR_AT90USB1286__) || defined(KEYBOARD_launchpad)
|
|
||||||
// RGB Matrix Animation modes. Explicitly enabled
|
|
||||||
// For full list of effects, see:
|
|
||||||
// https://docs.qmk.fm/#/feature_rgb_matrix?id=rgb-matrix-effects
|
|
||||||
# define ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN
|
|
||||||
# define ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT
|
|
||||||
# define ENABLE_RGB_MATRIX_BREATHING
|
|
||||||
# define ENABLE_RGB_MATRIX_BAND_SAT
|
|
||||||
# define ENABLE_RGB_MATRIX_BAND_VAL
|
|
||||||
# define ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
|
|
||||||
# define ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
|
|
||||||
# define ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT
|
|
||||||
# define ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_ALL
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_UP_DOWN
|
|
||||||
# define ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_OUT_IN
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_PINWHEEL
|
|
||||||
# define ENABLE_RGB_MATRIX_CYCLE_SPIRAL
|
|
||||||
# define ENABLE_RGB_MATRIX_DUAL_BEACON
|
|
||||||
# define ENABLE_RGB_MATRIX_RAINBOW_BEACON
|
|
||||||
# define ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS
|
|
||||||
# define ENABLE_RGB_MATRIX_RAINDROPS
|
|
||||||
# define ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
|
|
||||||
# define ENABLE_RGB_MATRIX_HUE_BREATHING
|
|
||||||
# define ENABLE_RGB_MATRIX_HUE_PENDULUM
|
|
||||||
# define ENABLE_RGB_MATRIX_HUE_WAVE
|
|
||||||
# define ENABLE_RGB_MATRIX_PIXEL_RAIN
|
|
||||||
# define ENABLE_RGB_MATRIX_PIXEL_FLOW
|
|
||||||
# define ENABLE_RGB_MATRIX_PIXEL_FRACTAL
|
|
||||||
# define ENABLE_RGB_MATRIX_DIGITAL_RAIN
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
|
|
||||||
# define ENABLE_RGB_MATRIX_SPLASH
|
|
||||||
# define ENABLE_RGB_MATRIX_MULTISPLASH
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_SPLASH
|
|
||||||
# define ENABLE_RGB_MATRIX_SOLID_MULTISPLASH
|
|
||||||
# endif // AVR
|
|
||||||
#endif // RGB_MATRIX_ENABLE
|
|
||||||
|
|
||||||
#ifdef OLED_ENABLE
|
|
||||||
# ifndef OLED_UPDATE_INTERVAL
|
|
||||||
# ifdef OLED_DRIVER_SH1107
|
|
||||||
# define OLED_UPDATE_INTERVAL 75
|
|
||||||
# else
|
|
||||||
# ifdef SPLIT_KEYBOARD
|
|
||||||
# define OLED_UPDATE_INTERVAL 60
|
|
||||||
# else
|
|
||||||
# define OLED_UPDATE_INTERVAL 15
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# define OLED_DISABLE_TIMEOUT
|
|
||||||
# ifdef OLED_FONT_H
|
|
||||||
# undef OLED_FONT_H
|
|
||||||
# endif
|
|
||||||
# define OLED_FONT_H "oled/drashna_font.h"
|
|
||||||
# define OLED_FONT_END 255
|
|
||||||
// # define OLED_FONT_5X5
|
|
||||||
// # define OLED_FONT_AZTECH
|
|
||||||
// # define OLED_FONT_BMPLAIN
|
|
||||||
// # define OLED_FONT_CRACKERS
|
|
||||||
# define OLED_FONT_DEAD_MEAL
|
|
||||||
// # define OLED_FONT_EIN
|
|
||||||
// # define OLED_FONT_HISKYF21
|
|
||||||
// # define OLED_FONT_SQUASH
|
|
||||||
// # define OLED_FONT_ZXPIX
|
|
||||||
// # define OLED_FONT_SUPER_DIGG
|
|
||||||
|
|
||||||
// # define OLED_LOGO_BEBOP
|
|
||||||
// # define OLED_LOGO_CORNE
|
|
||||||
// # define OLED_LOGO_GMK_BAD
|
|
||||||
// # define OLED_LOGO_GOTHAM
|
|
||||||
// # define OLED_LOGO_HUE_MANITEE
|
|
||||||
// # define OLED_LOGO_LOOSE
|
|
||||||
# define OLED_LOGO_SCIFI
|
|
||||||
// # define OLED_LOGO_SETS3N
|
|
||||||
// # define OLED_LOGO_SKEEB
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// #define WPM_ESTIMATED_WORD_SIZE 5
|
// #define WPM_ESTIMATED_WORD_SIZE 5
|
||||||
#define WPM_ALLOW_COUNT_REGRESSION
|
#define WPM_ALLOW_COUNT_REGRESSION
|
||||||
// #define WPM_UNFILTERED
|
// #define WPM_UNFILTERED
|
||||||
|
@ -237,11 +80,18 @@
|
||||||
# define ONESHOT_TIMEOUT 3000
|
# define ONESHOT_TIMEOUT 3000
|
||||||
#endif // !ONESHOT_TIMEOUT
|
#endif // !ONESHOT_TIMEOUT
|
||||||
|
|
||||||
|
#if defined(PER_KEY_TAPPING)
|
||||||
# define IGNORE_MOD_TAP_INTERRUPT_PER_KEY
|
# define IGNORE_MOD_TAP_INTERRUPT_PER_KEY
|
||||||
# define PERMISSIVE_HOLD_PER_KEY
|
# define PERMISSIVE_HOLD_PER_KEY
|
||||||
# define TAPPING_FORCE_HOLD_PER_KEY
|
# define TAPPING_FORCE_HOLD_PER_KEY
|
||||||
|
# define HOLD_ON_OTHER_KEY
|
||||||
# define RETRO_TAPPING_PER_KEY
|
# define RETRO_TAPPING_PER_KEY
|
||||||
|
# define HOLD_ON_OTHER_KEY_PRESS_PER_KEY
|
||||||
# define TAPPING_TERM_PER_KEY
|
# define TAPPING_TERM_PER_KEY
|
||||||
|
#else
|
||||||
|
# define IGNORE_MOD_TAP_INTERRUPT
|
||||||
|
# undef PERMISSIVE_HOLD
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef TAPPING_TOGGLE
|
#ifndef TAPPING_TOGGLE
|
||||||
# define TAPPING_TOGGLE 1
|
# define TAPPING_TOGGLE 1
|
||||||
|
@ -276,41 +126,7 @@
|
||||||
# define C15 PAL_LINE(GPIOC, 15)
|
# define C15 PAL_LINE(GPIOC, 15)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef OLED_DRIVER_SH1107
|
|
||||||
# define OLED_DISPLAY_CUSTOM
|
|
||||||
# define OLED_IC_SH1107 2
|
|
||||||
# define OLED_DISPLAY_128X128
|
|
||||||
# define OLED_DISPLAY_WIDTH 128
|
|
||||||
# define OLED_DISPLAY_HEIGHT 128
|
|
||||||
# define OLED_MATRIX_SIZE (OLED_DISPLAY_HEIGHT / 8 * OLED_DISPLAY_WIDTH)
|
|
||||||
# define OLED_BLOCK_TYPE uint32_t
|
|
||||||
# define OLED_SOURCE_MAP \
|
|
||||||
{ 0, 8, 16, 24, 32, 40, 48, 56 }
|
|
||||||
# define OLED_TARGET_MAP \
|
|
||||||
{ 56, 48, 40, 32, 24, 16, 8, 0 }
|
|
||||||
# define OLED_BLOCK_COUNT (sizeof(OLED_BLOCK_TYPE) * 8)
|
|
||||||
# define OLED_BLOCK_SIZE (OLED_MATRIX_SIZE / OLED_BLOCK_COUNT)
|
|
||||||
# define OLED_COM_PINS COM_PINS_ALT
|
|
||||||
# define OLED_IC OLED_IC_SH1107
|
|
||||||
# ifndef OLED_BRIGHTNESS
|
|
||||||
# define OLED_BRIGHTNESS 50
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef USE_I2CV1
|
|
||||||
# define I2C1_CLOCK_SPEED 400000
|
|
||||||
# define I2C1_DUTY_CYCLE FAST_DUTY_CYCLE_2
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define ENABLE_COMPILE_KEYCODE
|
#define ENABLE_COMPILE_KEYCODE
|
||||||
|
|
||||||
#define BOTH_SHIFTS_TURNS_ON_CAPS_WORD
|
#define BOTH_SHIFTS_TURNS_ON_CAPS_WORD
|
||||||
|
|
||||||
#ifndef SECURE_UNLOCK_SEQUENCE
|
|
||||||
# define SECURE_UNLOCK_SEQUENCE \
|
|
||||||
{ \
|
|
||||||
{2, 1}, {2, 2}, {2, 3}, { \
|
|
||||||
2, 4 \
|
|
||||||
} \
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -76,49 +76,110 @@ void tap_code16_nomods(uint16_t kc) {
|
||||||
set_mods(temp_mod);
|
set_mods(temp_mod);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
#ifdef I2C_SCANNER_ENABLE
|
||||||
* @brief Run shutdown routine and soft reboot firmware.
|
# include "i2c_master.h"
|
||||||
*
|
# include "debug.h"
|
||||||
*/
|
|
||||||
|
|
||||||
#ifdef HAPTIC_ENABLE
|
# ifndef I2C_SCANNER_TIMEOUT
|
||||||
# include "haptic.h"
|
# define I2C_SCANNER_TIMEOUT 50
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
#ifdef AUDIO_ENABLE
|
i2c_status_t i2c_start_bodge(uint8_t address, uint16_t timeout) {
|
||||||
# ifndef GOODBYE_SONG
|
i2c_start(address);
|
||||||
# define GOODBYE_SONG SONG(GOODBYE_SOUND)
|
|
||||||
# endif
|
// except on ChibiOS where the only way is do do "something"
|
||||||
float reset_song[][2] = GOODBYE_SONG;
|
uint8_t data = 0;
|
||||||
|
return i2c_readReg(address, 0, &data, sizeof(data), I2C_SCANNER_TIMEOUT);
|
||||||
|
}
|
||||||
|
|
||||||
|
# define i2c_start i2c_start_bodge
|
||||||
|
|
||||||
|
void do_scan(void) {
|
||||||
|
uint8_t nDevices = 0;
|
||||||
|
|
||||||
|
dprintf("Scanning...\n");
|
||||||
|
|
||||||
|
for (uint8_t address = 1; address < 127; address++) {
|
||||||
|
// The i2c_scanner uses the return value of
|
||||||
|
// i2c_start to see if a device did acknowledge to the address.
|
||||||
|
i2c_status_t error = i2c_start(address << 1, I2C_SCANNER_TIMEOUT);
|
||||||
|
if (error == I2C_STATUS_SUCCESS) {
|
||||||
|
i2c_stop();
|
||||||
|
xprintf(" I2C device found at address 0x%02X\n", I2C_SCANNER_TIMEOUT);
|
||||||
|
nDevices++;
|
||||||
|
} else {
|
||||||
|
// dprintf(" Unknown error (%u) at address 0x%02X\n", error, address);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nDevices == 0)
|
||||||
|
xprintf("No I2C devices found\n");
|
||||||
|
else
|
||||||
|
xprintf("done\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t scan_timer = 0;
|
||||||
|
|
||||||
|
void matrix_scan_i2c(void) {
|
||||||
|
if (timer_elapsed(scan_timer) > 5000) {
|
||||||
|
do_scan();
|
||||||
|
scan_timer = timer_read();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void keyboard_post_init_i2c(void) {
|
||||||
|
i2c_init();
|
||||||
|
scan_timer = timer_read();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void software_reset(void) {
|
void bootmagic_lite(void) {
|
||||||
clear_keyboard();
|
bool perform_reset = false;
|
||||||
#if defined(MIDI_ENABLE) && defined(MIDI_BASIC)
|
// We need multiple scans because debouncing can't be turned off.
|
||||||
process_midi_all_notes_off();
|
matrix_scan();
|
||||||
#endif
|
#if defined(DEBOUNCE) && DEBOUNCE > 0
|
||||||
#ifdef AUDIO_ENABLE
|
wait_ms(DEBOUNCE * 2);
|
||||||
# ifndef NO_MUSIC_MODE
|
|
||||||
music_all_notes_off();
|
|
||||||
# endif
|
|
||||||
uint16_t timer_start = timer_read();
|
|
||||||
PLAY_SONG(reset_song);
|
|
||||||
shutdown_user();
|
|
||||||
while (timer_elapsed(timer_start) < 250) wait_ms(1);
|
|
||||||
stop_all_notes();
|
|
||||||
#else
|
#else
|
||||||
shutdown_user();
|
wait_ms(30);
|
||||||
wait_ms(250);
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAPTIC_ENABLE
|
matrix_scan();
|
||||||
haptic_shutdown();
|
|
||||||
|
// If the configured key (commonly Esc) is held down on power up,
|
||||||
|
// reset the EEPROM valid state and jump to bootloader.
|
||||||
|
// This isn't very generalized, but we need something that doesn't
|
||||||
|
// rely on user's keymaps in firmware or EEPROM.
|
||||||
|
uint8_t row = BOOTMAGIC_LITE_ROW, col = BOOTMAGIC_LITE_COLUMN;
|
||||||
|
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN)
|
||||||
|
uint8_t row_e = BOOTMAGIC_LITE_EEPROM_ROW, col_e = BOOTMAGIC_LITE_EEPROM_COLUMN;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(PROTOCOL_LUFA)
|
#if defined(SPLIT_KEYBOARD) && defined(BOOTMAGIC_LITE_ROW_RIGHT) && defined(BOOTMAGIC_LITE_COLUMN_RIGHT)
|
||||||
wdt_enable(WDTO_250MS);
|
if (!is_keyboard_left()) {
|
||||||
#elif defined(PROTOCOL_CHIBIOS)
|
row = BOOTMAGIC_LITE_ROW_RIGHT;
|
||||||
# if defined(MCU_STM32) || defined(MCU_KINETIS)
|
col = BOOTMAGIC_LITE_COLUMN_RIGHT;
|
||||||
NVIC_SystemReset();
|
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN) && defined(BOOTMAGIC_LITE_EEPROM_ROW_RIGHT) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT)
|
||||||
# endif
|
row_e = BOOTMAGIC_LITE_EEPROM_ROW_RIGHT;
|
||||||
|
col_e = BOOTMAGIC_LITE_EEPROM_COLUMN_RIGHT;
|
||||||
# endif
|
# endif
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(BOOTMAGIC_LITE_EEPROM_ROW) && defined(BOOTMAGIC_LITE_EEPROM_COLUMN)
|
||||||
|
if (matrix_get_row(row_e) & (1 << col_e)) {
|
||||||
|
eeconfig_disable();
|
||||||
|
perform_reset = true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (matrix_get_row(row) & (1 << col)) {
|
||||||
|
perform_reset = true;
|
||||||
|
}
|
||||||
|
#ifdef STM32F411xE
|
||||||
|
if (!readPin(A0)) {
|
||||||
|
perform_reset = true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (perform_reset) {
|
||||||
|
bootloader_jump();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -79,7 +79,6 @@ bool mod_key_press_timer(uint16_t code, uint16_t mod_code, bool pressed);
|
||||||
bool mod_key_press(uint16_t code, uint16_t mod_code, bool pressed, uint16_t this_timer);
|
bool mod_key_press(uint16_t code, uint16_t mod_code, bool pressed, uint16_t this_timer);
|
||||||
bool hasAllBitsInMask(uint8_t value, uint8_t mask);
|
bool hasAllBitsInMask(uint8_t value, uint8_t mask);
|
||||||
void tap_code16_nomods(uint16_t kc);
|
void tap_code16_nomods(uint16_t kc);
|
||||||
void software_reset(void);
|
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
typedef union {
|
typedef union {
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
#include "autocorrect_data.h"
|
|
@ -6,9 +6,6 @@
|
||||||
#ifdef AUTOCORRECTION_ENABLE
|
#ifdef AUTOCORRECTION_ENABLE
|
||||||
# include "autocorrection/autocorrection.h"
|
# include "autocorrection/autocorrection.h"
|
||||||
#endif
|
#endif
|
||||||
#ifdef __AVR__
|
|
||||||
# include <avr/wdt.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint16_t copy_paste_timer;
|
uint16_t copy_paste_timer;
|
||||||
bool host_driver_disabled = false;
|
bool host_driver_disabled = false;
|
||||||
|
@ -49,7 +46,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||||
#endif
|
#endif
|
||||||
// If console is enabled, it will print the matrix position and status of each key pressed
|
// If console is enabled, it will print the matrix position and status of each key pressed
|
||||||
#ifdef KEYLOGGER_ENABLE
|
#ifdef KEYLOGGER_ENABLE
|
||||||
uprintf("KL: kc: 0x%04X, col: %2u, row: %2u, pressed: %b, time: %5u, int: %b, count: %u\n", keycode, record->event.key.col, record->event.key.row, record->event.pressed, record->event.time, record->tap.interrupted, record->tap.count);
|
uprintf("KL: kc: 0x%04X, col: %2u, row: %2u, pressed: %1d, time: %5u, int: %1d, count: %u\n", keycode, record->event.key.col, record->event.key.row, record->event.pressed, record->event.time, record->tap.interrupted, record->tap.count);
|
||||||
#endif // KEYLOGGER_ENABLE
|
#endif // KEYLOGGER_ENABLE
|
||||||
#if defined(OLED_ENABLE) && defined(CUSTOM_OLED_DRIVER)
|
#if defined(OLED_ENABLE) && defined(CUSTOM_OLED_DRIVER)
|
||||||
process_record_user_oled(keycode, record);
|
process_record_user_oled(keycode, record);
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
#include "drashna.h"
|
#include "drashna.h"
|
||||||
|
|
||||||
|
#ifdef TAPPING_TERM_PER_KEY
|
||||||
__attribute__((weak)) uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *record) {
|
__attribute__((weak)) uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *record) {
|
||||||
switch (keycode) {
|
switch (keycode) {
|
||||||
case BK_LWER:
|
case BK_LWER:
|
||||||
|
@ -11,7 +12,9 @@ __attribute__((weak)) uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *r
|
||||||
return TAPPING_TERM;
|
return TAPPING_TERM;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // TAPPING_TERM_PER_KEY
|
||||||
|
|
||||||
|
#ifdef PERMISSIVE_HOLD_PER_KEY
|
||||||
__attribute__((weak)) bool get_permissive_hold(uint16_t keycode, keyrecord_t *record) {
|
__attribute__((weak)) bool get_permissive_hold(uint16_t keycode, keyrecord_t *record) {
|
||||||
// Immediately select the hold action when another key is tapped:
|
// Immediately select the hold action when another key is tapped:
|
||||||
// return true;
|
// return true;
|
||||||
|
@ -22,7 +25,9 @@ __attribute__((weak)) bool get_permissive_hold(uint16_t keycode, keyrecord_t *re
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // PERMISSIVE_HOLD_PER_KEY
|
||||||
|
|
||||||
|
#ifdef HOLD_ON_OTHER_KEY_PRESS_PER_KEY
|
||||||
__attribute__((weak)) bool get_hold_on_other_key_press(uint16_t keycode, keyrecord_t *record) {
|
__attribute__((weak)) bool get_hold_on_other_key_press(uint16_t keycode, keyrecord_t *record) {
|
||||||
// Immediately select the hold action when another key is pressed.
|
// Immediately select the hold action when another key is pressed.
|
||||||
// return true;
|
// return true;
|
||||||
|
@ -32,10 +37,12 @@ __attribute__((weak)) bool get_hold_on_other_key_press(uint16_t keycode, keyreco
|
||||||
// case QK_LAYER_TAP ... QK_LAYER_TAP_MAX:
|
// case QK_LAYER_TAP ... QK_LAYER_TAP_MAX:
|
||||||
// return true;
|
// return true;
|
||||||
default:
|
default:
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // HOLD_ON_OTHER_KEY_PRESS_PER_KEY
|
||||||
|
|
||||||
|
#ifdef IGNORE_MOD_TAP_INTERRUPT_PER_KEY
|
||||||
__attribute__((weak)) bool get_ignore_mod_tap_interrupt(uint16_t keycode, keyrecord_t *record) {
|
__attribute__((weak)) bool get_ignore_mod_tap_interrupt(uint16_t keycode, keyrecord_t *record) {
|
||||||
// Do not force the mod-tap key press to be handled as a modifier
|
// Do not force the mod-tap key press to be handled as a modifier
|
||||||
// if any other key was pressed while the mod-tap key is held down.
|
// if any other key was pressed while the mod-tap key is held down.
|
||||||
|
@ -48,17 +55,22 @@ __attribute__((weak)) bool get_ignore_mod_tap_interrupt(uint16_t keycode, keyrec
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // IGNORE_MOD_TAP_INTERRUPT_PER_KEY
|
||||||
|
|
||||||
|
#ifdef TAPPING_FORCE_HOLD_PER_KEY
|
||||||
__attribute__((weak)) bool get_tapping_force_hold(uint16_t keycode, keyrecord_t *record) {
|
__attribute__((weak)) bool get_tapping_force_hold(uint16_t keycode, keyrecord_t *record) {
|
||||||
switch (keycode) {
|
switch (keycode) {
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // TAPPING_FORCE_HOLD_PER_KEY
|
||||||
|
|
||||||
|
#ifdef RETRO_TAPPING_PER_KEY
|
||||||
__attribute__((weak)) bool get_retro_tapping(uint16_t keycode, keyrecord_t *record) {
|
__attribute__((weak)) bool get_retro_tapping(uint16_t keycode, keyrecord_t *record) {
|
||||||
switch (keycode) {
|
switch (keycode) {
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // RETRO_TAPPING_PER_KEY
|
||||||
|
|
|
@ -142,7 +142,7 @@ DEFINE_UNICODE_LUT_TRANSLATOR(unicode_lut_translator_super,
|
||||||
0x2071, // i
|
0x2071, // i
|
||||||
0x02B2, // j
|
0x02B2, // j
|
||||||
0x1D4F, // k
|
0x1D4F, // k
|
||||||
0x1D4F, // l
|
0x02E1, // l
|
||||||
0x1D50, // m
|
0x1D50, // m
|
||||||
0x207F, // n
|
0x207F, // n
|
||||||
0x1D52, // o
|
0x1D52, // o
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
// Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#ifndef OLED_UPDATE_INTERVAL
|
||||||
|
# ifdef OLED_DRIVER_SH1107
|
||||||
|
# define OLED_UPDATE_INTERVAL 75
|
||||||
|
# else
|
||||||
|
# ifdef SPLIT_KEYBOARD
|
||||||
|
# define OLED_UPDATE_INTERVAL 60
|
||||||
|
# else
|
||||||
|
# define OLED_UPDATE_INTERVAL 15
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#define OLED_DISABLE_TIMEOUT
|
||||||
|
#ifdef OLED_FONT_H
|
||||||
|
# undef OLED_FONT_H
|
||||||
|
#endif
|
||||||
|
#define OLED_FONT_H "oled/drashna_font.h"
|
||||||
|
#define OLED_FONT_END 255
|
||||||
|
// # define OLED_FONT_5X5
|
||||||
|
// # define OLED_FONT_AZTECH
|
||||||
|
// # define OLED_FONT_BMPLAIN
|
||||||
|
// # define OLED_FONT_CRACKERS
|
||||||
|
#define OLED_FONT_DEAD_MEAL
|
||||||
|
// # define OLED_FONT_EIN
|
||||||
|
// # define OLED_FONT_HISKYF21
|
||||||
|
// # define OLED_FONT_SQUASH
|
||||||
|
// # define OLED_FONT_ZXPIX
|
||||||
|
// # define OLED_FONT_SUPER_DIGG
|
||||||
|
|
||||||
|
// # define OLED_LOGO_BEBOP
|
||||||
|
// # define OLED_LOGO_CORNE
|
||||||
|
// # define OLED_LOGO_GMK_BAD
|
||||||
|
// # define OLED_LOGO_GOTHAM
|
||||||
|
// # define OLED_LOGO_HUE_MANITEE
|
||||||
|
// # define OLED_LOGO_LOOSE
|
||||||
|
#define OLED_LOGO_SCIFI
|
||||||
|
// # define OLED_LOGO_SETS3N
|
||||||
|
// # define OLED_LOGO_SKEEB
|
||||||
|
|
||||||
|
#ifdef OLED_DRIVER_SH1107
|
||||||
|
# define OLED_DISPLAY_CUSTOM
|
||||||
|
# define OLED_IC_SH1107 2
|
||||||
|
# define OLED_DISPLAY_128X128
|
||||||
|
# define OLED_DISPLAY_WIDTH 128
|
||||||
|
# define OLED_DISPLAY_HEIGHT 128
|
||||||
|
# define OLED_MATRIX_SIZE (OLED_DISPLAY_HEIGHT / 8 * OLED_DISPLAY_WIDTH)
|
||||||
|
# define OLED_BLOCK_TYPE uint32_t
|
||||||
|
# define OLED_SOURCE_MAP \
|
||||||
|
{ 0, 8, 16, 24, 32, 40, 48, 56 }
|
||||||
|
# define OLED_TARGET_MAP \
|
||||||
|
{ 56, 48, 40, 32, 24, 16, 8, 0 }
|
||||||
|
# define OLED_BLOCK_COUNT (sizeof(OLED_BLOCK_TYPE) * 8)
|
||||||
|
# define OLED_BLOCK_SIZE (OLED_MATRIX_SIZE / OLED_BLOCK_COUNT)
|
||||||
|
# define OLED_COM_PINS COM_PINS_ALT
|
||||||
|
# define OLED_IC OLED_IC_SH1107
|
||||||
|
# ifndef OLED_BRIGHTNESS
|
||||||
|
# define OLED_BRIGHTNESS 50
|
||||||
|
# endif
|
||||||
|
#endif
|
|
@ -28,6 +28,8 @@
|
||||||
#endif
|
#endif
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
bool is_oled_enabled = true;
|
||||||
|
|
||||||
extern bool host_driver_disabled;
|
extern bool host_driver_disabled;
|
||||||
|
|
||||||
uint32_t oled_timer = 0;
|
uint32_t oled_timer = 0;
|
||||||
|
@ -850,7 +852,7 @@ void render_status_right(void) {
|
||||||
render_layer_state(1, 2);
|
render_layer_state(1, 2);
|
||||||
render_mod_status(get_mods() | get_oneshot_mods(), 1, 5);
|
render_mod_status(get_mods() | get_oneshot_mods(), 1, 5);
|
||||||
#if !defined(OLED_DISPLAY_VERBOSE) && defined(WPM_ENABLE) && !defined(STM32F303xC)
|
#if !defined(OLED_DISPLAY_VERBOSE) && defined(WPM_ENABLE) && !defined(STM32F303xC)
|
||||||
render_wpm(2);
|
render_wpm(2, 7, 1);
|
||||||
#endif
|
#endif
|
||||||
render_keylock_status(host_keyboard_led_state(), 1, 6);
|
render_keylock_status(host_keyboard_led_state(), 1, 6);
|
||||||
}
|
}
|
||||||
|
@ -929,9 +931,8 @@ __attribute__((weak)) bool oled_task_keymap(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool oled_task_user(void) {
|
bool oled_task_user(void) {
|
||||||
if (is_keyboard_master()) {
|
|
||||||
#ifndef OLED_DISPLAY_TEST
|
#ifndef OLED_DISPLAY_TEST
|
||||||
if (timer_elapsed32(oled_timer) > 60000) {
|
if (!is_oled_enabled) {
|
||||||
oled_off();
|
oled_off();
|
||||||
return false;
|
return false;
|
||||||
} else
|
} else
|
||||||
|
@ -939,7 +940,6 @@ bool oled_task_user(void) {
|
||||||
{
|
{
|
||||||
oled_on();
|
oled_on();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (!oled_task_keymap()) {
|
if (!oled_task_keymap()) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -990,3 +990,9 @@ bool oled_task_user(void) {
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern bool oled_initialized;
|
||||||
|
|
||||||
|
__attribute__((weak)) void matrix_scan_oled(void) {
|
||||||
|
is_oled_enabled = !(timer_elapsed32(oled_timer) > 60000);
|
||||||
|
}
|
||||||
|
|
|
@ -44,6 +44,8 @@ void render_wpm_graph(uint8_t max_lines_graph, uint8_t vertical_offse
|
||||||
void render_kitty(uint8_t col, uint8_t line);
|
void render_kitty(uint8_t col, uint8_t line);
|
||||||
void render_unicode_mode(uint8_t col, uint8_t line);
|
void render_unicode_mode(uint8_t col, uint8_t line);
|
||||||
void render_rgb_hsv(uint8_t col, uint8_t line);
|
void render_rgb_hsv(uint8_t col, uint8_t line);
|
||||||
|
void render_mouse_mode(uint8_t col, uint8_t line);
|
||||||
|
void matrix_scan_oled(void);
|
||||||
|
|
||||||
void oled_pan_section(bool left, uint16_t y_start, uint16_t y_end, uint16_t x_start, uint16_t x_end);
|
void oled_pan_section(bool left, uint16_t y_start, uint16_t y_end, uint16_t x_start, uint16_t x_end);
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ __attribute__((weak)) report_mouse_t pointing_device_task_keymap(report_mouse_t
|
||||||
}
|
}
|
||||||
|
|
||||||
report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
|
report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
|
||||||
int8_t x = mouse_report.x, y = mouse_report.y;
|
mouse_xy_report_t x = mouse_report.x, y = mouse_report.y;
|
||||||
mouse_report.x = 0;
|
mouse_report.x = 0;
|
||||||
mouse_report.y = 0;
|
mouse_report.y = 0;
|
||||||
|
|
||||||
|
@ -33,8 +33,8 @@ report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
|
||||||
#endif
|
#endif
|
||||||
if (timer_elapsed(mouse_debounce_timer) > TAP_CHECK) {
|
if (timer_elapsed(mouse_debounce_timer) > TAP_CHECK) {
|
||||||
if (enable_acceleration) {
|
if (enable_acceleration) {
|
||||||
x = (x > 0 ? x * x / 16 + x : -x * x / 16 + x);
|
x = (mouse_xy_report_t)(x > 0 ? x * x / 16 + x : -x * x / 16 + x);
|
||||||
y = (y > 0 ? y * y / 16 + y : -y * y / 16 + y);
|
y = (mouse_xy_report_t)(y > 0 ? y * y / 16 + y : -y * y / 16 + y);
|
||||||
}
|
}
|
||||||
mouse_report.x = x;
|
mouse_report.x = x;
|
||||||
mouse_report.y = y;
|
mouse_report.y = y;
|
||||||
|
|
|
@ -113,13 +113,17 @@
|
||||||
# endif
|
# endif
|
||||||
#endif // MOUSEKEY_ENABLE
|
#endif // MOUSEKEY_ENABLE
|
||||||
|
|
||||||
#if !defined(LAYER_STATE_16BIT) && !defined(LAYER_STATE_8BIT) && !defined(LAYER_STATE_32BIT)
|
#define MOUSE_EXTENDED_REPORT
|
||||||
# define LAYER_STATE_16BIT
|
|
||||||
#endif
|
|
||||||
#ifndef DYNAMIC_KEYMAP_LAYER_COUNT
|
|
||||||
# define DYNAMIC_KEYMAP_LAYER_COUNT 11
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef TAPPING_TERM
|
#ifndef TAPPING_TERM
|
||||||
# define TAPPING_TERM 175
|
# define TAPPING_TERM 175
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef SECURE_UNLOCK_SEQUENCE
|
||||||
|
# define SECURE_UNLOCK_SEQUENCE \
|
||||||
|
{ \
|
||||||
|
{2, 1}, {2, 2}, {2, 3}, { \
|
||||||
|
2, 4 \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -0,0 +1,107 @@
|
||||||
|
// Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#define RGB_MATRIX_KEYPRESSES // reacts to keypresses (will slow down matrix scan by a lot)
|
||||||
|
// # define RGB_MATRIX_KEYRELEASES // reacts to keyreleases (not recommened)
|
||||||
|
#define RGB_MATRIX_FRAMEBUFFER_EFFECTS
|
||||||
|
// # define RGB_DISABLE_AFTER_TIMEOUT 0 // number of ticks to wait until disabling effects
|
||||||
|
// # define RGB_DISABLE_WHEN_USB_SUSPENDED // turn off effects when suspended
|
||||||
|
|
||||||
|
#undef ENABLE_RGB_MATRIX_ALPHAS_MODS
|
||||||
|
#undef ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN
|
||||||
|
#undef ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT
|
||||||
|
#undef ENABLE_RGB_MATRIX_BREATHING
|
||||||
|
#undef ENABLE_RGB_MATRIX_BAND_SAT
|
||||||
|
#undef ENABLE_RGB_MATRIX_BAND_VAL
|
||||||
|
#undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
|
||||||
|
#undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
|
||||||
|
#undef ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT
|
||||||
|
#undef ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_ALL
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_UP_DOWN
|
||||||
|
#undef ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_PINWHEEL
|
||||||
|
#undef ENABLE_RGB_MATRIX_CYCLE_SPIRAL
|
||||||
|
#undef ENABLE_RGB_MATRIX_DUAL_BEACON
|
||||||
|
#undef ENABLE_RGB_MATRIX_RAINBOW_BEACON
|
||||||
|
#undef ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS
|
||||||
|
#undef ENABLE_RGB_MATRIX_RAINDROPS
|
||||||
|
#undef ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
|
||||||
|
#undef ENABLE_RGB_MATRIX_HUE_BREATHING
|
||||||
|
#undef ENABLE_RGB_MATRIX_HUE_PENDULUM
|
||||||
|
#undef ENABLE_RGB_MATRIX_HUE_WAVE
|
||||||
|
#undef ENABLE_RGB_MATRIX_PIXEL_RAIN
|
||||||
|
#undef ENABLE_RGB_MATRIX_PIXEL_FLOW
|
||||||
|
#undef ENABLE_RGB_MATRIX_PIXEL_FRACTAL
|
||||||
|
// enabled only if RGB_MATRIX_FRAMEBUFFER_EFFECTS is defined
|
||||||
|
#undef ENABLE_RGB_MATRIX_TYPING_HEATMAP
|
||||||
|
#undef ENABLE_RGB_MATRIX_DIGITAL_RAIN
|
||||||
|
// enabled only of RGB_MATRIX_KEYPRESSES or RGB_MATRIX_KEYRELEASES is defined
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
|
||||||
|
#undef ENABLE_RGB_MATRIX_SPLASH
|
||||||
|
#undef ENABLE_RGB_MATRIX_MULTISPLASH
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_SPLASH
|
||||||
|
#undef ENABLE_RGB_MATRIX_SOLID_MULTISPLASH
|
||||||
|
|
||||||
|
#define ENABLE_RGB_MATRIX_TYPING_HEATMAP
|
||||||
|
#define ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
|
||||||
|
#if !defined(SPLIT_KEYBOARD) && !defined(KEYBOARD_ergodox_ez) && !defined(KEYBOARD_moonlander)
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_OUT_IN
|
||||||
|
#endif
|
||||||
|
#if defined(__arm__) || defined(__AVR_AT90USB1286__) || defined(KEYBOARD_launchpad)
|
||||||
|
// RGB Matrix Animation modes. Explicitly enabled
|
||||||
|
// For full list of effects, see:
|
||||||
|
// https://docs.qmk.fm/#/feature_rgb_matrix?id=rgb-matrix-effects
|
||||||
|
# define ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN
|
||||||
|
# define ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT
|
||||||
|
# define ENABLE_RGB_MATRIX_BREATHING
|
||||||
|
# define ENABLE_RGB_MATRIX_BAND_SAT
|
||||||
|
# define ENABLE_RGB_MATRIX_BAND_VAL
|
||||||
|
# define ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
|
||||||
|
# define ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
|
||||||
|
# define ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT
|
||||||
|
# define ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_ALL
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_UP_DOWN
|
||||||
|
# define ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_OUT_IN
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_PINWHEEL
|
||||||
|
# define ENABLE_RGB_MATRIX_CYCLE_SPIRAL
|
||||||
|
# define ENABLE_RGB_MATRIX_DUAL_BEACON
|
||||||
|
# define ENABLE_RGB_MATRIX_RAINBOW_BEACON
|
||||||
|
# define ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS
|
||||||
|
# define ENABLE_RGB_MATRIX_RAINDROPS
|
||||||
|
# define ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
|
||||||
|
# define ENABLE_RGB_MATRIX_HUE_BREATHING
|
||||||
|
# define ENABLE_RGB_MATRIX_HUE_PENDULUM
|
||||||
|
# define ENABLE_RGB_MATRIX_HUE_WAVE
|
||||||
|
# define ENABLE_RGB_MATRIX_PIXEL_RAIN
|
||||||
|
# define ENABLE_RGB_MATRIX_PIXEL_FLOW
|
||||||
|
# define ENABLE_RGB_MATRIX_PIXEL_FRACTAL
|
||||||
|
# define ENABLE_RGB_MATRIX_DIGITAL_RAIN
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
|
||||||
|
# define ENABLE_RGB_MATRIX_SPLASH
|
||||||
|
# define ENABLE_RGB_MATRIX_MULTISPLASH
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_SPLASH
|
||||||
|
# define ENABLE_RGB_MATRIX_SOLID_MULTISPLASH
|
||||||
|
#endif // AVR
|
|
@ -0,0 +1,8 @@
|
||||||
|
// Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
# define RGBLIGHT_SLEEP
|
||||||
|
# define RGBLIGHT_EFFECT_TWINKLE_LIFE 250
|
||||||
|
# define RGBLIGHT_EFFECT_TWINKLE_PROBABILITY 1 / 24
|
|
@ -36,6 +36,10 @@ ifeq ($(strip $(PROTOCOL)), VUSB)
|
||||||
NKRO_ENABLE := no
|
NKRO_ENABLE := no
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(strip $(PER_KEY_TAPPING)), yes)
|
||||||
|
OPT_DEFS += -DPER_KEY_TAPPING
|
||||||
|
endif
|
||||||
|
|
||||||
CUSTOM_UNICODE_ENABLE ?= yes
|
CUSTOM_UNICODE_ENABLE ?= yes
|
||||||
ifeq ($(strip $(CUSTOM_UNICODE_ENABLE)), yes)
|
ifeq ($(strip $(CUSTOM_UNICODE_ENABLE)), yes)
|
||||||
UNICODE_ENABLE := no
|
UNICODE_ENABLE := no
|
||||||
|
@ -83,6 +87,11 @@ ifdef CONSOLE_ENABLE
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(strip $(I2C_SCANNER_ENABLE)), yes)
|
||||||
|
OPT_DEFS += -DI2C_SCANNER_ENABLE
|
||||||
|
CONSOLE_ENABLE := yes
|
||||||
|
endif
|
||||||
|
|
||||||
CUSTOM_OLED_DRIVER ?= yes
|
CUSTOM_OLED_DRIVER ?= yes
|
||||||
ifeq ($(strip $(OLED_ENABLE)), yes)
|
ifeq ($(strip $(OLED_ENABLE)), yes)
|
||||||
ifeq ($(strip $(OLED_DRIVER)), custom)
|
ifeq ($(strip $(OLED_DRIVER)), custom)
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
// Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
// # define SPLIT_TRANSPORT_MIRROR
|
||||||
|
#define SPLIT_LAYER_STATE_ENABLE
|
||||||
|
#define SPLIT_LED_STATE_ENABLE
|
||||||
|
#define SPLIT_MODS_ENABLE
|
||||||
|
#ifdef WPM_ENABLE
|
||||||
|
# define SPLIT_WPM_ENABLE
|
||||||
|
#endif
|
||||||
|
#ifdef OLED_ENABLE
|
||||||
|
# undef SPLIT_OLED_ENABLE
|
||||||
|
#endif
|
||||||
|
#if defined(__AVR__) && !defined(SELECT_SOFT_SERIAL_SPEED)
|
||||||
|
# define SELECT_SOFT_SERIAL_SPEED 1
|
||||||
|
#endif
|
||||||
|
#ifdef CUSTOM_SPLIT_TRANSPORT_SYNC
|
||||||
|
# define SPLIT_TRANSACTION_IDS_USER RPC_ID_USER_STATE_SYNC, RPC_ID_USER_KEYMAP_SYNC, RPC_ID_USER_CONFIG_SYNC, RPC_ID_USER_WATCHDOG_SYNC, RPC_ID_USER_KEYLOG_STR
|
||||||
|
#endif
|
|
@ -4,9 +4,6 @@
|
||||||
#include "transport_sync.h"
|
#include "transport_sync.h"
|
||||||
#include "transactions.h"
|
#include "transactions.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#ifdef __AVR__
|
|
||||||
# include <avr/wdt.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef UNICODE_COMMON_ENABLE
|
#ifdef UNICODE_COMMON_ENABLE
|
||||||
# include "process_unicode_common.h"
|
# include "process_unicode_common.h"
|
||||||
|
@ -18,6 +15,9 @@ extern unicode_config_t unicode_config;
|
||||||
extern audio_config_t audio_config;
|
extern audio_config_t audio_config;
|
||||||
extern bool delayed_tasks_run;
|
extern bool delayed_tasks_run;
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(OLED_ENABLE) && !defined(SPLIT_OLED_ENABLE) && defined(CUSTOM_OLED_DRIVER)
|
||||||
|
extern bool is_oled_enabled;
|
||||||
|
#endif
|
||||||
#if defined(POINTING_DEVICE_ENABLE) && defined(KEYBOARD_handwired_tractyl_manuform)
|
#if defined(POINTING_DEVICE_ENABLE) && defined(KEYBOARD_handwired_tractyl_manuform)
|
||||||
extern bool tap_toggling;
|
extern bool tap_toggling;
|
||||||
#endif
|
#endif
|
||||||
|
@ -95,6 +95,9 @@ void user_transport_update(void) {
|
||||||
user_state.audio_enable = is_audio_on();
|
user_state.audio_enable = is_audio_on();
|
||||||
user_state.audio_clicky_enable = is_clicky_on();
|
user_state.audio_clicky_enable = is_clicky_on();
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(OLED_ENABLE) && !defined(SPLIT_OLED_ENABLE) && defined(CUSTOM_OLED_DRIVER)
|
||||||
|
user_state.is_oled_enabled = is_oled_enabled;
|
||||||
|
#endif
|
||||||
#if defined(CUSTOM_POINTING_DEVICE)
|
#if defined(CUSTOM_POINTING_DEVICE)
|
||||||
user_state.tap_toggling = tap_toggling;
|
user_state.tap_toggling = tap_toggling;
|
||||||
#endif
|
#endif
|
||||||
|
@ -116,6 +119,9 @@ void user_transport_update(void) {
|
||||||
unicode_config.input_mode = user_state.unicode_mode;
|
unicode_config.input_mode = user_state.unicode_mode;
|
||||||
typing_mode = user_state.unicode_typing_mode;
|
typing_mode = user_state.unicode_typing_mode;
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(OLED_ENABLE) && !defined(SPLIT_OLED_ENABLE) && defined(CUSTOM_OLED_DRIVER)
|
||||||
|
is_oled_enabled = user_state.is_oled_enabled;
|
||||||
|
#endif
|
||||||
#if defined(CUSTOM_POINTING_DEVICE)
|
#if defined(CUSTOM_POINTING_DEVICE)
|
||||||
tap_toggling = user_state.tap_toggling;
|
tap_toggling = user_state.tap_toggling;
|
||||||
#endif
|
#endif
|
||||||
|
@ -226,7 +232,7 @@ void user_transport_sync(void) {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (timer_elapsed32(watchdog_timer) > 3500) {
|
if (timer_elapsed32(watchdog_timer) > 3500) {
|
||||||
software_reset();
|
mcu_reset();
|
||||||
while (1) {
|
while (1) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ typedef union {
|
||||||
bool swap_hands :1;
|
bool swap_hands :1;
|
||||||
bool host_driver_disabled :1;
|
bool host_driver_disabled :1;
|
||||||
uint8_t unicode_typing_mode :3;
|
uint8_t unicode_typing_mode :3;
|
||||||
|
bool is_oled_enabled :1;
|
||||||
};
|
};
|
||||||
} user_runtime_config_t;
|
} user_runtime_config_t;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue