summaryrefslogtreecommitdiffstats
path: root/keyboards/planck/keymaps/rai-suta/keymap.c
diff options
context:
space:
mode:
authorJack Humbert <jack.humb@gmail.com>2017-06-25 21:31:10 -0400
committerGitHub <noreply@github.com>2017-06-25 21:31:10 -0400
commitd1fb8d2296889ee1aaa08988c8951eb5f12d930b (patch)
treee19d6fd1cd93c4ee81eb19609c79661160f728bf /keyboards/planck/keymaps/rai-suta/keymap.c
parent42e6ecc36b65ad0f0d29c6c35c93b95078c11a1a (diff)
parent3a2ae6a213acf7b20fab711a311ed5ca44b79b19 (diff)
Merge pull request #1431 from rai-suta/master
Bugg fix and add keymap for testing JIS_KEYCODE switch.
Diffstat (limited to 'keyboards/planck/keymaps/rai-suta/keymap.c')
-rw-r--r--keyboards/planck/keymaps/rai-suta/keymap.c107
1 files changed, 107 insertions, 0 deletions
diff --git a/keyboards/planck/keymaps/rai-suta/keymap.c b/keyboards/planck/keymaps/rai-suta/keymap.c
new file mode 100644
index 0000000000..13fc3677e6
--- /dev/null
+++ b/keyboards/planck/keymaps/rai-suta/keymap.c
@@ -0,0 +1,107 @@
+// This keymap assumes that the keyboard is recognized as JIS keyboard from the OS.
+
+#include "planck.h"
+#include "version.h"
+
+// Keycode defines
+#define _______ KC_TRNS
+#define XXXXXXX KC_NO
+#define C(kc) LCTL(kc)
+// JIS keyboard
+#define JK_CIRC KC_EQL // ^
+#define JK_AT KC_LBRC // @
+#define JK_LBRC KC_RBRC // [
+#define JK_CLN KC_QUOT // :
+#define JK_RBRC KC_BSLS // ]
+#define JK_BSLS KC_RO // Backslash(\)
+#define JK_DQT S(KC_2) // "
+#define JK_AMPR S(KC_6) // &
+#define JK_SQT S(KC_7) // '
+#define JK_LPRN S(KC_8) // (
+#define JK_RPRN S(KC_9) // )
+#define JK_S0 S(KC_0) // Tilde(~) at IBM 5576-A01 spec
+#define JK_EQ S(KC_MINS) // =
+#define JK_TLD S(JK_CIRC) // ~
+#define JK_PIPE S(KC_JYEN) // |
+#define JK_GRV S(JK_AT) // `
+#define JK_LCBR S(JK_LBRC) // {
+#define JK_PLUS S(KC_SCLN) // +
+#define JK_ASTR S(JK_CLN) // *
+#define JK_RCBR S(JK_RBRC) // }
+#define JK_QUES S(KC_SLSH) // ?
+#define JK_UNDS S(JK_BSLS) // _
+
+enum user_macro {
+ UM_MHEN,
+ UM_HENK,
+ UM_DEBUG,
+};
+#define M_MHEN MACROTAP(UM_MHEN)
+#define M_HENK MACROTAP(UM_HENK)
+#define M_DEBUG M(UM_DEBUG)
+
+enum keymap_layer {
+ KL_QWERTY,
+ KL_LOWER,
+ KL_RAISE,
+};
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+
+ [KL_QWERTY] = {
+ { KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
+ {KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, JK_CLN},
+ {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT},
+ {KC_ZKHK, KC_KANA, KC_LGUI, KC_LALT, M_MHEN, KC_SPC, KC_SPC, M_HENK, KC_RALT, KC_RGUI, KC_APP, KC_ENT}
+ },
+
+ [KL_LOWER] = {
+ {KC_GESC, KC_EXLM, JK_DQT, KC_HASH, KC_DLR, KC_PERC, JK_AMPR, JK_SQT, JK_LPRN, JK_RPRN, JK_S0, KC_DEL},
+ {_______, KC_LEFT, KC_UP, KC_DOWN, KC_RGHT, KC_DEL, KC_BSPC, JK_EQ, JK_TLD, JK_GRV, JK_LCBR, JK_PIPE},
+ {_______, C(KC_Z), C(KC_X), C(KC_C), C(KC_V), C(KC_Y), XXXXXXX, KC_ENT, KC_LABK, KC_RABK, JK_RCBR, JK_UNDS},
+ { RESET, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}
+ },
+
+ [KL_RAISE] = {
+ {KC_CAPS, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_DEL},
+ {_______, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_MINS, JK_CIRC, JK_AT, JK_LBRC, KC_JYEN},
+ {_______, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, XXXXXXX, KC_COMM, KC_DOT, JK_RBRC, JK_BSLS},
+ {M_DEBUG, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}
+ },
+
+};
+
+const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
+{
+ dprintf( "record.\n"
+ " event.pressed = %u\n"
+ " tap.count = %u\n"
+ " tap.interrupted = %u\n"
+ , record->event.pressed
+ , record->tap.count
+ , record->tap.interrupted );
+ dprintf( "id = %u\n", id );
+ dprintf( "opt = %u\n", opt );
+
+ switch(id) {
+
+ case UM_MHEN: {
+ return MACRO_TAP_HOLD_LAYER( record, MACRO(TYPE(KC_MHEN), END), KL_LOWER );
+ } break;
+
+ case UM_HENK: {
+ return MACRO_TAP_HOLD_LAYER( record, MACRO(TYPE(KC_HENK), END), KL_RAISE );
+ } break;
+
+ case UM_DEBUG: {
+ if (record->event.pressed) {
+ debug_enable = !debug_enable;
+ if (debug_enable) {
+ dprint("\nDEBUG: enabled.\n");
+ SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION);
+ }
+ }
+ } break;
+
+ }
+ return MACRO_NONE;
+};