forked from mfulz_github/qmk_firmware
150 lines
4.6 KiB
C
150 lines
4.6 KiB
C
#include "bocaj.h"
|
|
#include QMK_KEYBOARD_H
|
|
|
|
uint16_t copy_paste_timer;
|
|
uint16_t grave_layer_timer;
|
|
uint16_t heal_layer_timer;
|
|
|
|
__attribute__ ((weak))
|
|
bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
|
|
return true;
|
|
}
|
|
|
|
// Defines actions tor my global custom keycodes. Defined in bocaj.h file
|
|
// Then runs the _keymap's record handler if not processed here
|
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
switch (keycode) {
|
|
case KC_MWRK:
|
|
if (!record->event.pressed) {
|
|
set_single_persistent_default_layer(_WORKMAN);
|
|
#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
|
|
set_unicode_input_mode(0);
|
|
#endif
|
|
layer_move(0);
|
|
ergodox_blink_all_leds();
|
|
}
|
|
break;
|
|
case KC_WWRK:
|
|
if (!record->event.pressed) {
|
|
set_single_persistent_default_layer(_WINWORKMAN);
|
|
#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
|
|
set_unicode_input_mode(4);
|
|
#endif
|
|
layer_move(0);
|
|
ergodox_blink_all_leds();
|
|
}
|
|
break;
|
|
case KC_MQWR:
|
|
if (!record->event.pressed) {
|
|
set_single_persistent_default_layer(_QWERTY);
|
|
#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
|
|
set_unicode_input_mode(0);
|
|
#endif
|
|
layer_move(0);
|
|
ergodox_blink_all_leds();
|
|
}
|
|
break;
|
|
case MC_LOCK:
|
|
if (!record->event.pressed) {
|
|
layer_move(0);
|
|
SEND_STRING(SS_LCTRL(SS_LGUI("q")));
|
|
}
|
|
break;
|
|
case KC_MAKE: // Compiles the firmware, and adds the flash command based on keyboard bootloader
|
|
if (!record->event.pressed) {
|
|
uint8_t temp_mod = get_mods();
|
|
uint8_t temp_osm = get_oneshot_mods();
|
|
clear_mods();
|
|
clear_oneshot_mods();
|
|
if (biton32(default_layer_state) == _WINWORKMAN) {
|
|
send_string_with_delay_P(PSTR("make " QMK_KEYBOARD ":" QMK_KEYMAP), 10);
|
|
} else {
|
|
send_string_with_delay_P(PSTR("util/docker_build.sh " QMK_KEYBOARD ":" QMK_KEYMAP), 10);
|
|
}
|
|
if (temp_mod & MODS_SHIFT_MASK) {
|
|
send_string_with_delay_P(PSTR(":teensy"), 10);
|
|
}
|
|
if (temp_mod & MODS_CTRL_MASK) {
|
|
send_string_with_delay_P(PSTR(" -j8 --output-sync"), 10);
|
|
}
|
|
send_string_with_delay_P(PSTR(SS_TAP(X_ENTER)), 10);
|
|
set_mods(temp_mod);
|
|
layer_move(0);
|
|
}
|
|
break;
|
|
case KC_DCLR: // reset all Diablo timers, disabling them
|
|
#ifdef TAP_DANCE_ENABLE
|
|
if (record->event.pressed) {
|
|
uint8_t dtime;
|
|
for (dtime = 0; dtime < 4; dtime++) {
|
|
diablo_key_time[dtime] = diablo_times[0];
|
|
}
|
|
}
|
|
#endif // TAP_DANCE_ENABLE
|
|
break;
|
|
case JJ_ARRW:
|
|
if (!record->event.pressed) {
|
|
SEND_STRING("->");
|
|
}
|
|
return false;
|
|
break;
|
|
case LM_GRAVE:
|
|
if (record->event.pressed) {
|
|
grave_layer_timer = timer_read();
|
|
} else {
|
|
if (timer_elapsed(grave_layer_timer) < TAPPING_TERM) {
|
|
uint8_t temp_mod = get_mods();
|
|
uint8_t one_shot = get_oneshot_mods();
|
|
clear_mods();
|
|
if (temp_mod & MODS_SHIFT_MASK || one_shot & MODS_SHIFT_MASK) {
|
|
register_code(KC_LSFT);
|
|
tap(KC_GRAVE);
|
|
unregister_code(KC_LSFT);
|
|
} else {
|
|
tap(KC_GRAVE);
|
|
}
|
|
set_mods(temp_mod);
|
|
} else {
|
|
layer_move(0);
|
|
}
|
|
}
|
|
return false;
|
|
break;
|
|
case KC_CCCV:
|
|
if (record->event.pressed) {
|
|
copy_paste_timer = timer_read();
|
|
} else {
|
|
if (timer_elapsed(copy_paste_timer) > TAPPING_TERM) { // Hold, copy
|
|
SEND_STRING(SS_LGUI("c"));
|
|
} else {
|
|
SEND_STRING(SS_LGUI("v"));
|
|
}
|
|
}
|
|
return false;
|
|
break;
|
|
#ifdef UNICODE_ENABLE
|
|
case UC_FLIP: // (ノಠ痊ಠ)ノ彡┻━┻
|
|
if (record->event.pressed) {
|
|
send_unicode_hex_string("0028 30CE 0CA0 75CA 0CA0 0029 30CE 5F61 253B 2501 253B");
|
|
}
|
|
break;
|
|
case UC_TABL: // ┬─┬ノ( º _ ºノ)
|
|
if (record->event.pressed) {
|
|
send_unicode_hex_string("252C 2500 252C 30CE 0028 0020 00BA 0020 005F 0020 00BA 30CE 0029");
|
|
}
|
|
break;
|
|
case UC_SHRG: // ¯\_(ツ)_/¯
|
|
if (record->event.pressed) {
|
|
send_unicode_hex_string("00AF 005C 005F 0028 30C4 0029 005F 002F 00AF");
|
|
}
|
|
break;
|
|
case UC_DISA: // ಠ_ಠ
|
|
if (record->event.pressed) {
|
|
send_unicode_hex_string("0CA0 005F 0CA0");
|
|
}
|
|
break;
|
|
#endif
|
|
}
|
|
return process_record_keymap(keycode, record);
|
|
}
|