385 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			385 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Copyright 2015-2017 Jack Humbert
 | 
						|
 *           2020 Niclas Meyer
 | 
						|
 *
 | 
						|
 * 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
 | 
						|
 | 
						|
#define K(kc) (1ull<<((kc) - ALPHA))
 | 
						|
 | 
						|
#define KALPHA   K(ALPHA)
 | 
						|
#define KBETA    K(BETA)
 | 
						|
#define KGAMMA   K(GAMMA)
 | 
						|
#define KDELTA   K(DELTA)
 | 
						|
#define KEPSILON K(EPSILON)
 | 
						|
#define KZETA    K(ZETA)
 | 
						|
#define KTHETA   K(THETA)
 | 
						|
#define KIOTA    K(IOTA)
 | 
						|
#define KKAPPA   K(KAPPA)
 | 
						|
 | 
						|
enum keys {
 | 
						|
    ALPHA = SAFE_RANGE,
 | 
						|
    BETA,
 | 
						|
    GAMMA,
 | 
						|
    DELTA,
 | 
						|
    EPSILON,
 | 
						|
    ZETA,
 | 
						|
    THETA,
 | 
						|
    IOTA,
 | 
						|
    KAPPA,
 | 
						|
    LOCK,
 | 
						|
    NONE,
 | 
						|
};
 | 
						|
 | 
						|
enum layers {
 | 
						|
    NORMAL,
 | 
						|
    QWERTY,
 | 
						|
    GAME,
 | 
						|
    LOWER,
 | 
						|
    RAISE,
 | 
						|
    PHI,
 | 
						|
    FN,
 | 
						|
};
 | 
						|
 | 
						|
#define XXXX KC_NO
 | 
						|
#define ____ KC_TRNS
 | 
						|
 | 
						|
#define CQWER LM(QWERTY, MOD_LCTL)
 | 
						|
