summaryrefslogtreecommitdiff
path: root/keyboards/gboards/gergoplex
diff options
context:
space:
mode:
Diffstat (limited to 'keyboards/gboards/gergoplex')
-rw-r--r--keyboards/gboards/gergoplex/gergoplex.c34
-rw-r--r--keyboards/gboards/gergoplex/gergoplex.h4
-rw-r--r--keyboards/gboards/gergoplex/keymaps/georgepetri/combos.def11
-rw-r--r--keyboards/gboards/gergoplex/keymaps/georgepetri/config.h31
-rw-r--r--keyboards/gboards/gergoplex/keymaps/georgepetri/gergoplex.def7
-rw-r--r--keyboards/gboards/gergoplex/keymaps/georgepetri/keymap.c212
-rw-r--r--keyboards/gboards/gergoplex/keymaps/georgepetri/readme.md6
-rw-r--r--keyboards/gboards/gergoplex/keymaps/georgepetri/rules.mk20
-rw-r--r--keyboards/gboards/gergoplex/keymaps/tgrosinger/combos.def11
-rw-r--r--keyboards/gboards/gergoplex/keymaps/tgrosinger/config.h4
-rw-r--r--keyboards/gboards/gergoplex/keymaps/tgrosinger/gergoplex.def17
-rw-r--r--keyboards/gboards/gergoplex/keymaps/tgrosinger/keymap.c286
-rw-r--r--keyboards/gboards/gergoplex/keymaps/tgrosinger/readme.md12
-rw-r--r--keyboards/gboards/gergoplex/keymaps/tgrosinger/rules.mk18
-rw-r--r--keyboards/gboards/gergoplex/matrix.c28
15 files changed, 19 insertions, 682 deletions
diff --git a/keyboards/gboards/gergoplex/gergoplex.c b/keyboards/gboards/gergoplex/gergoplex.c
index 1e44583895..b621201c16 100644
--- a/keyboards/gboards/gergoplex/gergoplex.c
+++ b/keyboards/gboards/gergoplex/gergoplex.c
@@ -39,30 +39,16 @@ uint8_t init_mcp23018(void) {
// - unused : input : 1
// - input : input : 1
// - driving : output : 0
- mcp23018_status = i2c_start(I2C_ADDR_WRITE, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(IODIRA, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(0b11000001, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(0b11111111, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- i2c_stop();
-
- // set pull-up
- // - unused : on : 1
- // - input : on : 1
- // - driving : off : 0
- mcp23018_status = i2c_start(I2C_ADDR_WRITE, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(GPPUA, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(0b11000001, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(0b11111111, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
+ uint8_t data[] = {0b11000001, 0b11111111};
+ mcp23018_status = i2c_writeReg(I2C_ADDR, IODIRA, data, sizeof(data), I2C_TIMEOUT);
+
+ if (!mcp23018_status) {
+ // set pull-up
+ // - unused : on : 1
+ // - input : on : 1
+ // - driving : off : 0
+ mcp23018_status = i2c_writeReg(I2C_ADDR, GPPUA, data, sizeof(data), I2C_TIMEOUT);
+ }
-out:
- i2c_stop();
return mcp23018_status;
}
diff --git a/keyboards/gboards/gergoplex/gergoplex.h b/keyboards/gboards/gergoplex/gergoplex.h
index 549228104a..217cb8dff1 100644
--- a/keyboards/gboards/gergoplex/gergoplex.h
+++ b/keyboards/gboards/gergoplex/gergoplex.h
@@ -25,9 +25,7 @@ extern i2c_status_t mcp23018_status;
#define XXX KC_NO
// I2C aliases and register addresses (see "mcp23018.md")
-#define I2C_ADDR 0x20 // 0b0100000
-#define I2C_ADDR_WRITE ((I2C_ADDR << 1) | I2C_WRITE)
-#define I2C_ADDR_READ ((I2C_ADDR << 1) | I2C_READ)
+#define I2C_ADDR (0x20 << 1) // 0b0100000
#define IODIRA 0x00 // i/o direction register
#define IODIRB 0x01
#define GPPUA 0x0C // GPIO pull-up resistor register
diff --git a/keyboards/gboards/gergoplex/keymaps/georgepetri/combos.def b/keyboards/gboards/gergoplex/keymaps/georgepetri/combos.def
deleted file mode 100644
index a9205c028a..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/georgepetri/combos.def
+++ /dev/null
@@ -1,11 +0,0 @@
-// List any combo dictionaries you want loaded to your device below!
-
-// QMK wide includes
-//#include "combos/germ-vim-helpers.def"
-#include "combos/germ-mouse-keys.def"
-
-// User includes
-#include "gergoplex.def"
-
-// Word completion
-// #include "combos/eng-combos.def"
diff --git a/keyboards/gboards/gergoplex/keymaps/georgepetri/config.h b/keyboards/gboards/gergoplex/keymaps/georgepetri/config.h
deleted file mode 100644
index e2c27583fa..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/georgepetri/config.h
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
-Copyright 2012 Jun Wako <wakojun@gmail.com>
-Copyright 2013 Oleg Kostyuk <cub.uanic@gmail.com>
-
-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/>.
-*/
-
-// Copy and worked on with love from the EZ team
-
-#pragma once
-
-#define HOLD_ON_OTHER_KEY_PRESS_PER_KEY
-
-#undef DEBOUNCE
-#define DEBOUNCE 25
-
-#define COMBO_ALLOW_ACTION_KEYS
-#define COMBO_VARIABLE_LEN
-
-#define TAPPING_TERM_PER_KEY
diff --git a/keyboards/gboards/gergoplex/keymaps/georgepetri/gergoplex.def b/keyboards/gboards/gergoplex/keymaps/georgepetri/gergoplex.def
deleted file mode 100644
index d50d431c8b..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/georgepetri/gergoplex.def
+++ /dev/null
@@ -1,7 +0,0 @@
-// Gergoplex specfic combos
-
-COMB(hjEnt, KC_ENT, KC_H, KC_J)
-COMB(loDel, KC_DEL, KC_L, KC_O)
-COMB(pscBspace, KC_BSPC, KC_P, KC_SCLN)
-COMB(sdEsc, KC_ESC, KC_D, KC_F)
-COMB(fgEsc, KC_ESC, KC_F, KC_G)
diff --git a/keyboards/gboards/gergoplex/keymaps/georgepetri/keymap.c b/keyboards/gboards/gergoplex/keymaps/georgepetri/keymap.c
deleted file mode 100644
index 44c570b42c..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/georgepetri/keymap.c
+++ /dev/null
@@ -1,212 +0,0 @@
-/* Copyright 2021 Jane Bernhardt
- *
- * 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/>.
- */
-
-/* Good on you for modifying your layout! if you don't have
- * time to read the QMK docs, a list of keycodes can be found at
- * https://github.com/qmk/qmk_firmware/blob/master/docs/keycodes.md
- */
-
-#include QMK_KEYBOARD_H
-#include "g/keymap_combo.h"
-
-enum {
- _ALPHA, // default
- _GAME, // gaming
- _SPECIAL, // special characters
- _NUMBERS // numbers/function/motion
-};
-
-typedef enum {
- TD_NONE,
- TD_UNKNOWN,
- TD_SINGLE_TAP,
- TD_DOUBLE_TAP,
- TD_TRIPLE_TAP
-} td_state_t;
-
-typedef struct {
- bool is_press_action;
- td_state_t state;
-} td_tap_t;
-
-enum {
- GAME
-};
-
-td_state_t cur_dance(tap_dance_state_t *state);
-
-void ql_finished(tap_dance_state_t *state, void *user_data);
-void ql_reset(tap_dance_state_t *state, void *user_data);
-
-#define KC_CTL_A MT(MOD_LCTL, KC_A) // Tap for A, hold for Control
-#define KC_SFT_Z MT(MOD_RSFT, KC_Z) // Tap for Z, hold for Shift
-#define KC_SFT_SL MT(MOD_RSFT, KC_SLSH) // Tap for slash, hold for Shift
-#define KC_SPE_SPC LT(_SPECIAL, KC_SPC) // Tap for Space, hold for Special layer
-#define KC_NUM_SPC LT(_NUMBERS, KC_SPC) // Tap for Space, hold for Numbers layer
-
- /* Combomap
- *
- * ,-------------------------------. ,-------------------------------.
- * | | | | | | | | | | | |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-DEL-+-BSPC--|
- * | | | ESC ESC | | ENT | | | |
- * |-------+-----+-----+-RMB-+-LMB-| |-----+-----+-----+-----+-------|
- * | | | | | | | | | | | |
- * `-------------------------------' `-------------------------------'
- * .-----------------. .-----------------.
- * | | | | | | | |
- * '-----------------' '-----------------'
- */
-
-const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
- /* Alpha layer
- *
- * ,-------------------------------. ,-------------------------------.
- * | Q | W | E | R | T | | Y | U | I | O | P |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | CTRL A| S | D | F | G | | H | J | K | L | ; |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | SHFT Z| X | C | V | B | | N | M | , | . |SHFT / |
- * `-------------------------------' `-------------------------------'
- * .----------------------. .----------------------.
- * | META | ALT | SPC SPE | | SPC NUM | TAB | SHFT |
- * '----------------------' '----------------------'
- */
- [_ALPHA] = LAYOUT_split_3x5_3(
- KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,
- KC_CTL_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN,
- KC_SFT_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, TD(GAME), KC_DOT, KC_SFT_SL,
- KC_LGUI, KC_LALT, KC_SPE_SPC, KC_NUM_SPC, KC_TAB, KC_RSFT),
-
- /* Gaming layer
- *
- * ,-------------------------------. ,-------------------------------.
- * | ~ | Q | W | E | R | | Y | U | I | O | P |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | CTRL | A | S | D | F | | H | J | K | L | ; |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | SHFT | Z | X | C | V | | N | M | , | . |SHFT / |
- * `-------------------------------' `-------------------------------'
- * .------------------. .----------------------.
- * | META | ALT | SPC | | SPC NUM | TAB | SHFT |
- * '------------------' '----------------------'
- */
- [_GAME] = LAYOUT_split_3x5_3(
- KC_TILD, KC_Q, KC_W, KC_E, KC_R, KC_Y, KC_U, KC_I, KC_O, KC_P,
- KC_LCTL , KC_A, KC_S, KC_D, KC_F, KC_H, KC_J, KC_K, KC_L, KC_SCLN,
- KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_N, KC_M, TD(GAME), KC_DOT, KC_SFT_SL,
- KC_LGUI, KC_LALT, KC_SPC, KC_NUM_SPC, KC_TAB, KC_RSFT),
-
- /* Special characters layer
- *
- * ,-------------------------------. ,-------------------------------.
- * | ! | @ | { | } | | | | ` | - | = | / | \ |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | # | $ | ( | ) | | | LFT | DWN | UP | RGT | ' |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | % | ^ | [ | ] | | | & | ~ | + | * | |
- * `-------------------------------' `-------------------------------'
- * .-------------------. .-----------------.
- * | | | | | | " | _ |
- * '-------------------' '-----------------'
- */
- [_SPECIAL] = LAYOUT_split_3x5_3(
- KC_EXLM, KC_AT, KC_LCBR, KC_RCBR, KC_PIPE, KC_GRV, KC_MINS, KC_EQL , KC_SLSH, KC_BSLS,
- KC_HASH, KC_DLR, KC_LPRN, KC_RPRN, KC_TRNS, KC_LEFT, KC_DOWN, KC_UP , KC_RGHT, KC_QUOT,
- KC_PERC, KC_CIRC, KC_LBRC, KC_RBRC, KC_TRNS, KC_AMPR, KC_TILD, KC_PLUS, KC_ASTR, KC_TRNS,
- KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, LSFT(KC_QUOTE), LSFT(KC_MINS)),
-
- /* Numbers/Function/Motion layer
- *
- * ,-------------------------------. ,-------------------------------.
- * | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | F1 | F2 | F3 | F4 | F5 | | | | | | |
- * |-------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | F6 | F7 | F8 | F9 | F10 | | MLFT| MDWN| MUP | MRGT| |
- * `-------------------------------' `-------------------------------'
- * .-----------------. .-----------------.
- * | F11 | F12 | | | | | |
- * '-----------------' '-----------------'
- */
- [_NUMBERS] = LAYOUT_split_3x5_3(
- KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,
- KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
- KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_MS_L, KC_MS_D, KC_MS_U, KC_MS_R, KC_TRNS,
- KC_F11, KC_F12, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS)
-};
-
-bool get_hold_on_other_key_press(uint16_t keycode, keyrecord_t *record) {
- switch (keycode) {
- case KC_CTL_A:
- return false;
- default:
- return true;
- }
-}
-
-td_state_t cur_dance(tap_dance_state_t *state) {
- if (state->count == 1)
- return TD_SINGLE_TAP;
- if (state->count == 2)
- return TD_DOUBLE_TAP;
- else if (state->count == 3)
- return TD_TRIPLE_TAP;
- return TD_UNKNOWN;
-}
-
-static td_tap_t ql_tap_state = {
- .is_press_action = true,
- .state = TD_NONE
-};
-
-void ql_finished(tap_dance_state_t *state, void *user_data) {
- ql_tap_state.state = cur_dance(state);
- switch (ql_tap_state.state) {
- case TD_SINGLE_TAP:
- tap_code(KC_COMMA);
- break;
- case TD_DOUBLE_TAP:
- tap_code(KC_COMMA);
- tap_code(KC_COMMA);
- break;
- case TD_TRIPLE_TAP:
- if (layer_state_is(_GAME))
- layer_off(_GAME);
- else
- layer_on(_GAME);
- break;
- default:
- break;
- }
-}
-
-void ql_reset(tap_dance_state_t *state, void *user_data) {
- ql_tap_state.state = TD_NONE;
-}
-
-tap_dance_action_t tap_dance_actions[] = {
- [GAME] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, ql_finished, ql_reset)
-};
-
-uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *record) {
- switch (keycode) {
- case QK_TAP_DANCE ... QK_TAP_DANCE_MAX:
- return 275;
- default:
- return TAPPING_TERM;
- }
-}
diff --git a/keyboards/gboards/gergoplex/keymaps/georgepetri/readme.md b/keyboards/gboards/gergoplex/keymaps/georgepetri/readme.md
deleted file mode 100644
index 7c8a6f2023..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/georgepetri/readme.md
+++ /dev/null
@@ -1,6 +0,0 @@
-# George Petri's Gergoplex layout
-Vim and programming focused layout.
-```
-qmk compile -kb gboards/gergoplex -km georgepetri
-qmk flash -kb gboards/gergoplex -km georgepetri
-```
diff --git a/keyboards/gboards/gergoplex/keymaps/georgepetri/rules.mk b/keyboards/gboards/gergoplex/keymaps/georgepetri/rules.mk
deleted file mode 100644
index 74d02c23bd..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/georgepetri/rules.mk
+++ /dev/null
@@ -1,20 +0,0 @@
-#----------------------------------------------------------------------------
-# make gboards/gergoplex:default:flash
-# Make sure you have dfu-programmer installed!
-#----------------------------------------------------------------------------
-
-#Debug options
-VERBOSE = no
-DEBUG_MATRIX_SCAN_RATE = no
-DEBUG_MATRIX = no
-CONSOLE_ENABLE = no
-
-#Combos!
-COMBO_ENABLE = yes
-VPATH += keyboards/gboards/
-
-ifeq ($(strip $(DEBUG_MATRIX)), yes)
- OPT_DEFS += -DDEBUG_MATRIX
-endif
-
-TAP_DANCE_ENABLE = yes
diff --git a/keyboards/gboards/gergoplex/keymaps/tgrosinger/combos.def b/keyboards/gboards/gergoplex/keymaps/tgrosinger/combos.def
deleted file mode 100644
index ef953d53f5..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/tgrosinger/combos.def
+++ /dev/null
@@ -1,11 +0,0 @@
-// List any combo dictionaries you want loaded to your device below!
-
-// QMK wide includes
-//#include "combos/germ-vim-helpers.def"
-//#include "combos/germ-mouse-keys.def"
-
-// User includes
-#include "gergoplex.def"
-
-// Word completion
-// #include "combos/eng-combos.def"
diff --git a/keyboards/gboards/gergoplex/keymaps/tgrosinger/config.h b/keyboards/gboards/gergoplex/keymaps/tgrosinger/config.h
deleted file mode 100644
index 1b30cc73b3..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/tgrosinger/config.h
+++ /dev/null
@@ -1,4 +0,0 @@
-#pragma once
-
-#define COMBO_ALLOW_ACTION_KEYS
-#define COMBO_VARIABLE_LEN
diff --git a/keyboards/gboards/gergoplex/keymaps/tgrosinger/gergoplex.def b/keyboards/gboards/gergoplex/keymaps/tgrosinger/gergoplex.def
deleted file mode 100644
index c7a93ed294..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/tgrosinger/gergoplex.def
+++ /dev/null
@@ -1,17 +0,0 @@
-// Gergoplex specfic combos
-
-COMB(qwGrav, KC_GRV, KC_W, KC_Q)
-COMB(wsEsc, KC_ESC, KC_W, KC_S)
-COMB(sdBackspace, KC_BSPC, KC_S, KC_D)
-COMB(dfTab, KC_TAB, KC_D, KC_F)
-COMB(cvEnter, KC_ENT, KC_C, KC_V)
-
-COMB(ioMinus, KC_MINS, KC_I, KC_O)
-COMB(opBackslash, KC_BSLS, KC_O, KC_P)
-COMB(hjLess, KC_LT, KC_H, KC_J)
-COMB(klGreat, KC_GT, KC_K, KC_L)
-COMB(jkColon, KC_COLN, KC_J, KC_K)
-COMB(mcUnder, KC_UNDS, KC_M, KC_COMM)
-COMB(nmQuote, KC_QUOT, KC_N, KC_M)
-
-SUBS(pasta, "I'd just like to interject for a moment.", KC_H, KC_J, KC_K, KC_L)
diff --git a/keyboards/gboards/gergoplex/keymaps/tgrosinger/keymap.c b/keyboards/gboards/gergoplex/keymaps/tgrosinger/keymap.c
deleted file mode 100644
index 74c0899fdb..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/tgrosinger/keymap.c
+++ /dev/null
@@ -1,286 +0,0 @@
-/* Copyright 2022 Tony Grosinger
- *
- * 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 "g/keymap_combo.h"
-
-enum {
- _ALPHA, // Default
- _SYMB, // Symbols
- _NUMB, // Numbers
- _ARROWS, // Arrows and OS
- _TMUX, // TMUX Nav layer
- _POPOS, // Gnome Shell, aka PopOS
-};
-
-
-// Macros
-enum custom_keycodes {
- TMUX_NEW = SAFE_RANGE,
- TMUX_ZOOM,
- TMUX_SCROLL,
- TMUX_PN_LT,
- TMUX_PN_UP,
- TMUX_PN_DN,
- TMUX_PN_RT,
- TMUX_WN_LT,
- TMUX_WN_RT,
- TMUX_SP_VT,
- TMUX_SP_HZ,
- VIM_CLIP_CP,
- VIM_CLIP_PST,
- VIM_MACRO,
-};
-
-bool process_record_user(uint16_t keycode, keyrecord_t *record) {
- switch (keycode) {
- case TMUX_NEW:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("c");
- }
- break;
- case TMUX_ZOOM:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("z");
- }
- break;
- case TMUX_SCROLL:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("[");
- }
- break;
- case TMUX_PN_LT:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- tap_code(KC_LEFT);
- }
- break;
- case TMUX_PN_DN:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- tap_code(KC_DOWN);
- }
- break;
- case TMUX_PN_UP:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- tap_code(KC_UP);
- }
- break;
- case TMUX_PN_RT:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- tap_code(KC_RIGHT);
- }
- break;
- case TMUX_WN_LT:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("p");
- }
- break;
- case TMUX_WN_RT:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("n");
- }
- break;
- case TMUX_SP_VT:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("%");
- }
- break;
- case TMUX_SP_HZ:
- if (record->event.pressed) {
- tap_code16(C(KC_B));
- SEND_STRING("\"");
- }
- break;
- case VIM_CLIP_CP:
- if (record->event.pressed) {
- tap_code16(S(KC_QUOTE));
- tap_code16(S(KC_EQUAL));
- tap_code(KC_Y);
- }
- break;
- case VIM_CLIP_PST:
- if (record->event.pressed) {
- tap_code16(S(KC_QUOTE));
- tap_code16(S(KC_EQUAL));
- tap_code(KC_P);
- }
- break;
- case VIM_MACRO:
- if (record->event.pressed) {
- tap_code16(S(KC_2));
- tap_code(KC_Q);
- }
- break;
- /*
- case LAYRMOD:
- // Act as a mod key if held, or toggle a layer if tapped
- // replace KC_LCTL with desired mod, and _TARGET with desired layer name / number
- if (record->event.pressed) {
- uint8_t key_timer = timer_read();
- register_mods(MOD_BIT(KC_LCTL));
- } else {
- unregister_mods(MOD_BIT(KC_LCTL));
- if (timer_elapsed(key_timer) < 200) {
- layer_invert(_TARGET);
- }
- }
- return false;
- break;
- */
- }
- return true;
-}
-
-/* Combos
- *
- * ,-----------------------------. ,-----------------------------.
- * | ` | | | | | | MINS | BSLH |
- * |-----+----ESC----+-----+-----| |-----+-----+-----+-----------|
- * | | BSPC TAB | | | LES COLN GRT | |
- * |-----+-----+-----+--RMB+-LMB-| |-----+-----+-----+-----------|
- * | | | ENT | | | QUO UNDR | | |
- * `-----+-----+-----+-----+-----' `-----------------------------'
- * .-------------------------. .-------------------.
- * | | | | | | | |
- * '-------------------------' '-------------------'
- */
-
-const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
- /* Keymap 0: Default layer
- * ,------------------------------. ,----------------------------------.
- * | Q | W | E | R | T | | Y | U | I | O | P |
- * |------+-----+-----+-----+-----| |-----+-----+-----+-------+--------|
- * |CTRL/A| S | D | F | G | | H | J | K | L | CTRL/; |
- * |------+-----+-----+-----+-----| |-----+-----+-----+-------+--------|
- * |SHFT/Z|ALT/X| C | V | B | | N | M | < | ALT/> | SHFT/? |
- * `------+-----+-----+------+----' `----------------------------------'
- * .-----------------. .----------------------.
- * | |GUI |SPC(NUM)| |SPC(SYM)|TMUX | PopOS |
- * '-----------------' '----------------------'
- */
- [_ALPHA] = LAYOUT_split_3x5_3(
- KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,
- MT(MOD_LCTL, KC_A),KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, MT(MOD_LCTL, KC_SCLN),
- MT(MOD_LSFT, KC_Z),MT(MOD_LALT, KC_X), KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, MT(MOD_LALT, KC_DOT), MT(MOD_RSFT, KC_SLSH),
-
- KC_NO, KC_LGUI, LT(_NUMB, KC_SPC), // Left
- LT(_SYMB, KC_SPC), MO(_TMUX), MO(_POPOS) // Right
- ),
-
- /* Keymap 1: Symbols layer
- * ,------------------------------. ,-------------------------------.
- * | ! | @ | # | $ | % | | ^ | & | * | + | = |
- * |------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | F1 | F2 | F3 | F4 | F5 | | F6 | F7 | F8 | F9 | F10 |
- * |------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | | | | | | | | | | F11 | F12 |
- * `------+-----+-----+-----+-----' `-------------------------------'
- * .-----------------. .-----------------.
- * | | DEL | MO3 | | HLD | SPC | |
- * '-----------------' '-----------------'
- */
- [_SYMB] = LAYOUT_split_3x5_3(
- KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_PLUS, KC_EQL,
- KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10,
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_F11, KC_F12,
- KC_NO, KC_DEL, MO(_ARROWS), KC_TRNS, KC_SPC, KC_NO
- ),
-
- /* Keymap 2: Number layer
- * ,------------------------------. ,-------------------------------.
- * | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 |
- * |------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | CTRL | | ( | ) | | | | 4 | 7 | 6 | |
- * |------+-----+-----+-----+-----| |-----+-----+-----+-----+-------|
- * | SHFT | | [ | ] | | | | 1 | 2 | 3 | . |
- * `------+-----+-----+-----+-----' `-------------------------------'
- * .-----------------. .-----------------.
- * | | | HLD | | MO3 | 0 | |
- * '-----------------' '-----------------'
- */
- [_NUMB] = LAYOUT_split_3x5_3(
- KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,
- KC_LCTL, KC_NO, KC_LPRN, KC_RPRN, KC_NO, KC_NO, KC_4, KC_5, KC_6, KC_NO,
- KC_LSFT, KC_NO, KC_LBRC, KC_RBRC, KC_NO, KC_NO, KC_1, KC_2, KC_3, KC_DOT,
- KC_NO,KC_NO,KC_TRNS, MO(_ARROWS),KC_0,KC_NO
- ),
-
- /* Keymap 3: Arrows and OS
- * ,------------------------------. ,------------------------------------.
- * | | | | | | | | | | | |
- * |------+-----+-----+-----+-----| |-------+-------+------+-------+-----|
- * | CTRL |HOME | PUP | | | | LEFT | DOWN | UP | RIGHT | |
- * |------+-----+-----+-----+-----| |-------+-------+------+-------+-----|
- * | SHFT |END | PDN | | | | | | | | |
- * `------+-----+-----+-----+-----' `------------------------------------'
- * .-----------------. .-----------------.
- * | | | HLD | | HLD | | |
- * '-----------------' '-----------------'
- */
- [_ARROWS] = LAYOUT_split_3x5_3(
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
- KC_LCTL, KC_HOME, KC_PGUP, KC_NO, KC_NO, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_NO,
- KC_LSFT, KC_END, KC_PGDN, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
- KC_NO,KC_NO,KC_TRNS, KC_TRNS,KC_NO,KC_NO
- ),
-
- /* Keymap 4: Tmux navigation layer
- * ,----------------------------------. ,---------------------------------------.
- * | Vi Mcr | | | | SP VT | | Vi Ynk| | | | Vi PT |
- * |--------+-----+-----+-----+-------| |-------+-------+-------+-------+-------|
- * | | SCRL| | | | | PN LT | PN DN | PN UP | PN RT | SP HZ |
- * |--------+-----+-----+-----+-------| |-------+-------+-------+-------+-------|
- * | ZOOM | KILL| NEW | | | | W LT | | | W RT | |
- * `--------+-----+-----+-----+-------' `---------------------------------------'
- * .-----------------. .-----------------.
- * | | | | | | HLD | |
- * '-----------------' '-----------------'
- */
- [_TMUX] = LAYOUT_split_3x5_3(
- VIM_MACRO, KC_NO, KC_NO, KC_NO, TMUX_SP_VT, VIM_CLIP_CP, KC_NO, KC_NO, KC_NO, VIM_CLIP_PST,
- KC_NO, TMUX_SCROLL, KC_NO, KC_NO, KC_NO, TMUX_PN_LT, TMUX_PN_DN, TMUX_PN_UP, TMUX_PN_RT, TMUX_SP_HZ,
- TMUX_ZOOM, KC_NO, TMUX_NEW, KC_NO, KC_NO, TMUX_WN_LT, KC_NO, KC_NO, TMUX_WN_RT, KC_NO,
- KC_NO,KC_NO,KC_NO, KC_NO,KC_TRNS,KC_NO
- ),
-
- /* Keymap 5: Gnome Shell (PopOS)
- * ,------------------------------. ,--------------------------------------.
- * | | | | | | | MV-DWN| D-DWN | D-UP | MV-UP | Flip |
- * |------+-----+-----+-----+-----| |-------+-------+-------+-------+------|
- * | | | | | | | W-L | W-DWN | W-UP | W-R | |
- * |------+-----+-----+-----+-----| |-------+-------+-------+-------+------|
- * | | | | | | | Scrns | Apps | Close | | |
- * `------+-----+-----+-----+-----' `--------------------------------------'
- * .-----------------. .-----------------.
- * | | | | | | | HLD |
- * '-----------------' '-----------------'
- */
- [_POPOS] = LAYOUT_split_3x5_3(
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, SGUI(KC_J), LCTL(LGUI(KC_J)), LCTL(LGUI(KC_K)), SGUI(KC_K), LGUI(KC_O),
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, LGUI(KC_H), LGUI(KC_J), LGUI(KC_K), LGUI(KC_L), KC_NO,
- KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, LGUI(KC_D), LGUI(KC_A), LGUI(KC_Q), KC_NO, KC_NO,
- KC_NO,KC_NO,KC_NO, KC_NO,KC_NO,KC_TRNS
- ),
-};
diff --git a/keyboards/gboards/gergoplex/keymaps/tgrosinger/readme.md b/keyboards/gboards/gergoplex/keymaps/tgrosinger/readme.md
deleted file mode 100644
index 0a53aa1cbf..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/tgrosinger/readme.md
+++ /dev/null
@@ -1,12 +0,0 @@
-# GergoPlex
-
-This keymap I created for the GergoPlex with a focus on:
-
-- Keeping keys close to their normal locations when possible (number/symbol rows)
-- Work well for vim, tmux, and Ubuntu default desktop shortcuts
-- Work okay for OSx shortcuts
-
-## Firmware Building
-
- util/docker_build.sh gboards/gergoplex:tgrosinger
- util/docker_build.sh gboards/gergoplex:tgrosinger:flash
diff --git a/keyboards/gboards/gergoplex/keymaps/tgrosinger/rules.mk b/keyboards/gboards/gergoplex/keymaps/tgrosinger/rules.mk
deleted file mode 100644
index 620cab16c0..0000000000
--- a/keyboards/gboards/gergoplex/keymaps/tgrosinger/rules.mk
+++ /dev/null
@@ -1,18 +0,0 @@
-#----------------------------------------------------------------------------
-# make gboards/gergoplex:default:flash
-# Make sure you have dfu-programmer installed!
-#----------------------------------------------------------------------------
-
-#Debug options
-VERBOSE = no
-DEBUG_MATRIX_SCAN_RATE = no
-DEBUG_MATRIX = no
-CONSOLE_ENABLE = no
-
-#Combos!
-COMBO_ENABLE = yes
-VPATH += keyboards/gboards/
-
-ifeq ($(strip $(DEBUG_MATRIX)), yes)
- OPT_DEFS += -DDEBUG_MATRIX
-endif
diff --git a/keyboards/gboards/gergoplex/matrix.c b/keyboards/gboards/gergoplex/matrix.c
index c9f5528b74..9437b24377 100644
--- a/keyboards/gboards/gergoplex/matrix.c
+++ b/keyboards/gboards/gergoplex/matrix.c
@@ -177,20 +177,12 @@ static matrix_row_t read_cols(uint8_t row) {
if (mcp23018_status) { // if there was an error
return 0;
} else {
- uint8_t data = 0;
- mcp23018_status = i2c_start(I2C_ADDR_READ, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_read_nack(I2C_TIMEOUT);
- if (mcp23018_status < 0) goto out;
- data = ~((uint8_t)mcp23018_status);
- mcp23018_status = I2C_STATUS_SUCCESS;
- out:
- i2c_stop();
-
+ uint8_t data = 0;
+ mcp23018_status = i2c_receive(I2C_ADDR, &data, 1, I2C_TIMEOUT);
#ifdef DEBUG_MATRIX
- if (data != 0x00) xprintf("I2C: %d\n", data);
+ if (~data != 0x00) xprintf("I2C: %d\n", ~data);
#endif
- return data;
+ return ~data;
}
} else {
return ~((((PINF & COL4) >> 1) | ((PINF & (COL1 | COL2 | COL3)) >> 3)) & 0xF);
@@ -213,14 +205,10 @@ static void select_row(uint8_t row) {
// select on mcp23018
if (mcp23018_status) { // do nothing on error
} else { // set active row low : 0 // set other rows hi-Z : 1
- mcp23018_status = i2c_start(I2C_ADDR_WRITE, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(GPIOA, I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- mcp23018_status = i2c_write(0xFF & ~(1 << (row + 1)), I2C_TIMEOUT);
- if (mcp23018_status) goto out;
- out:
- i2c_stop();
+ uint8_t data;
+ data = 0xFF & ~(1 << (row + 1));
+ mcp23018_status = i2c_writeReg(I2C_ADDR, GPIOA, &data, 1, I2C_TIMEOUT);
+
}
} else {
setPinOutput(row_pins[row - MATRIX_ROWS_PER_SIDE]);