Clean up Unicode API usage in user keymaps (#21849)

This commit is contained in:
Ryan 2023-08-27 16:51:19 +10:00 committed by GitHub
parent 70e34e491c
commit 66b744b63b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 31 additions and 88 deletions

View file

@ -21,11 +21,6 @@ A layout based on neo2
#endif #endif
#define LEADER_TIMEOUT 300 #define LEADER_TIMEOUT 300
#define TAP_ONCE(code) \
register_code (code); \
unregister_code (code)
// Automatic number generation of important keywords // Automatic number generation of important keywords
enum my_keycodes{ enum my_keycodes{
// Layer numbers follow the neo2 terminology, i.e. base layer = layer 1 // Layer numbers follow the neo2 terminology, i.e. base layer = layer 1
@ -257,22 +252,11 @@ L06 -> <TBD>: UNSPECIFIED
void leader_end_user(void) { void leader_end_user(void) {
if (leader_sequence_one_key(KC_1)) { if (leader_sequence_one_key(KC_1)) {
// ¯\_(ツ)_/¯ send_unicode_string("¯\\_(ツ)_/¯");
unicode_input_start(); register_hex(0xaf); unicode_input_finish();
register_code (KC_RALT); TAP_ONCE (KC_MINS); unregister_code (KC_RALT);
register_code (KC_RSFT); TAP_ONCE (KC_8); unregister_code (KC_RSFT);
unicode_input_start (); register_hex(0x30c4); unicode_input_finish();
register_code (KC_RSFT); TAP_ONCE (KC_9); TAP_ONCE(KC_7); unregister_code (KC_RSFT);
unicode_input_start (); register_hex(0xaf); unicode_input_finish();
} }
if (leader_sequence_one_key(KC_2)) { if (leader_sequence_one_key(KC_2)) {
// 凸(ツ)凸 send_unicode_string("凸(ツ)凸");
unicode_input_start(); register_hex(0x51F8); unicode_input_finish();
register_code (KC_RSFT); TAP_ONCE (KC_8); unregister_code (KC_RSFT);
unicode_input_start (); register_hex(0x30c4); unicode_input_finish();
register_code (KC_RSFT); TAP_ONCE (KC_9); unregister_code (KC_RSFT);
unicode_input_start (); register_hex(0x51F8); unicode_input_finish();
} }
} }

View file

@ -1328,33 +1328,25 @@ void send_degree_symbol(tap_dance_state_t* state, void* user_data) {
switch (state->count) { switch (state->count) {
case 4: case 4:
// ℃ // ℃
unicode_input_start(); register_unicode(0x2103);
register_hex(0x2103);
unicode_input_finish();
print("You pressed the Degrees key 4 times!\n"); print("You pressed the Degrees key 4 times!\n");
reset_tap_dance(state); reset_tap_dance(state);
break; break;
case 3: case 3:
//℉ //℉
unicode_input_start(); register_unicode(0x2109);
register_hex(0x2109);
unicode_input_finish();
print("You pressed the Degrees key 3 times!\n"); print("You pressed the Degrees key 3 times!\n");
reset_tap_dance(state); reset_tap_dance(state);
break; break;
case 2: case 2:
// € // €
unicode_input_start(); register_unicode(0x20AC);
register_hex(0x20AC);
unicode_input_finish();
print("You pressed the Degrees key 2 times!\n"); print("You pressed the Degrees key 2 times!\n");
reset_tap_dance(state); reset_tap_dance(state);
break; break;
case 1: case 1:
// ° // °
unicode_input_start(); register_unicode(0x00B0);
register_hex(0x00B0);
unicode_input_finish();
print("You pressed the Degrees key 1 time!\n"); print("You pressed the Degrees key 1 time!\n");
reset_tap_dance(state); reset_tap_dance(state);
break; break;

View file

@ -291,13 +291,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_A: case TUR_A:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x00c2);
register_hex(0x00c2);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x00e2);
register_hex(0x00e2);
unicode_input_finish();
} }
} }
return false; return false;
@ -305,13 +301,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_O: case TUR_O:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x00d6);
register_hex(0x00d6);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x00f6);
register_hex(0x00f6);
unicode_input_finish();
} }
} }
return false; return false;
@ -319,13 +311,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_U: case TUR_U:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x00dc);
register_hex(0x00dc);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x00fc);
register_hex(0x00fc);
unicode_input_finish();
} }
} }
return false; return false;
@ -333,13 +321,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_I: case TUR_I:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x0130);
register_hex(0x0130);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x0131);
register_hex(0x0131);
unicode_input_finish();
} }
} }
return false; return false;
@ -347,13 +331,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_G: case TUR_G:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x011e);
register_hex(0x011e);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x011f);
register_hex(0x011f);
unicode_input_finish();
} }
} }
return false; return false;
@ -361,13 +341,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_C: case TUR_C:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x00c7);
register_hex(0x00c7);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x00e7);
register_hex(0x00e7);
unicode_input_finish();
} }
} }
return false; return false;
@ -375,13 +351,9 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
case TUR_S: case TUR_S:
if (record->event.pressed) { if (record->event.pressed) {
if ( is_capital ) { if ( is_capital ) {
unicode_input_start(); register_unicode(0x015e);
register_hex(0x015e);
unicode_input_finish();
} else { } else {
unicode_input_start(); register_unicode(0x015f);
register_hex(0x015f);
unicode_input_finish();
} }
} }
return false; return false;

