summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOscillope <jvrosenman@gmail.com>2017-12-21 01:54:43 +0100
committerJack Humbert <jack.humb@gmail.com>2017-12-21 01:54:43 +0100
commit846598541b03d97b2b3fbab0a276110d215ce9e2 (patch)
treea75f9cf35b19b32d6bc12c29e5032a8ce064f3b3
parentc68597d9ad983c7d8f2b857f795037f2a441522d (diff)
downloadqmk_firmware-846598541b03d97b2b3fbab0a276110d215ce9e2.tar.gz
qmk_firmware-846598541b03d97b2b3fbab0a276110d215ce9e2.tar.xz
Oscillope keymap: handy programming macros (#2176)
* Added macro to type -> since that symbol requres much finger acrobatics otherwise. * Added macros for braces
-rw-r--r--keyboards/jj40/jj40.h1
-rw-r--r--keyboards/jj40/keymaps/oscillope/keymap.c32
2 files changed, 29 insertions, 4 deletions
diff --git a/keyboards/jj40/jj40.h b/keyboards/jj40/jj40.h
index b1a7a6238..6e90cb972 100644
--- a/keyboards/jj40/jj40.h
+++ b/keyboards/jj40/jj40.h
@@ -18,6 +18,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifndef KEYMAP_COMMON_H
#define KEYMAP_COMMON_H
+#include "quantum.h"
#include "quantum_keycodes.h"
#include "keycode.h"
#include "action.h"
diff --git a/keyboards/jj40/keymaps/oscillope/keymap.c b/keyboards/jj40/keymaps/oscillope/keymap.c
index 28bfbc154..2eaecd7e4 100644
--- a/keyboards/jj40/keymaps/oscillope/keymap.c
+++ b/keyboards/jj40/keymaps/oscillope/keymap.c
@@ -26,6 +26,10 @@ enum custom_keycodes {
QWERTY = SAFE_RANGE,
LOWER,
RAISE,
+ CC_ARRW,
+ CC_PRN,
+ CC_BRC,
+ CC_CBR,
};
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
@@ -51,7 +55,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
* ,-----------------------------------------------------------------------------------.
* | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 |
* |------+------+------+------+------+-------------+------+------+------+------+------|
- * | Ins | | | | | | Left | Down | Up |Right | | |
+ * | Ins | | | () | [] | {} | Left | Down | Up |Right | | |
* |------+------+------+------+------+------|------+------+------+------+------+------|
* |PrScr | Back | Fwd | | | | | | Mute | Vol- | Vol+ | |
* |------+------+------+------+------+------+------+------+------+------+------+------|
@@ -60,7 +64,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
*/
[_LOWER] = KEYMAP( \
KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, \
- KC_INS, _______, _______, _______, _______, _______, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, _______, _______, \
+ KC_INS, _______, _______, CC_PRN, CC_BRC, CC_CBR, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, _______, _______, \
KC_PSCR, KC_WBAK, KC_WFWD, _______, _______, _______, _______, _______, KC_MUTE, KC_VOLD, KC_VOLU, _______, \
_______, _______, _______, _______, KC_LOCK, _______, _______, KC_MPRV, KC_MSTP, KC_MPLY, KC_MNXT \
),
@@ -71,7 +75,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
* |------+------+------+------+------+-------------+------+------+------+------+------|
* | Tab | $ | % | ^ | [ | ] | 4 | 5 | 6 | - | + |Enter |
* |------+------+------+------+------+------|------+------+------+------+------+------|
- * | ` | ! | @ | # | { | } | 1 | 2 | 3 | . | \ | | |
+ * | -> | ! | @ | # | { | } | 1 | 2 | 3 | . | \ | | |
* |------+------+------+------+------+------+------+------+------+------+------+------|
* | Ctrl | OS | Alt | |Shift | | 0 | Home | PgDn | PgUp | End |
* `-----------------------------------------------------------------------------------'
@@ -79,7 +83,27 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[_RAISE] = KEYMAP( \
KC_CAPS, KC_AMPR, KC_ASTR, KC_UNDS, KC_LPRN, KC_RPRN, KC_7, KC_8, KC_9, KC_EQL, KC_BSPC, KC_DEL, \
KC_TAB, KC_DLR, KC_PERC, KC_CIRC, KC_LBRC, KC_RBRC, KC_4, KC_5, KC_6, KC_MINS, KC_PLUS, _______, \
- _______, KC_EXLM, KC_AT, KC_HASH, KC_LCBR, KC_RCBR, KC_1, KC_2, KC_3, _______, KC_BSLS, KC_PIPE, \
+ CC_ARRW, KC_EXLM, KC_AT, KC_HASH, KC_LCBR, KC_RCBR, KC_1, KC_2, KC_3, _______, KC_BSLS, KC_PIPE, \
_______, _______, _______, _______, _______, _______, KC_0, KC_HOME, KC_PGDN, KC_PGUP, KC_END \
)
};
+
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ if (record->event.pressed) {
+ switch(keycode) {
+ case CC_ARRW:
+ SEND_STRING("->");
+ return false;
+ case CC_PRN:
+ SEND_STRING("()"SS_TAP(X_LEFT));
+ return false;
+ case CC_BRC:
+ SEND_STRING("[]"SS_TAP(X_LEFT));
+ return false;
+ case CC_CBR:
+ SEND_STRING("{}"SS_TAP(X_LEFT));
+ return false;
+ }
+ }
+ return true;
+}