/* Copyright 2018 Yann Hodique <yann.hodique@gmail.com> @sigma 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 "sigma.h" userspace_config_t runtime_userspace_config; userspace_config_t stored_userspace_config; __attribute__ ((weak)) void matrix_init_keymap(void) {} __attribute__ ((weak)) void startup_keymap(void) {} __attribute__ ((weak)) void shutdown_keymap(void) {} __attribute__ ((weak)) void suspend_power_down_keymap(void) {} __attribute__ ((weak)) void suspend_wakeup_init_keymap(void) {} __attribute__ ((weak)) void matrix_scan_keymap(void) {} __attribute__ ((weak)) bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { return true; } __attribute__ ((weak)) bool process_record_secrets(uint16_t keycode, keyrecord_t *record) { return true; } __attribute__ ((weak)) uint32_t layer_state_set_keymap (uint32_t state) { return state; } __attribute__ ((weak)) uint32_t default_layer_state_set_keymap (uint32_t state) { return state; } __attribute__ ((weak)) void led_set_keymap(uint8_t usb_led) {} void set_os(uint8_t os) { runtime_userspace_config.os_target = os; switch (os) { case _OS_MACOS: set_unicode_input_mode(UC_OSX); break; case _OS_LINUX: set_unicode_input_mode(UC_LNX); break; case _OS_WINDOWS: set_unicode_input_mode(UC_WIN); break; } } void matrix_init_user(void) { stored_userspace_config.raw = eeconfig_read_user(); runtime_userspace_config.raw = stored_userspace_config.raw; set_os(runtime_userspace_config.os_target); } void store_userspace_config(void) { eeconfig_update_user(stored_userspace_config.raw); } LEADER_EXTERNS(); void matrix_scan_user(void) { LEADER_DICTIONARY() { leading = false; leader_end(); SEQ_TWO_KEYS(KC_F1, KC_L) { set_os(_OS_LINUX); } SEQ_TWO_KEYS(KC_F1, KC_M) { set_os(_OS_MACOS); } SEQ_TWO_KEYS(KC_F1, KC_W) { set_os(_OS_WINDOWS); } SEQ_TWO_KEYS(KC_F1, KC_S) { stored_userspace_config.raw = runtime_userspace_config.raw; store_userspace_config(); } } } bool process_record_user(uint16_t keycode, keyrecord_t *record) { uint8_t os_target = runtime_userspace_config.os_target; bool pressed = record->event.pressed; switch (keycode) { case KC_QWERTY: if (pressed) { set_single_persistent_default_layer(_QWERTY); } return false; break; case KC_MAKE: // Compiles the firmware, and adds the flash command based on keyboard bootloader if (!pressed) { send_string_with_delay_P(PSTR("make " QMK_KEYBOARD ":" QMK_KEYMAP #if defined(__ARM__) ":dfu-util" #elif defined(BOOTLOADER_DFU) ":dfu" #elif defined(BOOTLOADER_HALFKAY) ":teensy" #elif defined(BOOTLOADER_CATERINA) ":avrdude" #endif // bootloader options SS_TAP(X_ENTER)), 10); } return false; break; case EPRM: // Resets EEPROM if (pressed) { eeconfig_init(); default_layer_set(1UL<<eeconfig_read_default_layer()); layer_state_set(layer_state); set_os(_OS_MACOS); store_userspace_config(); } return false; break; case VRSN: // Prints firmware version if (pressed) { send_string_with_delay_P(PSTR(QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION ", Built on: " QMK_BUILDDATE), MACRO_TIMER); } return false; break; case KC_OS_CUT: switch (os_target) { case _OS_MACOS: if (pressed) SEND_STRING(SS_LGUI("x")); break; case _OS_LINUX: pressed ? register_code(KC_CUT) : unregister_code(KC_CUT); break; default: if (pressed) SEND_STRING(SS_LCTRL("x")); break; } break; case KC_OS_COPY: switch (os_target) { case _OS_MACOS: if (pressed) SEND_STRING(SS_LGUI("c")); break; case _OS_LINUX: pressed ? register_code(KC_COPY) : unregister_code(KC_COPY); break; default: if (pressed) SEND_STRING(SS_LCTRL("c")); break; } break; case KC_OS_PASTE: switch (os_target) { case _OS_MACOS: if (pressed) SEND_STRING(SS_LGUI("v")); break; case _OS_LINUX: pressed ? register_code(KC_PASTE) : unregister_code(KC_PASTE); break; default: if (pressed) SEND_STRING(SS_LCTRL("v")); break; } break; case KC_OS_UNDO: switch (os_target) { case _OS_MACOS: if (pressed) SEND_STRING(SS_LGUI("z")); break; case _OS_LINUX: pressed ? register_code(KC_UNDO) : unregister_code(KC_UNDO); break; default: if (pressed) SEND_STRING(SS_LCTRL("z")); break; } break; case KC_OS_REDO: switch (os_target) { case _OS_MACOS: if (pressed) SEND_STRING(SS_LGUI(SS_LSFT("z"))); break; case _OS_LINUX: pressed ? register_code(KC_AGAIN) : unregister_code(KC_AGAIN); break; default: if (pressed) SEND_STRING(SS_LCTRL(SS_LSFT("z"))); break; } break; case KC_OS_LOCK: switch (os_target) { case _OS_MACOS: if (pressed) SEND_STRING(SS_LGUI(SS_LCTRL("q"))); break; case _OS_LINUX: pressed ? register_code(KC_PWR) : unregister_code(KC_PWR); break; default: if (pressed) SEND_STRING(SS_LGUI("l")); break; } break; case KC_SCRT: if (pressed) { SEND_STRING(SS_LGUI("`")); } break; } return process_record_keymap(keycode, record); }