aboutsummaryrefslogtreecommitdiff
path: root/users/bocaj/bocaj.c
diff options
context:
space:
mode:
authorJacob Jerrell <jacob.jerrell@gmail.com>2019-01-02 11:23:42 -0600
committerDrashna Jaelre <drashna@live.com>2019-01-02 09:23:42 -0800
commita7b1b146d12cce1858db59c1d99ce84fb37fc59e (patch)
tree14f91e601dcc7ac41871824d698a6143344497fd /users/bocaj/bocaj.c
parent7b5fa4b13e332bab476b65565d63708b306d000a (diff)
downloadqmk_firmware-a7b1b146d12cce1858db59c1d99ce84fb37fc59e.tar.gz
qmk_firmware-a7b1b146d12cce1858db59c1d99ce84fb37fc59e.zip
Keymap: Bocaj Layout and Userspace Refactor (#4753)
* Bocaj Layout Revamp * Pull in Upstream (#1) * Various tweaks for some Input:Club build processes * change KEYMAP to LAYOUT for all new keyboards made using this script * Add support for rev3 of the Atom47 (#2672) * Added support for rev3 of the Atom47 * Updated Atom47 readme's * Fix redefine error on rev2 and add maartenwut's keymap * Fix redefine error on LEdiodes keymap * Add Nyquist keymap (#2692) * nyquist * danielhklein nyquist setup * shift left controls * remove readme * cleanup before pr * ready for pr * Adds Phantom TKL support (#2696) * Add an info.json to phantom keyboard * Add layouts - KEYMAP_WINKEYLESS - KEYMAP_7BIT - KEYMAP_ISO - KEYMAP_ISO_WINKEYLESS * Add key_counts * Add 2 missing F-Row keys * Add TKC1800 info.json Created an info.json for the tkc1800. * Clueboard 60 info.json - adds - LAYOUT_60_ansi - LAYOUT_60_iso - KEYMAP_AEK - KEYMAP - LAYOUT_60_ansi_split_bs_rshift * Add the Speedo keyboard * Fix KC60 info.json file (#2707) * change KEYMAP to LAYOUT in all the KC60 files * Redo the info.json file * Small fixes to TKC1800 - adjust F-row to use 0.25 spacing - split left shift - add key_count * Fix some Configurator Warnings regarding LAYOUT vs KEYMAP (#2708) * change diverge 3 KC_KEYMAP to LAYOUT * Change KEYMAP to LAYOUT for handwired arrow pad * change M10A to LAYOUT for m10-a * Change KC_KEYMAP to LAYOUT_kc and KEYMAP to LAYOUT for mf68 * change KC_KEYMAP to LAYOUT for nano * Refactor to LAYOUT * refactor to LAYOUT-ansi and LAYOUT_iso for s65 * LAYOUT conversions for lfkkeyboards * missed a few renames * mini1800 for lfkeyobards support of LAYOUT * Improve state/chord handling and clean up namespace Some values that can never, ever, change were held in local variables, rather than in PROGMEM. Fixed. Change "pressed" to a signed int so the test for < 0 makes sense, and to avoid possible weird failure modes in the case where a key release comes in when pressed is already zero. (Shouldn't happen, sure, but computers are weird.) A lot of things in process_steno had external linkage for no particular reason. They've been marked static. Stuff still builds. Distinguish between currently-held keys and keys that have been held, and expose these values through a nicely-named API so other code could, say, check on the current set of steno chording in order to make displays. Also in passing fix up the "state" value having external linkage so it could clash with other people's variable declarations. The API also provides hooks for key processing and steno chord events, so you can monitor those events without having to run in matrix_scan_user and recheck the values directly. Also document these. There is no path through processing a key that doesn't end with a return false, so the nested return foo() are gone and we just return false. * Pull information from config.h and rules.mk (#2711) * Pull information from config.h and rules.mk * Readd the kbd75 maintainer * Remove obsolete info.json entries (#2712) * Clean up some long-standing errors when populating the API (#2715) * More Configurator Warning Fixes (#2716) * mf68_ble did not have the correct .c and .h files * Fix JC65 KEYMAP to LAYOUT * Change KEYMAP to LAYOUT for s60_x * Convert KEYMAP to LAYOUT for lets_split boards * Convert KEYMAP to LAYOUT * more fixes to keymap for iris * convert KEYMAP to LAYOUT for levinson keyboard * change losinggeneration's KEYMAP to LAYOUT * convert KEYMAP to LAYOUT * convert KEYMAP to LAYOUT for nyquist * convert KEYMAP to LAYOUT * convert KEYMAP to LAYOUT for viterbi * convert KEYMAP to LAYOUT * convert KEYMAP and its subsidiries to the LAYOUT standard * convert KEYMAP and its subsidiries to the new LAYOUT standard * Normacos keymap for let's split keyboard (#2691) * Cheers let's split keymap * fixed typo on norman layer of cheers keymap for let's split * fixed right handed mappings for home row * cheers keymap for let's split redefinition * updated Cheers keymap for let's split * cheers keymap for let's split updated with some terminal macros * renamed cheers let's split keymap to a more appropriate normacos * updated normacos keymap doc / removed non functional keys * reset let's split rules to default values * added more spotlight search macros * normalized keymap comments * Moved numpad on lower layer * hhkb jp personal keymap (#2698) * Add JJ40 Cockpit personal keymap (#2713) * Add JJ40 Cockpit keymap * Fix lower layer symbols * Add readme for "major" keyboards to eliminate more QMK Configurator errors (#2718) * add readme to ktype keyboard * add readme to m10a * add readme to mini1800 * add readme to parent directory * Revert "Pull in Upstream (#1)" This reverts commit eeba0cec17ccb636e4225eed88aeae72b99f5e45. * Updates to Bocaj Files - Gave up on Tap Dance for ' -> ' + Added another 'Secret' + Add ' -> ' to the Swap Hands key + Add Swap Hands to the ' -> ' key + Made Hand Swapping a momentary toggle - Removed Auto Shift + Added Layer Toggle to KC_QUOTE for the _TOOLS layer - Disabled Tap Dance * Merge remote-tracking branch 'upstream/master' * Updates to Bocaj Added Game Layers, Removed Unused Macros * Removed 'secrets.h' * Updates to Bocaj Remove 'secrets'. Remove 'sendstring_workman.h' and set related layer back to qwerty due to macro compatibility issues * Total revisioning of keymap and layout structure * Missed readme.md file * Bocaj - Permissive Hold setting enabled * Switching from ErgoDox EZ centric configuration to the layout/user approach * Bocaj - Create Userspace and Ergodox layout * Update settings.json * Pushing local updates * Reverting .vscode/settings.json * Adds pretty_osx and _win wrappers * Utilize Windows and Mac Wrappers * Update layouts/community/ergodox/bocaj/keymap.c * Updates to Bocaj keymap.c - Extended pretty_osx and pretty_win wrappers to allow modification of the bottom rows and thumb clusters. - Fixed already wrapped layouts to align with the change - Wrapped _NUMS and _CLICKY layers with the _osx wrapper because I main with a Mac * Updates to Bocaj Small documentation updates, added KC_MAKE from Drashna's layout, added KC_LOCK back to the diablo layer. * Add LShift to _Adjust layer * Minor changes to bocaj Put wrappers in userspace and added RESET keycode to the Adjust layer * Updates to Bocaj config & keymap; Fixed problem with process_leader.c - Made lots of changes to the bocaj layout and userspace - Pulled in latest upstream/master - Attempted to compile with latest and found an unneccessary `break` in process_leader.c * Bocaj - Updates to Layout and Userspace * Adjust LEADER_TIMEOUT to 350 * Put KC_GRAVE on _ADJUST layer * Eliminate _LOWER layer and associated definitions * Adjusted layer indicating LEDs to match changes * Fixed Diablo leader sequence * Added build info leader sequence * Got rid of obsoleted IGNORE_MOD_TAP_INTERRUPT/PERMISSIVE_HOLD/PREVENT_STUCK_MODIFIERS (may add STRICT_LAYER_RELEASE in the future) * Remove type_traits Not sure what in my VSCode config always brings this one in * refactor stage 1 * Bocaj Refactor Phase II * Made LED_2 brighter if both CTRL & GUI are being held * Enabled unicode because I got it to work in Mac OS * Finalized Build Info leader combination after testing in Mac OS * Not sure why KC_D3_1 was set to ASDF if !TAP_DANCE_ENABLE. So I changed that back * Experienced issues with `EXTRAFLAGS += -flto` using Docker in MacOS. Not sure what it does, but I don't seem to be missing anything * Wrote obligatory readme.md files and mentioned Drashna too many times... I don't think I can actually take credit for much of anything here. * Updates to Bocaj Made LED changes, added LM_DFLT which is similar to the grave macro, enabled retro tapping, working on a unicode idea -- currently fails to build. * Bocaj Refactor Phase 3 Part 2 - Continuation of implementing unicode switching based on default layer - Slight adjustments to _DIABLO and base wrapper because LM_DFLT macro didn't function as I'd hoped * Slight adjustment to KC_MAKE
Diffstat (limited to 'users/bocaj/bocaj.c')
-rw-r--r--users/bocaj/bocaj.c200
1 files changed, 106 insertions, 94 deletions
diff --git a/users/bocaj/bocaj.c b/users/bocaj/bocaj.c
index 6df6e3bbf..689dbe7b4 100644
--- a/users/bocaj/bocaj.c
+++ b/users/bocaj/bocaj.c
@@ -1,14 +1,30 @@
1/*
2Copyright 2018 Jacob Jerrell <jacob.jerrell@gmail.com> @JacobJerrell
3
4This program is free software: you can redistribute it and/or modify
5it under the terms of the GNU General Public License as published by
6the Free Software Foundation, either version 2 of the License, or
7(at your option) any later version.
8
9This program is distributed in the hope that it will be useful,
10but WITHOUT ANY WARRANTY; without even the implied warranty of
11MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12GNU General Public License for more details.
13
14You should have received a copy of the GNU General Public License
15along with this program. If not, see <http://www.gnu.org/licenses/>.
16*/
17
1#include "bocaj.h" 18#include "bocaj.h"
2#include "eeprom.h"
3#include "version.h"
4#include "tap_dances.h"
5 19
6static uint16_t copy_paste_timer;
7userspace_config_t userspace_config; 20userspace_config_t userspace_config;
21#if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
22 #define BOCAJ_UNICODE_MODE UC_OSX
23#else
24 // set to 2 for UC_WIN, set to 4 for UC_WINC
25 #define BOCAJ_UNICODE_MODE 2
26#endif
8 27
9/* *** *** *** *** *
10 * Helper Functions *
11 * *** *** *** *** */
12void tap(uint16_t keycode){ register_code(keycode); unregister_code(keycode); }; 28void tap(uint16_t keycode){ register_code(keycode); unregister_code(keycode); };
13 29
14// Add reconfigurable functions here, for keymap customization 30// Add reconfigurable functions here, for keymap customization
@@ -36,10 +52,7 @@ bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
36} 52}
37 53
38__attribute__ ((weak)) 54__attribute__ ((weak))
39bool process_record_secrets(uint16_t keycode, keyrecord_t *record) { 55void matrix_scan_secrets(void) {}
40 return true;
41}
42
43 56
44__attribute__ ((weak)) 57__attribute__ ((weak))
45uint32_t layer_state_set_keymap (uint32_t state) { 58uint32_t layer_state_set_keymap (uint32_t state) {
@@ -57,7 +70,14 @@ void led_set_keymap(uint8_t usb_led) {}
57// Call user matrix init, set default RGB colors and then 70// Call user matrix init, set default RGB colors and then
58// call the keymap's init function 71// call the keymap's init function
59void matrix_init_user(void) { 72void matrix_init_user(void) {
60 userspace_config.raw = eeprom_read_byte(EECONFIG_USERSPACE); 73 userspace_config.raw = eeconfig_read_user();
74
75 #if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
76 set_unicode_input_mode(BOCAJ_UNICODE_MODE);
77 get_unicode_input_mode();
78 #endif //UNICODE_ENABLE
79
80
61 matrix_init_keymap(); 81 matrix_init_keymap();
62} 82}
63 83
@@ -78,6 +98,18 @@ void suspend_wakeup_init_user(void)
78 #endif 98 #endif
79} 99}
80 100
101void eeconfig_init_user(void) {
102 userspace_config.raw = 0;
103 eeconfig_update_user(userspace_config.raw);
104 #if (defined(UNICODE_ENABLE) || defined(UNICODEMAP_ENABLE) || defined(UCIS_ENABLE))
105 set_unicode_input_mode(BOCAJ_UNICODE_MODE);
106 get_unicode_input_mode();
107 #else
108 eeprom_update_byte(EECONFIG_UNICODEMODE, BOCAJ_UNICODE_MODE);
109 #endif
110}
111
112LEADER_EXTERNS();
81// No global matrix scan code, so just run keymap's matrix 113// No global matrix scan code, so just run keymap's matrix
82// scan function 114// scan function
83void matrix_scan_user(void) { 115void matrix_scan_user(void) {
@@ -86,6 +118,68 @@ void matrix_scan_user(void) {
86 has_ran_yet = true; 118 has_ran_yet = true;
87 startup_user(); 119 startup_user();
88 } 120 }
121 LEADER_DICTIONARY() {
122 leading = false;
123 leader_end();
124
125 // Mac Save (Leader -> s)
126 SEQ_ONE_KEY(KC_S) {
127 SEND_STRING(SS_LGUI("s"));
128 }
129
130 // Mac copy line down (Leader -> d, d)
131 SEQ_TWO_KEYS(KC_D, KC_D) {
132 register_code(KC_LSHIFT);
133 register_code(KC_HOME);
134 unregister_code(KC_HOME);
135 unregister_code(KC_LSHIFT);
136 SEND_STRING(SS_LGUI("c"));
137 tap(KC_END);
138 tap(KC_ENTER);
139 SEND_STRING(SS_LGUI("v"));
140 }
141
142 // Mac copy line up (Leader -> u, u)
143 SEQ_TWO_KEYS(KC_U, KC_U) {
144 register_code(KC_LSHIFT);
145 register_code(KC_HOME);
146 unregister_code(KC_HOME);
147 unregister_code(KC_LSHIFT);
148 SEND_STRING(SS_LGUI("c"));
149 tap(KC_UP);
150 tap(KC_END);
151 tap(KC_ENTER);
152 SEND_STRING(SS_LGUI("v"));
153 }
154
155 // Mac VS Debug
156 SEQ_ONE_KEY(KC_D) {
157 tap(KC_F5);
158 }
159
160 // Mac VS Stop Debug
161 SEQ_TWO_KEYS(KC_S, KC_D) {
162 register_code(KC_LSHIFT);
163 tap(KC_F5);
164 unregister_code(KC_LSHIFT);
165 }
166
167 // Start Diablo 3
168 SEQ_ONE_KEY(KC_3) {
169 SEND_STRING(SS_LCTRL(" "));
170 SEND_STRING("Diablo");
171 tap(KC_ENTER);
172 }
173
174 SEQ_ONE_KEY(KC_B) {
175 SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION " ");
176 tap(KC_ENTER);
177 SEND_STRING ("Built at: " QMK_BUILDDATE);
178 }
179#ifndef NO_SECRETS
180 matrix_scan_secrets();
181#endif // !NO_SECRETS
182 }
89 183
90#ifdef TAP_DANCE_ENABLE // Run Diablo 3 macro checking code. 184#ifdef TAP_DANCE_ENABLE // Run Diablo 3 macro checking code.
91 run_diablo_macro_check(); 185 run_diablo_macro_check();
@@ -93,85 +187,3 @@ void matrix_scan_user(void) {
93 187
94 matrix_scan_keymap(); 188 matrix_scan_keymap();
95} 189}
96
97bool process_record_user(uint16_t keycode, keyrecord_t *record) {
98 /* uint8_t default_layer = 0;
99 default_layer = eeconfig_read_default_layer(); */
100 switch (keycode) {
101 case JJ_COPY:
102 if (!record->event.pressed) {
103 SEND_STRING(SS_LGUI("c"));
104 }
105 return false;
106 break;
107 case JJ_PSTE:
108 if (!record->event.pressed) {
109 SEND_STRING(SS_LGUI("v"));
110 }
111 return false;
112 break;
113 case JJ_ARRW:
114 if (!record->event.pressed) {
115 SEND_STRING("->");
116 }
117 return false;
118 break; /*
119 case KC_SWRK:
120 if (!record->event.pressed) {
121 set_single_persistent_default_layer(_SWRKMN);
122 layer_move(default_layer);
123 //ergodox_blink_all_leds();
124 //ergodox_blink_all_leds();
125 }
126 return false;
127 break;
128 case KC_HWRK:
129 if (!record->event.pressed) {
130 set_single_persistent_default_layer(_HWRKMN);
131 layer_move(default_layer);
132 //ergodox_blink_all_leds();
133 //ergodox_blink_all_leds();
134 }
135 return false;
136 break;
137 case KC_EPRM:
138 if (!record->event.pressed) {
139 //ergodox_blink_all_leds();
140 eeconfig_init();
141 }
142 return false;
143 break;
144 case MC_LOCK:
145 if (!record->event.pressed) {
146 layer_move(default_layer);
147 SEND_STRING(SS_LCTRL(SS_LGUI("q")));
148 }
149 return false;
150 break; */
151 case KC_DCLR:
152#ifdef TAP_DANCE_ENABLE
153 if (record->event.pressed) {
154 uint8_t dtime;
155 for (dtime = 0; dtime < 4; dtime++) {
156 diablo_key_time[dtime] = diablo_times[0];
157 }
158 }
159#endif // !TAP_DANCE_ENABLE
160 return false;
161 break;
162 case KC_CCCV:
163 if (record->event.pressed) {
164 copy_paste_timer = timer_read();
165 } else {
166 if (timer_elapsed(copy_paste_timer) > TAPPING_TERM) { // Hold, copy
167 SEND_STRING(SS_LGUI("c"));
168 } else {
169 SEND_STRING(SS_LGUI("v"));
170 }
171 }
172 return false;
173 break;
174 }
175 return process_record_keymap(keycode, record);
176}
177