2020-01-04 20:51:33 +00:00
|
|
|
#include "rossman360.h"
|
|
|
|
|
|
|
|
void my_custom_function(void) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
__attribute__ ((weak))
|
|
|
|
bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
return true;
|
|
|
|
}
|
2020-01-07 04:36:00 +00:00
|
|
|
|
2020-01-04 20:51:33 +00:00
|
|
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
switch (keycode) {
|
|
|
|
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();
|
|
|
|
SEND_STRING("make " QMK_KEYBOARD ":" QMK_KEYMAP);
|
|
|
|
#ifndef FLASH_BOOTLOADER
|
|
|
|
if ((temp_mod | temp_osm) & MOD_MASK_SHIFT)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
SEND_STRING(":flash");
|
|
|
|
}
|
|
|
|
if ((temp_mod | temp_osm) & MOD_MASK_CTRL) {
|
|
|
|
SEND_STRING(" -j8 --output-sync");
|
|
|
|
}
|
|
|
|
tap_code(KC_ENT);
|
|
|
|
set_mods(temp_mod);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case CSPEAK:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_PAGE_DOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PAGE_DOWN));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SPEAK1:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_PAGE_DOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PAGE_DOWN) SS_LCTL(SS_TAP(X_1)));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SPEAK2:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_PAGE_DOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PAGE_DOWN) SS_LCTL(SS_TAP(X_2)));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SPEAK3:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_PAGE_DOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PAGE_DOWN) SS_LCTL(SS_TAP(X_3)));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SPEAK4:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_PAGE_DOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PAGE_DOWN) SS_LCTL(SS_TAP(X_4)));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PARADOWN:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_PAGE_DOWN) SS_TAP(X_ENTER) SS_TAP(X_PAGE_DOWN));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PMERGE:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_HOME) SS_TAP(X_BACKSPACE) SS_TAP(X_SPACE) SS_LCTL(SS_TAP(X_BACKSPACE)) SS_TAP(X_SPACE));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case WREFRESH:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_SPACE) SS_TAP(X_BACKSPACE));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case REMCAPS:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_TAP(X_LEFT) SS_TAP(X_LEFT) SS_LCTL(SS_TAP(X_LEFT)) SS_TAP(X_DELETE));
|
2020-01-04 20:51:33 +00:00
|
|
|
}
|
|
|
|
break;
|
2020-05-16 07:17:02 +00:00
|
|
|
case EMDASH:
|
|
|
|
if (record->event.pressed) {
|
2022-10-17 12:45:23 +00:00
|
|
|
SEND_STRING(SS_LCTL(SS_LSFT(SS_TAP(X_U))) SS_TAP(X_2) SS_TAP(X_0) SS_TAP(X_1) SS_TAP(X_4) SS_TAP(X_SPACE) SS_TAP(X_SPACE));
|
2020-05-16 07:17:02 +00:00
|
|
|
}
|
|
|
|
break;
|
2020-01-04 20:51:33 +00:00
|
|
|
};
|
|
|
|
return true;
|
|
|
|
};
|