|
@@ -0,0 +1,104 @@
|
|
|
+#include "rossman360.h"
|
|
|
+
|
|
|
+void my_custom_function(void) {
|
|
|
+
|
|
|
+}
|
|
|
+
|
|
|
+#define PGMOD LT(_NUM, KC_PGDN)
|
|
|
+#define TABMOD LT(_FN1, KC_TAB)
|
|
|
+#define SPCMOD LT(_FN1, KC_SPACE)
|
|
|
+#define ENTMOD LT(_FN2, KC_ENTER)
|
|
|
+#define ESCMOD LT(_NUM, KC_ESC)
|
|
|
+#define RSMOD LT(_FN1, KC_RSHIFT)
|
|
|
+#define CMDBSP MT(MOD_LGUI, KC_BSPC)
|
|
|
+#define ALTDEL MT(MOD_LALT, KC_DEL)
|
|
|
+#define CTRLSP MT(MOD_LCTL, KC_SPACE)
|
|
|
+#define BWORD LCTL(KC_BSPC)
|
|
|
+#define JUMPBACK LSFT(KC_TAB)
|
|
|
+#define LWORD LCTL(KC_LEFT)
|
|
|
+#define RWORD LCTL(KC_RIGHT)
|
|
|
+#define UNDO LCTL(KC_Z)
|
|
|
+#define NTAB LCTL(KC_T)
|
|
|
+#define CTAB LCTL(KC_W)
|
|
|
+#define XPANDR LCTL(LSFT(KC_X))
|
|
|
+#define TAB1 LCTL(KC_1)
|
|
|
+#define TAB2 LCTL(KC_2)
|
|
|
+#define TAB3 LCTL(KC_3)
|
|
|
+#define TAB4 LCTL(KC_4)
|
|
|
+#define RVOLU LCTL(KC_RBRC)
|
|
|
+#define RVOLD LCTL(KC_LBRC)
|
|
|
+
|
|
|
+__attribute__ ((weak))
|
|
|
+bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
|
|
|
+ return true;
|
|
|
+}
|
|
|
+
|
|
|
+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) {
|
|
|
+ SEND_STRING(SS_TAP(X_PGDOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PGDOWN));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case SPEAK1:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_PGDOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PGDOWN) SS_LCTRL(SS_TAP(X_1)));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case SPEAK2:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_PGDOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PGDOWN) SS_LCTRL(SS_TAP(X_2)));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case SPEAK3:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_PGDOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PGDOWN) SS_LCTRL(SS_TAP(X_3)));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case SPEAK4:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_PGDOWN) SS_TAP(X_ENTER) SS_TAP(X_ENTER) SS_TAP(X_PGDOWN) SS_LCTRL(SS_TAP(X_4)));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case PARADOWN:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_PGDOWN) SS_TAP(X_ENTER) SS_TAP(X_PGDOWN));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case PMERGE:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_HOME) SS_TAP(X_BSPACE) SS_TAP(X_SPACE) SS_LCTRL(SS_TAP(X_BSPACE)) SS_TAP(X_SPACE));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case WREFRESH:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_SPACE) SS_TAP(X_BSPACE));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case REMCAPS:
|
|
|
+ if (record->event.pressed) {
|
|
|
+ SEND_STRING(SS_TAP(X_LEFT) SS_TAP(X_LEFT) SS_LCTRL(SS_TAP(X_LEFT)) SS_TAP(X_DELETE));
|
|
|
+ }
|
|
|
+ break;
|
|
|
+};
|
|
|
+return true;
|
|
|
+};
|