View file

@ -125,12 +125,14 @@ bool u_xp(bool is_shifted, const char *shifted, const char *plain) {
}; };
void zalgo(void) { void zalgo(void) {
unicode_input_start();
int number = (rand() % (8 + 1 - 2)) + 2; int number = (rand() % (8 + 1 - 2)) + 2;
unsigned int index; unsigned int index;
for (index=0; index<number; index++) { for (index=0; index<number; index++) {
uint16_t hex = (rand() % (0x036F + 1 - 0x0300)) + 0x0300; uint16_t hex = (rand() % (0x036F + 1 - 0x0300)) + 0x0300;
register_hex(hex); register_hex(hex);
} }
unicode_input_finish();
} }
bool combined_text(uint16_t keycode) { bool combined_text(uint16_t keycode) {
@ -138,16 +140,16 @@ bool combined_text(uint16_t keycode) {
return false; return false;
} }
tap_code(keycode); tap_code(keycode);
unicode_input_start();
switch (combined_mode) { switch (combined_mode) {
case CM_CIRCLE: case CM_CIRCLE:
register_hex(0x20DD); register_unicode(0x20DD);
break; break;
case CM_NO: case CM_NO:
register_hex(0x20E0); register_unicode(0x20E0);
break; break;
case CM_KEYCAP: case CM_KEYCAP:
register_hex(0x20E3); register_unicode(0x20E3);
break; break;
case CM_ZALGO: case CM_ZALGO:
zalgo(); zalgo();
@ -155,7 +157,6 @@ bool combined_text(uint16_t keycode) {
default: default:
break; break;
} }
unicode_input_finish();
return true; return true;
} }

View file

@ -73,19 +73,13 @@ static uint32_t math_glyph_exceptions(const uint16_t keycode, const bool shifted
} }
bool process_record_glyph_replacement(uint16_t keycode, keyrecord_t *record, uint32_t baseAlphaLower, uint32_t baseAlphaUpper, uint32_t zeroGlyph, uint32_t baseNumberOne, uint32_t spaceGlyph, uint32_t (*exceptions)(const uint16_t keycode, const bool shifted), uint8_t temp_mod, uint8_t temp_osm) { bool process_record_glyph_replacement(uint16_t keycode, keyrecord_t *record, uint32_t baseAlphaLower, uint32_t baseAlphaUpper, uint32_t zeroGlyph, uint32_t baseNumberOne, uint32_t spaceGlyph, uint32_t (*exceptions)(const uint16_t keycode, const bool shifted), uint8_t temp_mod, uint8_t temp_osm) {
void _register(uint32_t codepoint) {
unicode_input_start();
register_hex32(codepoint);
unicode_input_finish();
}
if ((((temp_mod | temp_osm) & (MOD_MASK_CTRL | MOD_MASK_ALT | MOD_MASK_GUI))) == 0) { if ((((temp_mod | temp_osm) & (MOD_MASK_CTRL | MOD_MASK_ALT | MOD_MASK_GUI))) == 0) {
bool shifted = ((temp_mod | temp_osm) & MOD_MASK_SHIFT); bool shifted = ((temp_mod | temp_osm) & MOD_MASK_SHIFT);
if (exceptions) { if (exceptions) {
uint32_t res = exceptions(keycode, shifted); uint32_t res = exceptions(keycode, shifted);
if (res) { if (res) {
if (record->event.pressed) { if (record->event.pressed) {
_register(res); register_unicode(res);
} }
return false; return false;
} }
@ -100,7 +94,7 @@ bool process_record_glyph_replacement(uint16_t keycode, keyrecord_t *record, uin
bool caps = host_keyboard_led_state().caps_lock; bool caps = host_keyboard_led_state().caps_lock;
uint32_t base = ((shifted == caps) ? baseAlphaLower : baseAlphaUpper); uint32_t base = ((shifted == caps) ? baseAlphaLower : baseAlphaUpper);
_register(base + (keycode - KC_A)); register_unicode(base + (keycode - KC_A));
set_mods(temp_mod); set_mods(temp_mod);
} }
return false; return false;
@ -109,7 +103,7 @@ bool process_record_glyph_replacement(uint16_t keycode, keyrecord_t *record, uin
return true; return true;
} }
if (record->event.pressed) { if (record->event.pressed) {
_register(zeroGlyph); register_unicode(zeroGlyph);
} }
return false; return false;
case KC_1 ... KC_9: case KC_1 ... KC_9:
@ -117,12 +111,12 @@ bool process_record_glyph_replacement(uint16_t keycode, keyrecord_t *record, uin
return true; return true;
} }
if (record->event.pressed) { if (record->event.pressed) {
_register(baseNumberOne + (keycode - KC_1)); register_unicode(baseNumberOne + (keycode - KC_1));
} }
return false; return false;
case KC_SPACE: case KC_SPACE:
if (record->event.pressed) { if (record->event.pressed) {
_register(spaceGlyph); // em space register_unicode(spaceGlyph); // em space
} }
return false; return false;
} }