From 9511f86e0974d2ec48551d2207399566ef208392 Mon Sep 17 00:00:00 2001 From: Gustaf Rydholm Date: Sat, 30 Dec 2023 14:11:59 +0100 Subject: Add Charybdis --- aktersnurra/charybdis/config.h | 25 +++++++++++++ aktersnurra/charybdis/keymap.c | 80 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 105 insertions(+) create mode 100644 aktersnurra/charybdis/config.h create mode 100644 aktersnurra/charybdis/keymap.c diff --git a/aktersnurra/charybdis/config.h b/aktersnurra/charybdis/config.h new file mode 100644 index 0000000..c67cb16 --- /dev/null +++ b/aktersnurra/charybdis/config.h @@ -0,0 +1,25 @@ +/* +Copyright 2020 Pierre Chevalier + +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 . +*/ + +#pragma once +// Pick good defaults for enabling homerow modifiers +#define TAPPING_TERM 150 +#define PERMISSIVE_HOLD +#define TAPPING_FORCE_HOLD + +#define CHARYBDIS_MINIMUM_SNIPING_DPI 100 +#define CHARYBDIS_SNIPING_DPI_CONFIG_STEP 100 diff --git a/aktersnurra/charybdis/keymap.c b/aktersnurra/charybdis/keymap.c new file mode 100644 index 0000000..2c63c5a --- /dev/null +++ b/aktersnurra/charybdis/keymap.c @@ -0,0 +1,80 @@ +// this is the style you want to emulate. +// This is the canonical layout file for the Quantum project. If you want to add another keyboard, + +#include QMK_KEYBOARD_H + +// Each layer gets a name for readability, which is then used in the keymap matrix below. +// The underscores don't mean anything - you can have a layer called STUFF or any other name. +// Layer names don't all need to be of the same length, obviously, and you can also skip them +// entirely and just use numbers. + +#define KC_HA GUI_T(KC_A) +#define KC_HR ALT_T(KC_R) +#define KC_HS CTL_T(KC_S) +#define KC_HT SFT_T(KC_T) + +#define KC_HO GUI_T(KC_O) +#define KC_HI ALT_T(KC_I) +#define KC_HE CTL_T(KC_E) +#define KC_HN SFT_T(KC_N) + +#define KC_ALT_CTL LALT(KC_LCTL) + +#define NAV LT(_NAV, KC_SPC) +#define SYM LT(_SYM, KC_BSPC) +#define NUM LT(_NUM, KC_TAB) +#define MOU LT(_MOU, KC_ESC) +#define CHARYBDIS_AUTO_SNIPING_ON_LAYER _MOU + +enum { _COLEMAK_DH, _NAV, _NUM, _SYM, _FUN, _MEDIA, _MOU } layers; + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + [_COLEMAK_DH] = LAYOUT( /* COLEMAK MOD DH */ + KC_Q, KC_W, KC_F, KC_P, KC_B, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, + KC_HA, KC_HR, KC_HS, KC_HT, KC_G, KC_M, KC_HN, KC_HE, KC_HI, KC_HO, + KC_Z, KC_X, KC_C, KC_D, KC_V, KC_K, KC_H, KC_COMM, KC_DOT, KC_SLSH, + KC_ENT, NAV, MOU, SYM, NUM + ), + + [_NAV] = LAYOUT( /* [> Navigation layer <] */ + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_LPRN, KC_LBRC, KC_RBRC, KC_RPRN, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_BSLS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_BSPC, KC_LSFT + ), + + [_SYM] = LAYOUT( /* [> Symbol layer <] */ + KC_GRV, KC_EXLM, KC_PERC, KC_DLR, KC_AT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_HASH, KC_QUOT, KC_ASTR, KC_MINS, KC_EQL, KC_PIPE, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_AMPR, KC_CIRC, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_BSLS, + KC_TRNS, KC_SPC, KC_TRNS, KC_TRNS, KC_TRNS + ), + + [_NUM] = LAYOUT( /* [> Number layer <] */ + KC_TRNS, KC_4, KC_5, KC_6, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_1, KC_2, KC_3, KC_0, KC_TRNS, KC_7, KC_8, KC_9, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + MO(_MEDIA), MO(_FUN), KC_TRNS, KC_TRNS, KC_TRNS + ), + + [_MEDIA] = LAYOUT( /* [> Media layer <] */ + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_MPRV, KC_MPLY, KC_MNXT, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_VOLD, KC_VOLU, KC_MUTE, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS + ), + + [_FUN] = LAYOUT( /* [> Function layer <] */ + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, EE_CLR, QK_BOOT, + KC_TRNS, KC_TRNS, KC_TRNS, KC_ALT_CTL, KC_TRNS, KC_TRNS, KC_F1, KC_F2, KC_F3, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS + ), + + [_MOU] = LAYOUT( /* [> Mouse layer <] */ + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_MS_BTN1, KC_MS_BTN2, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, + KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS + ) +}; -- cgit v1.2.3-70-g09d2