#define AQWER LM(QWERTY, MOD_LALT)
 | 
						|
 | 
						|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
						|
    [NORMAL] = LAYOUT_planck_grid(
 | 
						|
        ALPHA,   BETA,  GAMMA, DELTA,  ____,  ____, ____, ____,  DELTA,  GAMMA, BETA, ALPHA,
 | 
						|
        EPSILON, ZETA,  THETA, IOTA,   ____,  ____, ____, ____,  IOTA,   THETA, ZETA, EPSILON,
 | 
						|
        ____,    ____,  ____,  ____,   ____,  ____, ____, ____,  ____,   ____, ____,  ____,
 | 
						|
        MO(PHI), CQWER, AQWER, MO(FN), KAPPA, ____, XXXX, KAPPA, MO(FN), ____, ____,  MO(PHI)
 | 
						|
    ),
 | 
						|
    [QWERTY] = LAYOUT_planck_grid(
 | 
						|
        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_ESC,  KC_A,    KC_S,    KC_D,    KC_F,      KC_G,   KC_H, KC_J,      KC_K,    KC_L,    KC_SCLN, KC_QUOT,
 | 
						|
        KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,      KC_B,   KC_N, KC_M,      KC_COMM, KC_DOT,  KC_SLSH, KC_SFTENT,
 | 
						|
        MO(PHI), KC_LCTL, KC_LALT, KC_LGUI, MO(LOWER), KC_SPC, XXXX, MO(RAISE), KC_LEFT, KC_DOWN, KC_UP,   KC_RIGHT
 | 
						|
    ),
 | 
						|
    [GAME] = LAYOUT_planck_grid(
 | 
						|
        KC_ESC,  KC_1, KC_2, KC_3, KC_4,   KC_5, KC_Y, KC_U, KC_I,    KC_O,   KC_P,    KC_BSPC,
 | 
						|
        KC_TAB,  KC_Q, KC_W, KC_E, KC_R,   KC_T, KC_H, KC_J, KC_K,    KC_L,   KC_SCLN, KC_QUOT,
 | 
						|
        KC_LSFT, KC_A, KC_S, KC_D, KC_F,   KC_G, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_ENT,
 | 
						|
        KC_LCTL, KC_Z, KC_X, KC_C, KC_SPC, ____, XXXX, ____, KC_V,    KC_B,   ____,    MO(PHI)
 | 
						|
    ),
 | 
						|
    [LOWER] = LAYOUT_planck_grid(
 | 
						|
        KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL,
 | 
						|
        KC_DEL,  ____,    ____,   ____,    ____,  ____,    ____,    KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE,
 | 
						|
        ____,    ____,    ____,   ____,    ____,  ____,    ____,    KC_PGUP, KC_PGDN, KC_HOME, KC_END,  ____,
 | 
						|
        ____,    ____,    ____,   ____,    ____,  ____,    XXXX,    ____,    KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY
 | 
						|
    ),
 | 
						|
    [RAISE] = LAYOUT_planck_grid(
 | 
						|
        KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7,    KC_8,    KC_9,    KC_0,    KC_DEL,
 | 
						|
        KC_DEL, ____, ____, ____, ____, ____, ____, KC_MINS, KC_EQL,  KC_LBRC, KC_RBRC, KC_BSLS,
 | 
						|
        ____,   ____, ____, ____, ____, ____, ____, KC_PGUP,  KC_PGDN, KC_HOME, KC_END, ____,
 | 
						|
        ____,   ____, ____, ____, ____, ____, XXXX, ____,    KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY
 | 
						|
    ),
 | 
						|
    [PHI] = LAYOUT_planck_grid(
 | 
						|
        RESET, KC_F1,   KC_F2,   KC_F3,  KC_F4,  ____, ____, ____,       ____,       ____,     ____,    KC_DEL,
 | 
						|
        ____,  KC_F5,   KC_F6,   KC_F7,  KC_F8,  ____, ____, DF(QWERTY), DF(NORMAL), DF(GAME), ____,    KC_F13,
 | 
						|
        ____,  KC_F9,   KC_F10,  KC_F11, KC_F12, ____, ____, ____,       ____,       ____,     ____,    ____,
 | 
						|
        ____,  RGB_TOG, RGB_MOD, ____,   ____,   ____, XXXX, ____,       KC_MNXT,    KC_VOLD,  KC_VOLU, KC_MPLY
 | 
						|
    ),
 | 
						|
    [FN] = LAYOUT_planck_grid(
 | 
						|
        ____,    ____,    KC_UP,   ____,     ____, ____, ____, ____, ____,    KC_UP,   ____,     ____,
 | 
						|
        KC_DEL,  KC_LEFT, KC_DOWN, KC_RIGHT, ____, ____, ____, ____, KC_LEFT, KC_DOWN, KC_RIGHT, KC_DEL,
 | 
						|
        KC_HOME, KC_END,  KC_PGUP, KC_PGDN,  ____, ____, ____, ____, KC_PGDN, KC_PGUP, KC_HOME,  KC_END,
 | 
						|
        ____,    ____,    ____,    ____,     ____, ____, XXXX, ____, ____,    ____,    ____,     ____
 | 
						|
    ),
 | 
						|
};
 | 
						|
 | 
						|
static uint16_t left_chord = 0;
 | 
						|
static uint16_t right_chord = 0;
 | 
						|
 | 
						|
static bool locking = false;
 | 
						|
static bool locked = false;
 | 
						|
static uint16_t mods = 0;
 | 
						|
 | 
						|
