341 lines
11 KiB
C
341 lines
11 KiB
C
#pragma once
|
||
|
||
#ifndef CUSTOM_SAFE_RANGE
|
||
#error "You must specify variable CUSTOM_SAFE_RANGE for lang_shift extension."
|
||
#endif
|
||
|
||
enum lang_shift_keycodes {
|
||
LANG_SHIFT_START = CUSTOM_SAFE_RANGE,
|
||
|
||
// Кейкоды, на основе которых реализуются кейкоды ниже, пользователю их лучше не использовать.
|
||
#include "private_keycodes.h"
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Английские символы */
|
||
EN_GRV, /* ` */
|
||
EN_TILD, /* ~ */
|
||
EN_1, /* 1 */
|
||
EN_EXCL, /* ! */
|
||
EN_2, /* 2 */
|
||
EN_AT, /* @ */
|
||
EN_3, /* 3 */
|
||
EN_HASH, /* # */
|
||
EN_4, /* 4 */
|
||
EN_DLR, /* $ */
|
||
EN_5, /* 5 */
|
||
EN_PERC, /* % */
|
||
EN_6, /* 6 */
|
||
EN_CIRC, /* ^ */
|
||
EN_7, /* 7 */
|
||
EN_AMPR, /* & */
|
||
EN_8, /* 8 */
|
||
EN_ASTR, /* * */
|
||
EN_9, /* 9 */
|
||
EN_LPRN, /* ( */
|
||
EN_0, /* 0 */
|
||
EN_RPRN, /* ) */
|
||
EN_MINS, /* - */
|
||
EN_UNDS, /* _ */
|
||
EN_EQL, /* = */
|
||
EN_PLUS, /* + */
|
||
|
||
EN_Q, /* q */
|
||
EN_S_Q, /* Q */
|
||
EN_W, /* w */
|
||
EN_S_W, /* W */
|
||
EN_E, /* e */
|
||
EN_S_E, /* E */
|
||
EN_R, /* r */
|
||
EN_S_R, /* R */
|
||
EN_T, /* t */
|
||
EN_S_T, /* T */
|
||
EN_Y, /* y */
|
||
EN_S_Y, /* Y */
|
||
EN_U, /* u */
|
||
EN_S_U, /* U */
|
||
EN_I, /* i */
|
||
EN_S_I, /* I */
|
||
EN_O, /* o */
|
||
EN_S_O, /* O */
|
||
EN_P, /* p */
|
||
EN_S_P, /* P */
|
||
EN_LBRC, /* [ */
|
||
EN_LCBR, /* { */
|
||
EN_RBRC, /* ] */
|
||
EN_RCBR, /* } */
|
||
|
||
EN_A, /* a */
|
||
EN_S_A, /* A */
|
||
EN_S, /* s */
|
||
EN_S_S, /* S */
|
||
EN_D, /* d */
|
||
EN_S_D, /* D */
|
||
EN_F, /* f */
|
||
EN_S_F, /* F */
|
||
EN_G, /* g */
|
||
EN_S_G, /* G */
|
||
EN_H, /* h */
|
||
EN_S_H, /* H */
|
||
EN_J, /* j */
|
||
EN_S_J, /* J */
|
||
EN_K, /* k */
|
||
EN_S_K, /* K */
|
||
EN_L, /* l */
|
||
EN_S_L, /* L */
|
||
EN_SCLN, /* ; */
|
||
EN_COLN, /* : */
|
||
EN_QUOT, /* ' */
|
||
EN_DQUO, /* " */
|
||
EN_BSLS, /* \ */
|
||
EN_PIPE, /* | */
|
||
|
||
EN_Z, /* z */
|
||
EN_S_Z, /* Z */
|
||
EN_X, /* x */
|
||
EN_S_X, /* X */
|
||
EN_C, /* c */
|
||
EN_S_C, /* C */
|
||
EN_V, /* v */
|
||
EN_S_V, /* V */
|
||
EN_B, /* b */
|
||
EN_S_B, /* B */
|
||
EN_N, /* n */
|
||
EN_S_N, /* N */
|
||
EN_M, /* m */
|
||
EN_S_M, /* M */
|
||
EN_COMM, /* , */
|
||
EN_LT, /* < */
|
||
EN_DOT, /* . */
|
||
EN_GT, /* > */
|
||
EN_SLSH, /* / */
|
||
EN_QUES, /* ? */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Русские символы */
|
||
RU_JO, /* ё */
|
||
RU_S_JO, /* Ё */
|
||
RU_1, /* 1 */
|
||
RU_EXCL, /* ! */
|
||
RU_2, /* 2 */
|
||
RU_DQUO, /* " */
|
||
RU_3, /* 3 */
|
||
RU_NUME, /* № */
|
||
RU_4, /* 4 */
|
||
RU_SCLN, /* ; */
|
||
RU_5, /* 5 */
|
||
RU_PERC, /* % */
|
||
RU_6, /* 6 */
|
||
RU_COLN, /* : */
|
||
RU_7, /* 7 */
|
||
RU_QUES, /* ? */
|
||
RU_8, /* 8 */
|
||
RU_ASTR, /* * */
|
||
RU_9, /* 9 */
|
||
RU_LPRN, /* ( */
|
||
RU_0, /* 0 */
|
||
RU_RPRN, /* ) */
|
||
RU_MINS, /* - */
|
||
RU_UNDS, /* _ */
|
||
RU_EQL, /* = */
|
||
RU_PLUS, /* + */
|
||
|
||
RU_J, /* й */
|
||
RU_S_J, /* Й */
|
||
RU_TS, /* ц */
|
||
RU_S_TS, /* Ц */
|
||
RU_U, /* у */
|
||
RU_S_U, /* У */
|
||
RU_K, /* к */
|
||
RU_S_K, /* К */
|
||
RU_JE, /* е */
|
||
RU_S_JE, /* Е */
|
||
RU_N, /* н */
|
||
RU_S_N, /* Н */
|
||
RU_G, /* г */
|
||
RU_S_G, /* Г */
|
||
RU_SH, /* ш */
|
||
RU_S_SH, /* Ш */
|
||
RU_SC, /* щ */
|
||
RU_S_SC, /* Щ */
|
||
RU_Z, /* з */
|
||
RU_S_Z, /* З */
|
||
RU_H, /* х */
|
||
RU_S_H, /* Х */
|
||
RU_HD, /* ъ */
|
||
RU_S_HD, /* Ъ */
|
||
|
||
RU_F, /* ф */
|
||
RU_S_F, /* Ф */
|
||
RU_Y, /* ы */
|
||
RU_S_Y, /* Ы */
|
||
RU_V, /* в */
|
||
RU_S_V, /* В */
|
||
RU_A, /* а */
|
||
RU_S_A, /* А */
|
||
RU_P, /* п */
|
||
RU_S_P, /* п */
|
||
RU_R, /* р */
|
||
RU_S_R, /* Р */
|
||
RU_O, /* о */
|
||
RU_S_O, /* О */
|
||
RU_L, /* л */
|
||
RU_S_L, /* Л */
|
||
RU_D, /* д */
|
||
RU_S_D, /* Д */
|
||
RU_ZH, /* ж */
|
||
RU_S_ZH, /* Ж */
|
||
RU_E, /* э */
|
||
RU_S_E, /* Э */
|
||
RU_BSLS, /* \ */
|
||
RU_SLSH, /* / */
|
||
|
||
RU_JA, /* я */
|
||
RU_S_JA, /* Я */
|
||
RU_CH, /* ч */
|
||
RU_S_CH, /* Ч */
|
||
RU_S, /* с */
|
||
RU_S_S, /* С */
|
||
RU_M, /* м */
|
||
RU_S_M, /* М */
|
||
RU_I, /* и */
|
||
RU_S_I, /* И */
|
||
RU_T, /* т */
|
||
RU_S_T, /* Т */
|
||
RU_SF, /* ь */
|
||
RU_S_SF, /* Ь */
|
||
RU_B, /* б */
|
||
RU_S_B, /* Б */
|
||
RU_JU, /* ю */
|
||
RU_S_JU, /* Ю */
|
||
RU_DOT, /* . */
|
||
RU_COMM, /* , */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Символы, нажимаемые независимо от текущего языка. Language-agnostic-keycodes. */
|
||
AG_1, /* 1 */
|
||
AG_2, /* 2 */
|
||
AG_3, /* 3 */
|
||
AG_4, /* 4 */
|
||
AG_5, /* 5 */
|
||
AG_6, /* 6 */
|
||
AG_7, /* 7 */
|
||
AG_8, /* 8 */
|
||
AG_9, /* 9 */
|
||
AG_0, /* 0 */
|
||
AG_EXCL, /* ! */
|
||
AG_PERC, /* % */
|
||
AG_ASTR, /* * */
|
||
AG_LPRN, /* ( */
|
||
AG_RPRN, /* ) */
|
||
AG_MINS, /* - */
|
||
AG_UNDS, /* _ */
|
||
AG_EQL, /* = */
|
||
AG_PLUS, /* + */
|
||
AG_SCLN, /* ; */
|
||
AG_COLN, /* : */
|
||
AG_DQUO, /* " */
|
||
AG_BSLS, /* \ */
|
||
AG_COMM, /* , */
|
||
AG_DOT, /* . */
|
||
AG_SLSH, /* / */
|
||
AG_QUES, /* ? */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Кастомные language-agnostic-кейкоды */
|
||
AG_3DOT, /* ... */
|
||
AG_SDOT, /* Space + Dot + Shift to next key */
|
||
AG_CMSP, /* Comma + Space */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Шифты для набора текста. */
|
||
SFT_N, /* Работает как обычный шифт, при её зажатии, шифт зажат. Параллельно переключает на (шифтовый) следующий слой относительно текущего языка (если язык 0, то включает слой 1, если язык 1, то включает слой 3). */
|
||
SFT_N_O, /* Данная клавиша применит шифт и переключение на шифтовый слой только к следующему символу. Неважно, была ли она нажата одновременно со следующей клавишей, или до неё, или вместе с двумя клавишами. Применится только к одной клавише. То есть это как залипающий шифт, если нажимать отдельно от всех клавиш, и как одиночный шифт, если эту клавишу зажимать. Такая клавиша может пригодиться если вы печатаете с большой скоростью и вам сложно выдерживать время удержания шифта, и у вас получается что-то вроде "ПРивет". */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Модификаторы, переключащие текущий слой на 0. Такое нужно чтобы при включённом русском языке были такие же хоткеи с модификаторами, как и на английском языке. */
|
||
CTRL_0, /* Ctrl on 0 layer */
|
||
ALT_0, /* Alt on 0 layer */
|
||
WIN_0, /* Win on 0 layer */
|
||
SHAL_0, /* Shift+Alt on 0 layer */
|
||
CTAL_0, /* Ctrl+Alt on 0 layer */
|
||
CTSH_0, /* Ctrl+Shift on 0 layer */
|
||
MCAS_0, /* Ctrl+Alt+Shift on 0 layer */
|
||
|
||
/* А данные модификаторы помимо включения 0 слоя ещё и переключают язык на английский. Такое разделение нужно, потому что у некоторых смена языка идёт на комбинации с Ctrl, или Shift, и у них может сниматься выделение текста, например. */
|
||
CTRL_EN, /* Ctrl on 0 layer */
|
||
ALT_EN, /* Alt on 0 layer */
|
||
WIN_EN, /* Win on 0 layer */
|
||
SHAL_EN, /* Shift+Alt on 0 layer */
|
||
CTAL_EN, /* Ctrl+Alt on 0 layer */
|
||
CTSH_EN, /* Ctrl+Shift on 0 layer */
|
||
MCAS_EN, /* Ctrl+Alt+Shift on 0 layer */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Кнопки, отвечающие за переключение языка. */
|
||
LA_CHNG, /* Переключает язык и переключает на 2 или 0 слой в зависимости от текущего языка. */
|
||
LA_SYNC, /* Кнопка для синхронизации языков. Её нужно нажимать в случае если язык в системе и язык в клавиатуре различаются. Данная клавиша изменит язык в системе. */
|
||
LA_CAPS, /* Задаёт переключение языка на Caps. */
|
||
LA_ALSH, /* Задаёт переключение языка на Alt + Shift. */
|
||
LA_SHAL, /* Задаёт переключение языка на Shift + Alt. На Win10 это позволяет избежать появления окна переключения языков. */
|
||
LA_CTSH, /* Задаёт переключение языка на Ctrl + Shift. */
|
||
LA_SHCT, /* Задаёт переключение языка на Shift + Ctrl. На Win10 это позволяет избежать появления окна переключения языков. */
|
||
LA_WISP, /* Задаёт переключение языка на Win + Shift. */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* Кейкоды от Buliway. */
|
||
ONCE_SHIFT, /* Зажимает шифт до тех пор, пока не будет нажата любая другая клавиша. Не работает с кастом кейкодами, только стандартные */
|
||
SMART_DOT, /* Отправить агностик точку из lang_shift, нажать пробел, активировать одиночный шифт ONCE_SHIFT */
|
||
COMMA_SPACE, /* Отправить агностик запятую из lang_shift, нажать пробел */
|
||
|
||
/* -------------------------------------------------------------------- */
|
||
/* SAFE_RANGE данной библиотеки. */
|
||
LANG_SHIFT_NEW_SAFE_RANGE,
|
||
#undef CUSTOM_SAFE_RANGE
|
||
#define CUSTOM_SAFE_RANGE LANG_SHIFT_NEW_SAFE_RANGE
|
||
};
|
||
|
||
typedef uint16_t Key;
|
||
#define NONE_KEY (uint16_t)(65535)
|
||
|
||
typedef uint8_t Lang;
|
||
#define NONE_LANG (uint8_t)(255)
|
||
|
||
typedef uint8_t Shift;
|
||
#define NONE_SHIFT (uint8_t)(255)
|
||
|
||
// Способ смены языка
|
||
enum LangChange {
|
||
LANG_CHANGE_CAPS,
|
||
LANG_CHANGE_ALT_SHIFT,
|
||
LANG_CHANGE_SHIFT_ALT,
|
||
LANG_CHANGE_CTRL_SHIFT,
|
||
LANG_CHANGE_SHIFT_CTRL,
|
||
LANG_CHANGE_WIN_SPACE
|
||
};
|
||
|
||
// Переменная, в которой можно менять текущий способ смены языка
|
||
enum LangChange lang_current_change =
|
||
#ifdef LANG_CHANGE_DEFAULT
|
||
LANG_CHANGE_DEFAULT;
|
||
#else
|
||
#error "You must specify default language change method by defining variable LANG_CHANGE_DEFAULT."
|
||
#endif
|
||
|
||
void shift_activate(Shift shift);
|
||
void shift_activate_from_user(Shift shift);
|
||
|
||
void shift_once_use_to_next_key(uint8_t layer);
|
||
|
||
uint8_t lang_get_shift_layer_number(void);
|
||
void lang_synchronize(void);
|
||
void lang_activate(Lang lang);
|
||
void lang_activate_from_user(Lang lang);
|
||
|
||
void lang_shift_press_key(Key key, bool down);
|
||
void lang_shift_tap_key(Key key);
|
||
|
||
bool lang_shift_process_record(Key key, keyrecord_t* record);
|
||
void lang_shift_user_timer(void);
|
||
|
||
// Инклюжу код напрямую, потому что нельзя сделать линковку, ведь код внутри использует кейкоды отсюда, и обязательно нужно это делать через safe_range
|
||
#include "src.c"
|