aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar ridingqwerty <george.g.koenig@gmail.com>2019-08-16 19:54:16 -0400
committerGravatar Drashna Jaelre <drashna@live.com>2019-08-16 16:54:16 -0700
commit0c03811d6affb31d9952e9b4c9c0f5e10fddee8a (patch)
tree25e10a61ed0e40ee7852fc9bcdc2f1571b288fa1
parent36dd261d06e86ed90997486776f06b286a163cd8 (diff)
downloadqmk_firmware-0c03811d6affb31d9952e9b4c9c0f5e10fddee8a.tar.gz
[Keymap] add "ridingqwerty" user and keymap for atreus keyboard (#6533)
* add userspace and atreus keymap * cleaning up notes/comments * Update keyboards/atreus/keymaps/ridingqwerty/atreus.c Co-Authored-By: Joel Challis <git@zvecr.com> * Update keyboards/atreus/keymaps/ridingqwerty/atreus.c Co-Authored-By: Joel Challis <git@zvecr.com> * Create readme.md * remove reference to matrix_init_kb from atreus.c * correct atreus.c * remove unnecessary defines * merge register/unregister sequence into single tapcode * move 'LAYOUT to keymap.c; remove atreus.h * remove TAPPING_TERM from keyboard-level config.h
-rw-r--r--keyboards/atreus/keymaps/ridingqwerty/config.h13
-rw-r--r--keyboards/atreus/keymaps/ridingqwerty/keymap.c116
-rw-r--r--keyboards/atreus/keymaps/ridingqwerty/readme.md1
-rw-r--r--keyboards/atreus/keymaps/ridingqwerty/rules.mk17
-rw-r--r--users/ridingqwerty/config.h3
-rw-r--r--users/ridingqwerty/process_records.c33
-rw-r--r--users/ridingqwerty/process_records.h29
-rw-r--r--users/ridingqwerty/ridingqwerty.c1
-rw-r--r--users/ridingqwerty/ridingqwerty.h37
-rw-r--r--users/ridingqwerty/rules.mk8
10 files changed, 258 insertions, 0 deletions
diff --git a/keyboards/atreus/keymaps/ridingqwerty/config.h b/keyboards/atreus/keymaps/ridingqwerty/config.h
new file mode 100644
index 000000000..349d7b1c4
--- /dev/null
+++ b/keyboards/atreus/keymaps/ridingqwerty/config.h
@@ -0,0 +1,13 @@
+#pragma once
+
+#undef MATRIX_ROWS
+#define MATRIX_ROWS 8
+
+#undef MATRIX_COLS
+#define MATRIX_COLS 6
+
+#undef MATRIX_ROW_PINS
+#define MATRIX_ROW_PINS { A6, A7, A8, A15, B11, B12, A14, A13 }
+
+#undef MATRIX_COL_PINS
+#define MATRIX_COL_PINS { B5, B4, B3, B2, B1, B0 }
diff --git a/keyboards/atreus/keymaps/ridingqwerty/keymap.c b/keyboards/atreus/keymaps/ridingqwerty/keymap.c
new file mode 100644
index 000000000..336df4973
--- /dev/null
+++ b/keyboards/atreus/keymaps/ridingqwerty/keymap.c
@@ -0,0 +1,116 @@
+/* Copyright 2019 George Koenig
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include QMK_KEYBOARD_H
+#include "ridingqwerty.h"
+
+/* Atreus
+ ┏━━━━━━━━┯━━━━━━━━┯━━━━━━━━┯━━━━━━━━┯━━━━━━━━┓ ┏━━━━━━━━┯━━━━━━━━┯━━━━━━━━┯━━━━━━━━┯━━━━━━━━┓
+ ┃ Q │ W │ E │ R │ T ┃ ┃ Y │ U │ I │ O │ P ┃
+ ┠────────┼────────┼────────┼────────┼────────┨ ┠────────┼────────┼────────┼────────┼────────┨
+ /┃ ¶ A │ S │ D │ F │ G ┃ ┃ H │ J │ K │ L │ 🔢 ; ┃
+ ┠────────┼────────┼────────┼────────┼────────┞━━━━━━━━┳━━━━━━━━┞────────┼────────┼────────┼────────┼────────┨
+ /┃ ⇧ Z │ X │ C │ V │ B │ ┃ │ N │ M │ , │ 𝔽 . │ ⇧ / ┃
+ ┠────────┼────────┼────────┼────────┼────────┤ ¶ ⎋ ┃ ❦ ⇥ ├────────┼────────┼────────┼────────┼────────┨
+ ┃ ⎈ ⎋ │ ⌘ ⇥ │ ⎇ [ │ ⇧ ] │ 🔢 ⌫ │ ┃ │ ★ ␣ │ ⇧ - │ ⎇ = │ ⌘ ' │ ⎈ ↵ ┃
+ ┗━━━━━━━━┷━━━━━━━━┷━━━━━━━━┷━━━━━━━━┷━━━━━━━━┷━━━━━━━━┻━━━━━━━━┷━━━━━━━━┷━━━━━━━━┷━━━━━━━━┷━━━━━━━━┷━━━━━━━━┛
+ MODS // LAYERS // MODS //
+*/
+
+#ifdef LAYOUT
+#undef LAYOUT
+#define LAYOUT( \
+ K00, K01, K02, K03, K04, K40, K41, K42, K43, K44, \
+ K10, K11, K12, K13, K14, K50, K51, K52, K53, K54, \
+ K20, K21, K22, K23, K24, K60, K61, K62, K63, K64, \
+ K30, K31, K32, K33, K34, K35, K70, K71, K72, K73, K74, K75 \
+) { \
+ { K00, K01, K02, K03, K04, KC_NO }, \
+ { K10, K11, K12, K13, K14, KC_NO }, \
+ { K20, K21, K22, K23, K24, KC_NO }, \
+ { K30, K31, K32, K33, K34, K35 }, \
+ { K44, K43, K42, K41, K40, KC_NO }, \
+ { K54, K53, K52, K51, K50, KC_NO }, \
+ { K64, K63, K62, K61, K60, KC_NO }, \
+ { K75, K74, K73, K72, K71, K70 } \
+}
+#endif
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ [_QWERTY] = LAYOUT( /* Qwerty */
+ KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,
+ ED_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, NM_SCLN,
+ LS_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, FK_DOT, RS_SLSH,
+ LC_ESC, LG_TAB, LA_LBRC, LS_RBRC, NM_BSPC, ED_ESC, SC_TAB, SM_SPC, RS_MINS, RA_EQL, RG_QUOT, RC_ENT
+ ),
+ [_EDITOR] = LAYOUT( /* ED_A, ED_ESC */
+ KC_GRV, _______, KC_END, _______, KC_TAB, _______, _______, KC_INS, _______, KC_PGUP,
+ KC_HOME, _______, KC_DELT, _______, _______, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_ENT,
+ _______, _______, _______, _______, _______, KC_PGDN, _______, _______, _______, KC_BSLS,
+ _______, _______, _______, _______, _______, _______, KC_ENT, _______, _______, _______, _______, _______
+ ),
+ [_NUMBER] = LAYOUT( /* NM_SCLN, NM_BSPC */
+ KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,
+ KC_6, KC_7, KC_8, KC_9, KC_0, _______, KC_4, KC_5, KC_6, _______,
+ _______, _______, _______, _______, _______, _______, KC_1, KC_2, KC_3, KC_BSLS,
+ _______, _______, _______, _______, _______, KC_MINS, KC_EQL, KC_0, KC_0, KC_DOT, _______, _______
+ ),
+ [_SYMBOL] = LAYOUT( /* SM_SPC */
+ KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN,
+ KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, _______, _______, _______, _______, KC_COLN,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_BSLS,
+ _______, _______, _______, _______, _______, KC_LBRC, KC_RBRC, _______, _______, _______, _______, _______
+ ),
+ [_F_KEYS] = LAYOUT( /* FK_DOT */
+ KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10,
+ KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, _______, _______, _______, _______, KC_F11,
+ KC_F11, KC_F12, _______, _______, _______, _______, _______, _______, _______, KC_F12,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
+ ),
+ [_SECRET] = LAYOUT( /* shhhh... */
+ RESET, _______, _______, RUSTY, FUEL, KC_F13, _______, _______, _______, _______,
+ AR1ST, SYSNOC, _______, _______, _______, _______, _______, _______, OS_LAB, _______,
+ CDLOCAL, _______, C0RE, VAXIS, _______, _______, MUNKY, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
+ ),
+ [_FINAL] = LAYOUT( /* . */
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
+ )
+};
+
+// custom tap/hold keys
+uint16_t key_timer;
+bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
+ switch(keycode) {
+ case RG_QUOT:
+ if (record->event.pressed) {
+ key_timer = timer_read();
+ layer_on(_NUMBER);
+ register_mods(MOD_BIT(KC_RGUI));
+ } else {
+ unregister_mods(MOD_BIT(KC_RGUI));
+ layer_off(_NUMBER);
+ if (timer_elapsed(key_timer) < TAPPING_TERM) {
+ tap_code(KC_QUOT);
+ }
+ }
+ return false; break;
+ }
+ return true;
+};
diff --git a/keyboards/atreus/keymaps/ridingqwerty/readme.md b/keyboards/atreus/keymaps/ridingqwerty/readme.md
new file mode 100644
index 000000000..936df3609
--- /dev/null
+++ b/keyboards/atreus/keymaps/ridingqwerty/readme.md
@@ -0,0 +1 @@
+This is a handwired Atreus42 using a Proton C
diff --git a/keyboards/atreus/keymaps/ridingqwerty/rules.mk b/keyboards/atreus/keymaps/ridingqwerty/rules.mk
new file mode 100644
index 000000000..95b257f75
--- /dev/null
+++ b/keyboards/atreus/keymaps/ridingqwerty/rules.mk
@@ -0,0 +1,17 @@
+MCU = STM32F303
+
+# Build Options
+# comment out to disable the options.
+#
+BACKLIGHT_ENABLE = no
+BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration
+#MOUSEKEY_ENABLE = yes # Mouse keys
+EXTRAKEY_ENABLE = yes # Audio control and System control
+CONSOLE_ENABLE = yes # Console for debug
+COMMAND_ENABLE = yes # Commands for debug and configuration
+#SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend
+NKRO_ENABLE = yes # USB Nkey Rollover
+AUDIO_ENABLE = yes
+RGBLIGHT_ENABLE = no
+# SERIAL_LINK_ENABLE = yes
+#TAP_DANCE_ENABLE = yes
diff --git a/users/ridingqwerty/config.h b/users/ridingqwerty/config.h
new file mode 100644
index 000000000..2461b8b8d
--- /dev/null
+++ b/users/ridingqwerty/config.h
@@ -0,0 +1,3 @@
+#pragma once
+#define TAPPING_TERM 175
+#define MACRO_TIMER 5
diff --git a/users/ridingqwerty/process_records.c b/users/ridingqwerty/process_records.c
new file mode 100644
index 000000000..be72883ec
--- /dev/null
+++ b/users/ridingqwerty/process_records.c
@@ -0,0 +1,33 @@
+#include "ridingqwerty.h"
+
+__attribute__ ((weak))
+bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
+ return true;
+}
+
+__attribute__ ((weak))
+bool process_record_secrets(uint16_t keycode, keyrecord_t *record) {
+ return true;
+}
+
+uint16_t user_key_timer;
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch(keycode) {
+ case RG_QUOT:
+ if (record->event.pressed) {
+ user_key_timer = timer_read();
+ layer_on(_NUMBER);
+ register_mods(MOD_BIT(KC_RGUI));
+ } else {
+ unregister_mods(MOD_BIT(KC_RGUI));
+ layer_off(_NUMBER);
+ if (timer_elapsed(user_key_timer) < TAPPING_TERM) {
+ register_code(KC_QUOT);
+ unregister_code(KC_QUOT);
+ }
+ }
+ return false; break;
+ }
+ return process_record_keymap(keycode, record) &&
+ process_record_secrets(keycode, record);
+}
diff --git a/users/ridingqwerty/process_records.h b/users/ridingqwerty/process_records.h
new file mode 100644
index 000000000..2c453bcd9
--- /dev/null
+++ b/users/ridingqwerty/process_records.h
@@ -0,0 +1,29 @@
+#pragma once
+#include "ridingqwerty.h"
+
+#if defined(KEYMAP_SAFE_RANGE)
+ #define PLACEHOLDER_SAFE_RANGE KEYMAP_SAFE_RANGE
+#else
+ #define PLACEHOLDER_SAFE_RANGE SAFE_RANGE
+#endif
+
+bool process_record_secrets(uint16_t keycode, keyrecord_t *record);
+bool process_record_keymap(uint16_t keycode, keyrecord_t *record);
+
+enum userspace_custom_keycodes {
+ FIRST = PLACEHOLDER_SAFE_RANGE,
+ RUSTY,
+ FUEL,
+ C0RE,
+ MUNKY,
+ AR1ST,
+ VAXIS,
+ OS_LAB,
+ CDLOCAL,
+ SYSNOC,
+ RG_QUOT,
+ LAST
+};
+
+bool process_record_secrets(uint16_t keycode, keyrecord_t *record);
+bool process_record_keymap(uint16_t keycode, keyrecord_t *record);
diff --git a/users/ridingqwerty/ridingqwerty.c b/users/ridingqwerty/ridingqwerty.c
new file mode 100644
index 000000000..fd39021da
--- /dev/null
+++ b/users/ridingqwerty/ridingqwerty.c
@@ -0,0 +1 @@
+#include "ridingqwerty.h"
diff --git a/users/ridingqwerty/ridingqwerty.h b/users/ridingqwerty/ridingqwerty.h
new file mode 100644
index 000000000..ae5262567
--- /dev/null
+++ b/users/ridingqwerty/ridingqwerty.h
@@ -0,0 +1,37 @@
+#pragma once
+
+#include "quantum.h"
+#include "process_records.h"
+
+enum userspace_layers
+{
+ _QWERTY = 0,
+ _EDITOR,
+ _NUMBER,
+ _SYMBOL,
+ _F_KEYS,
+ _DEBUG,
+ _SECRET,
+ _FINAL
+};
+
+// modtaps
+#define LS_Z MT(MOD_LSFT, KC_Z)
+#define LC_ESC MT(MOD_LCTL, KC_ESC)
+#define LG_TAB MT(MOD_LGUI, KC_TAB)
+#define LA_LBRC MT(MOD_LALT, KC_LBRC)
+#define LS_RBRC MT(MOD_LSFT, KC_RBRC)
+#define RS_MINS MT(MOD_RSFT, KC_MINS)
+#define RA_EQL MT(MOD_RALT, KC_EQL)
+//RG_LMOT defined in process_records.h
+#define RC_ENT MT(MOD_RCTL, KC_ENT)
+#define RS_SLSH MT(MOD_RSFT, KC_SLSH)
+// layertaps
+#define ED_A LT(_EDITOR, KC_A)
+#define ED_ESC LT(_EDITOR, KC_ESC)
+#define NM_SCLN LT(_NUMBER, KC_SCLN)
+#define NM_BSPC LT(_NUMBER, KC_BSPC)
+#define SM_SPC LT(_SYMBOL, KC_SPC)
+#define SC_TAB LT(_SECRET, KC_TAB)
+#define FK_DOT LT(_F_KEYS, KC_DOT)
+
diff --git a/users/ridingqwerty/rules.mk b/users/ridingqwerty/rules.mk
new file mode 100644
index 000000000..9c3846744
--- /dev/null
+++ b/users/ridingqwerty/rules.mk
@@ -0,0 +1,8 @@
+#LEADER_ENABLE = yes
+
+SRC += ridingqwerty.c \
+ process_records.c
+
+ifneq ("$(wildcard $(USER_PATH)/secrets.c)","")
+ SRC += secrets.c
+endif