#define PROCESS_MOD(mod)                                 \
 | 
						|
    do {                                                 \
 | 
						|
        if ((mods & MOD_##mod) && !(keys & MOD_##mod)) { \
 | 
						|
            unregister_code16(KC_##mod);                 \
 | 
						|
        }                                                \
 | 
						|
        if (!(mods & MOD_##mod) && (keys & MOD_##mod)) { \
 | 
						|
            register_code16(KC_##mod);                   \
 | 
						|
        }                                                \
 | 
						|
    } while (0)
 | 
						|
 | 
						|
static void process_keys(uint16_t keys) {
 | 
						|
    if (keys == NONE) {
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    if (keys == LOCK) {
 | 
						|
        locking = !locking;
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    if ((keys & QK_ONE_SHOT_MOD) == QK_ONE_SHOT_MOD) {
 | 
						|
        PROCESS_MOD(LCTL);
 | 
						|
        PROCESS_MOD(LSFT);
 | 
						|
        PROCESS_MOD(LALT);
 | 
						|
        PROCESS_MOD(LGUI);
 | 
						|
 | 
						|
        mods = keys & ~QK_ONE_SHOT_MOD;
 | 
						|
        locked = false;
 | 
						|
 | 
						|
        if (locking) {
 | 
						|
            locking = false;
 | 
						|
            locked  = true;
 | 
						|
        }
 | 
						|
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    // Normal key
 | 
						|
    tap_code16(keys);
 | 
						|
    locking = false;
 | 
						|
 | 
						|
    if (mods && !locked) {
 | 
						|
        if (mods & MOD_LCTL) {
 | 
						|
            unregister_code16(KC_LCTL);
 | 
						|
        }
 | 
						|
 | 
						|
        if (mods & MOD_LSFT) {
 | 
						|
            unregister_code16(KC_LSFT);
 | 
						|
        }
 | 
						|
 | 
						|
        if (mods & MOD_LALT) {
 | 
						|
            unregister_code16(KC_LALT);
 | 
						|
        }
 | 
						|
 | 
						|
        if (mods & MOD_LGUI) {
 | 
						|
            unregister_code16(KC_LGUI);
 | 
						|
        }
 | 
						|
 | 
						|
        mods = 0;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
static uint16_t chord_to_keys(uint16_t chord) {
 | 
						|
    switch (chord) {
 | 
						|
        // Unshifted Extra
 | 
						|
        case KKAPPA:                            return KC_SPC;
 | 
						|
        case KEPSILON | KZETA | KTHETA | KIOTA: return KC_ENT;
 | 
						|
        case KEPSILON | KZETA | KGAMMA | KIOTA: return KC_TAB;
 | 
						|
        case KEPSILON | KIOTA:                  return KC_BSPC;
 | 
						|
        case KKAPPA | KEPSILON:                 return KC_ESC;
 | 
						|
 | 
						|
        // Shifted Extra
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KTHETA | KIOTA: return S(KC_ENT);
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KGAMMA | KIOTA: return S(KC_TAB);
 | 
						|
        case KKAPPA | KEPSILON | KIOTA:                  return S(KC_BSPC);
 | 
						|
 | 
						|
        // Lowercase Letters
 | 
						|
        case KBETA:                   return KC_A;
 | 
						|
        case KZETA | KDELTA:          return KC_B;
 | 
						|
        case KBETA | KGAMMA | KDELTA: return KC_C;
 | 
						|
        case KZETA | KTHETA | KIOTA:  return KC_D;
 | 
						|
        case KDELTA:                  return KC_E;
 | 
						|
        case KGAMMA | KIOTA:          return KC_F;
 | 
						|
        case KBETA | KTHETA:          return KC_G;
 | 
						|
        case KZETA | KTHETA:          return KC_H;
 | 
						|
        case KGAMMA:                  return KC_I;
 | 
						|
        case KBETA | KGAMMA | KIOTA:  return KC_J;
 | 
						|
        case KBETA | KTHETA | KIOTA:  return KC_K;
 | 
						|
        case KBETA | KGAMMA:          return KC_L;
 | 
						|
        case KBETA | KDELTA:          return KC_M;
 | 
						|
        case KZETA:                   return KC_N;
 | 
						|
        case KTHETA:                  return KC_O;
 | 
						|
        case KZETA | KGAMMA:          return KC_P;
 | 
						|
        case KBETA | KTHETA | KDELTA: return KC_Q;
 | 
						|
        case KGAMMA | KDELTA:         return KC_R;
 | 
						|
        case KTHETA | KIOTA:          return KC_S;
 | 
						|
        case KIOTA:                   return KC_T;
 | 
						|
        case KZETA | KIOTA:           return KC_U;
 | 
						|
        case KTHETA | KDELTA:         return KC_V;
 | 
						|
        case KZETA | KGAMMA | KIOTA:  return KC_W;
 | 
						|
        case KZETA | KTHETA | KDELTA: return KC_X;
 | 
						|
        case KBETA | KIOTA:           return KC_Y;
 | 
						|
        case KZETA | KGAMMA | KDELTA: return KC_Z;
 | 
						|
 | 
						|
        // Uppercase Letters
 | 
						|
        case KKAPPA | KBETA:                   return S(KC_A);
 | 
						|
        case KKAPPA | KZETA | KDELTA:          return S(KC_B);
 | 
						|
        case KKAPPA | KBETA | KGAMMA | KDELTA: return S(KC_C);
 | 
						|
        case KKAPPA | KZETA | KTHETA | KIOTA:  return S(KC_D);
 | 
						|
        case KKAPPA | KDELTA:                  return S(KC_E);
 | 
						|
        case KKAPPA | KGAMMA | KIOTA:          return S(KC_F);
 | 
						|
        case KKAPPA | KBETA | KTHETA:          return S(KC_G);
 | 
						|
        case KKAPPA | KZETA | KTHETA:          return S(KC_H);
 | 
						|
        case KKAPPA | KGAMMA:                  return S(KC_I);
 | 
						|
        case KKAPPA | KBETA | KGAMMA | KIOTA:  return S(KC_J);
 | 
						|
        case KKAPPA | KBETA | KTHETA | KIOTA:  return S(KC_K);
 | 
						|
        case KKAPPA | KBETA | KGAMMA:          return S(KC_L);
 | 
						|
        case KKAPPA | KBETA | KDELTA:          return S(KC_M);
 | 
						|
        case KKAPPA | KZETA:                   return S(KC_N);
 | 
						|
        case KKAPPA | KTHETA:                  return S(KC_O);
 | 
						|
        case KKAPPA | KZETA | KGAMMA:          return S(KC_P);
 | 
						|
        case KKAPPA | KBETA | KTHETA | KDELTA: return S(KC_Q);
 | 
						|
        case KKAPPA | KGAMMA | KDELTA:         return S(KC_R);
 | 
						|
        case KKAPPA | KTHETA | KIOTA:          return S(KC_S);
 | 
						|
        case KKAPPA | KIOTA:                   return S(KC_T);
 | 
						|
        case KKAPPA | KZETA | KIOTA:           return S(KC_U);
 | 
						|
        case KKAPPA | KTHETA | KDELTA:         return S(KC_V);
 | 
						|
        case KKAPPA | KZETA | KGAMMA | KIOTA:  return S(KC_W);
 | 
						|
        case KKAPPA | KZETA | KTHETA | KDELTA: return S(KC_X);
 | 
						|
        case KKAPPA | KBETA | KIOTA:           return S(KC_Y);
 | 
						|
        case KKAPPA | KZETA | KGAMMA | KDELTA: return S(KC_Z);
 | 
						|
 | 
						|
        // Unshifted Numbers
 | 
						|
        case KEPSILON | KZETA:                  return KC_0;
 | 
						|
        case KEPSILON | KZETA | KIOTA:          return KC_1;
 | 
						|
        case KEPSILON | KZETA | KTHETA:         return KC_2;
 | 
						|
        case KEPSILON | KBETA:                  return KC_3;
 | 
						|
        case KEPSILON | KBETA | KDELTA:         return KC_4;
 | 
						|
        case KEPSILON | KBETA | KGAMMA:         return KC_5;
 | 
						|
        case KEPSILON | KBETA | KIOTA:          return KC_6;
 | 
						|
        case KEPSILON | KTHETA:                 return KC_7;
 | 
						|
        case KEPSILON | KBETA | KGAMMA | KIOTA: return KC_8;
 | 
						|
        case KEPSILON | KGAMMA | KDELTA:        return KC_9;
 | 
						|
 | 
						|
        // Shifted Numbers
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KIOTA:          return KC_EXLM;
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KTHETA:         return KC_AT;
 | 
						|
        case KKAPPA | KEPSILON | KBETA:                  return KC_HASH;
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KDELTA:         return KC_DLR;
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KGAMMA:         return KC_PERC;
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KIOTA:          return KC_CIRC;
 | 
						|
        case KKAPPA | KEPSILON | KTHETA:                 return KC_AMPR;
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KGAMMA | KIOTA: return KC_ASTR;
 | 
						|
        case KKAPPA | KEPSILON | KGAMMA | KDELTA:        return KC_LPRN;
 | 
						|
        case KKAPPA | KEPSILON | KZETA:                  return KC_RPRN;
 | 
						|
 | 
						|
        // Unshifted Symbols
 | 
						|
        case KEPSILON | KBETA | KTHETA | KIOTA:  return KC_MINS;
 | 
						|
        case KEPSILON | KZETA | KTHETA | KDELTA: return KC_EQL;
 | 
						|
        case KEPSILON | KZETA | KGAMMA:          return KC_LBRC;
 | 
						|
        case KEPSILON | KGAMMA | KIOTA:          return KC_RBRC;
 | 
						|
        case KEPSILON | KBETA | KTHETA:          return KC_BSLS;
 | 
						|
        case KEPSILON | KBETA | KGAMMA | KDELTA: return KC_SCLN;
 | 
						|
        case KEPSILON | KZETA | KDELTA:          return KC_QUOT;
 | 
						|
        case KEPSILON | KTHETA | KIOTA:          return KC_COMM;
 | 
						|
        case KEPSILON | KZETA | KGAMMA | KDELTA: return KC_DOT;
 | 
						|
        case KEPSILON | KGAMMA:                  return KC_SLSH;
 | 
						|
        case KEPSILON | KDELTA:                  return KC_GRV;
 | 
						|
 | 
						|
        // Shifted Symbols
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KTHETA | KIOTA:  return KC_UNDS;
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KTHETA | KDELTA: return KC_PLUS;
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KGAMMA:          return KC_LCBR;
 | 
						|
        case KKAPPA | KEPSILON | KGAMMA | KIOTA:          return KC_RCBR;
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KTHETA:          return KC_PIPE;
 | 
						|
        case KKAPPA | KEPSILON | KBETA | KGAMMA | KDELTA: return KC_COLN;
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KDELTA:          return KC_DQT;
 | 
						|
        case KKAPPA | KEPSILON | KTHETA | KIOTA:          return KC_LT;
 | 
						|
        case KKAPPA | KEPSILON | KZETA | KGAMMA | KDELTA: return KC_GT;
 | 
						|
        case KKAPPA | KEPSILON | KGAMMA:                  return KC_QUES;
 | 
						|
        case KKAPPA | KEPSILON | KDELTA:                  return KC_TILD;
 | 
						|
 | 
						|
        // Modifiers
 | 
						|
        case KALPHA | KIOTA: return LOCK;
 | 
						|
 | 
						|
        case KALPHA: return QK_ONE_SHOT_MOD; // Release all
 | 
						|
 | 
						|
        case KALPHA | KBETA:  return OSM(MOD_LCTL);
 | 
						|
        case KALPHA | KGAMMA: return OSM(MOD_LSFT);
 | 
						|
        case KALPHA | KDELTA: return OSM(MOD_LALT);
 | 
						|
        case KALPHA | KKAPPA: return OSM(MOD_LGUI);
 | 
						|
 | 
						|
        case KALPHA | KBETA | KGAMMA:  return OSM(MOD_LCTL | MOD_LSFT);
 | 
						|
        case KALPHA | KBETA | KDELTA:  return OSM(MOD_LCTL | MOD_LALT);
 | 
						|
        case KALPHA | KBETA | KKAPPA:  return OSM(MOD_LCTL | MOD_LGUI);
 | 
						|
        case KALPHA | KGAMMA | KDELTA: return OSM(MOD_LSFT | MOD_LALT);
 | 
						|
        case KALPHA | KGAMMA | KKAPPA: return OSM(MOD_LSFT | MOD_LGUI);
 | 
						|
        case KALPHA | KDELTA | KKAPPA: return OSM(MOD_LALT | MOD_LGUI);
 | 
						|
 | 
						|
        case KALPHA | KBETA | KGAMMA | KDELTA:  return OSM(MOD_LCTL | MOD_LSFT | MOD_LALT);
 | 
						|
        case KALPHA | KBETA | KGAMMA | KKAPPA:  return OSM(MOD_LCTL | MOD_LSFT | MOD_LGUI);
 | 
						|
        case KALPHA | KBETA | KDELTA | KKAPPA:  return OSM(MOD_LCTL | MOD_LALT | MOD_LGUI);
 | 
						|
        case KALPHA | KGAMMA | KDELTA | KKAPPA: return OSM(MOD_LSFT | MOD_LALT | MOD_LGUI);
 | 
						|
 | 
						|
        case KALPHA | KBETA | KGAMMA | KDELTA | KKAPPA: return OSM(MOD_LCTL | MOD_LSFT | MOD_LALT | MOD_LGUI);
 | 
						|
    }
 | 
						|
 | 
						|
    return NONE;
 | 
						|
}
 | 
						|
 | 
						|
static uint16_t *get_hand(keypos_t *key) {
 | 
						|
    if (key->row <= 3) {
 | 
						|
        return &left_chord;
 | 
						|
    }
 | 
						|
 | 
						|
    if (key->row <= 6) {
 | 
						|
        return &right_chord;
 | 
						|
    }
 | 
						|
 | 
						|
    // row 7
 | 
						|
    if (key->col <= 2) {
 | 
						|
        return &right_chord;
 | 
						|
    } else {
 | 
						|
        return &left_chord;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
 | 
						|
    if (keycode < ALPHA) {
 | 
						|
        return true;
 | 
						|
    }
 | 
						|
 | 
						|
    uint16_t *chord = get_hand(&record->event.key);
 | 
						|
 | 
						|
    if (record->event.pressed) {
 | 
						|
        *chord |= K(keycode);
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
 | 
						|
    if (*chord != 0) {
 | 
						|
        process_keys(chord_to_keys(*chord));
 | 
						|
        *chord = 0;
 | 
						|
    }
 | 
						|
 | 
						|
    return false;
 | 
						|
}
 | 
						|
 | 
						|
#ifdef KEYBOARD_planck_ez
 | 
						|
 | 
						|
#define LED_BRIGHTNESS 50
 | 
						|
 | 
						|
layer_state_t default_layer_state_set_user(layer_state_t state) {
 | 
						|
    switch (state) {
 | 
						|
        case 1U << NORMAL:
 | 
						|
            planck_ez_left_led_off();
 | 
						|
            planck_ez_right_led_off();
 | 
						|
            break;
 | 
						|
        case 1U << QWERTY:
 | 
						|
            planck_ez_left_led_level(LED_BRIGHTNESS);
 | 
						|
            planck_ez_right_led_off();
 | 
						|
            break;
 | 
						|
        case 1U << GAME:
 | 
						|
            planck_ez_left_led_off();
 | 
						|
            planck_ez_right_led_level(LED_BRIGHTNESS);
 | 
						|
            break;
 | 
						|
    }
 | 
						|
 | 
						|
    return state;
 | 
						|
}
 | 
						|
 | 
						|
#endif /* KEYBOARD_planck_ez */
 |