]> git.donarmstrong.com Git - qmk_firmware.git/blob - keyboards/mitosis/keymaps/datagrok/keymap.c
24d9d650042ebe24dd3e18a7bbee46e3beeea25a
[qmk_firmware.git] / keyboards / mitosis / keymaps / datagrok / keymap.c
1 #include "mitosis.h"
2
3 enum mitosis_layers
4 {
5     _xQ, // qwerty
6     _xW, // workman
7     _xS, // symbols
8     _xN, // numbers
9     _xF  // functions
10 };
11
12 // Fillers to make layering more clear
13 #define XXXXXXX KC_NO   // No-op (no key in this location on Mitosis' fake matrix)
14 #define _______ KC_TRNS // Transparent, because I haven't decided a mapping yet
15 #define KC_LMTA KC_LALT // For fun, name the mods like the space cadet keyboard does
16 #define KC_RMTA KC_RALT // META
17 #define KC_LSUP KC_LGUI // SUPER
18 #define KC_RSUP KC_RGUI //
19 #define KC_RHYP KC_INT4 // HYPER (actually muhenkan 無変換 and henkan 変換)
20 #define KC_LHYP KC_INT5 // or NFER/XFER.
21
22 // Momentary tri-state layers. Mitosis default keymap does this too but employs
23 // new keymappings and a bunch of conditional code. This simpler keymap
24 // accomplishes it, but with a small quirk: triggering both layers then
25 // releasing one out-of-order will leave the tri-state triggered until the
26 // other is released. Which doesn't bother me.
27
28 const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
29   [_xQ] = {
30     {KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P},
31     {KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN},
32     {KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_QUOT},
33     {XXXXXXX, KC_LSUP, KC_LCTL, MO(_xN), SFT_T(KC_TAB), KC_RSFT, MO(_xN), KC_RCTL, KC_RSUP, XXXXXXX},
34     {XXXXXXX, KC_LHYP, KC_LMTA, MO(_xS), KC_BSPC, KC_SPC,  MO(_xS), KC_RMTA, KC_RHYP, XXXXXXX}
35   },
36   [_xW] = {
37     {KC_Q,    KC_D,    KC_R,    KC_W,    KC_B,    KC_J,    KC_F,    KC_U,    KC_P,    KC_SCLN},
38     {KC_A,    KC_S,    KC_H,    KC_T,    KC_G,    KC_Y,    KC_N,    KC_E,    KC_O,    KC_I},
39     {KC_Z,    KC_X,    KC_M,    KC_C,    KC_V,    KC_K,    KC_L,    KC_COMM, KC_DOT,  KC_QUOT},
40     {XXXXXXX, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX},
41     {XXXXXXX, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX}
42   },
43   [_xS] = {
44     {KC_ESC,  _______, KC_UP,   _______, _______, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, KC_TILD},
45     {KC_TAB,  KC_LEFT, KC_DOWN, KC_RGHT, _______, KC_CIRC, KC_AMPR, KC_PIPE, KC_GRV,  KC_UNDS},
46     {KC_BSLS, KC_RPRN, KC_RCBR, KC_RBRC, KC_RABK, KC_LABK, KC_LBRC, KC_LCBR, KC_LPRN, KC_SLSH},
47     {XXXXXXX, _______, _______, MO(_xF), _______, _______, MO(_xF), _______, _______, XXXXXXX},
48     {XXXXXXX, _______, _______, _______, KC_DEL,  KC_ENT,  _______, _______, _______, XXXXXXX},
49   },
50   [_xN] = {
51     {_______, _______, _______, _______, KC_NLCK, KC_PSLS, KC_P7,   KC_P8,   KC_P9,   KC_P0},
52     {_______, _______, _______, _______, _______, KC_PAST, KC_P4,   KC_P5,   KC_P6,   KC_PPLS},
53     {_______, _______, _______, _______, _______, KC_PMNS, KC_P1,   KC_P2,   KC_P3,   KC_PEQL},
54     {XXXXXXX, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX},
55     {XXXXXXX, _______, _______, MO(_xF), _______, KC_PENT, MO(_xF), _______, _______, XXXXXXX},
56   },
57   [_xF] = {
58     {_______, _______, KC_PGUP, _______, KC_VOLU, KC_F13,  KC_F7,   KC_F8,   KC_F9,   KC_F10},
59     {_______, KC_HOME, KC_PGDN, KC_END,  KC_VOLD, KC_F14,  KC_F4,   KC_F5,   KC_F6,   KC_F11},
60     {TG(_xW), KC_MPRV, KC_MPLY, KC_MNXT, KC_MUTE, KC_F15,  KC_F1,   KC_F2,   KC_F3,   KC_F12},
61     {XXXXXXX, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX},
62     {XXXXXXX, _______, _______, _______, _______, _______, _______, _______, _______, XXXXXXX},
63   },
64 };
65
66 // This is a hack to place <question mark> on <shift-comma> and <exclaimation
67 // mark> on <shift-period>, when using an operating system configured for a
68 // US/qwerty layout.
69 bool comm_shifted = false;
70 bool ques_shifted = false;
71 bool process_record_user(uint16_t keycode, keyrecord_t *record) {
72   uint8_t shifted;
73   uint16_t s_keycode;
74   bool *k_shifted;
75
76   switch (keycode) {
77     case KC_COMM:
78       s_keycode = KC_SLSH;
79       k_shifted = &comm_shifted;
80       break;
81     case KC_DOT:
82       s_keycode = KC_1;
83       k_shifted = &ques_shifted;
84       break;
85     default:
86       return true;
87   }
88
89   shifted = get_mods() & (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT));
90
91   // Keydown. If shift is currently pressed, register its alternate keycode.
92   if (record->event.pressed && shifted) {
93     *k_shifted = true;
94     register_code(s_keycode);
95     return false;
96     // Keyup. If shift was pressed back when the key was pressed, unregister
97     // its alternate keycode.
98   } else if (!(record->event.pressed) && *k_shifted) {
99     *k_shifted = false;
100     unregister_code(s_keycode);
101     return false;
102     // Otherwise, behave as normal.
103   } else {
104     return true;
105   }
106 }
107
108 // Set the bits of A selected by MASK to the corresponding bits of B
109 #define setbits(A, B, MASK) A = (A & (B | ~MASK)) | (B & MASK)
110 void matrix_scan_user(void) {
111   //
112   // Bit #            7     6     5     4     3     2     1     0
113   // layer_state: [     |     |     | _xF | _xN | _xS | _xQ | _xW ]
114   // usb_led      [     |     |     |kana |cmps |scrl |caps | num ]
115   // PORTB:       [  NC |  10 |   9 |   8 |  14 |  16 |  15 |rxled]
116   // PORTC:       [  NC |   5 |     |     |     |     |     |     ]
117   // PORTD:       [   6 |  NC |txled|   4 | tx* | rx* | grn | p29 ]
118   // PORTE:       [     |   7 |     |     |     |     |     |     ]
119   // PORTF:       [  a0 |  a1 | red | blu |     |     |  NC |  NC ]
120   //
121   // PD0 is connected to the pairing switch and p29 on the wireless module.
122   // PF0,PF1,PB7,PC7,PD6 are not broken out by the pro micro board. I don't understand why.
123   // PB1-PB6,PD4,PD5,PD6,PF6,PF7 are not connected to the Mitosis receiver
124   // board. Each may be connected to an LED by way of a resistor (4.7k to
125   // match the others) for a total of 14 additional indicators.
126
127   // A simple (but technically inaccurate) model of the momentary layer state:
128   // Fn1 key makes _xS active; indicator = red
129   // Fn2 key makes _xN active; indicator = blue
130   // Both keys make _xF active; indicator = purple
131   // Toggling QWERTY mode makes indicator include green, so (red/blue/purple becomes yellow/cyan/white)
132
133   // negated because for ports 0=LED on.
134   uint32_t portf_bits = ~(layer_state|layer_state<<1|(layer_state&0b100)<<3);
135   setbits(PORTF, portf_bits, 0b00110000);
136   setbits(PORTD, ~layer_state, 0b00000010);
137 }
138
139 // vim: set sw=2 et: