summaryrefslogtreecommitdiff
path: root/keyboards/handwired/datahand/keymaps
diff options
context:
space:
mode:
authorDrashna Jaelre <drashna@live.com>2019-04-09 08:58:11 -0700
committerDrashna Jaelre <drashna@live.com>2019-04-09 08:58:11 -0700
commitb6850bc043b1d129042f47501f0a1dc1e196f962 (patch)
treea0a772f278c3c494db3bc69103955af5561e1cae /keyboards/handwired/datahand/keymaps
parent19ed62114a1f5d20aacb9cbe83105e977b9a2971 (diff)
remove all keyboards but ergodox and planck
Diffstat (limited to 'keyboards/handwired/datahand/keymaps')
-rw-r--r--keyboards/handwired/datahand/keymaps/default/keymap.c313
1 files changed, 0 insertions, 313 deletions
diff --git a/keyboards/handwired/datahand/keymaps/default/keymap.c b/keyboards/handwired/datahand/keymaps/default/keymap.c
deleted file mode 100644
index 8f44535594..0000000000
--- a/keyboards/handwired/datahand/keymaps/default/keymap.c
+++ /dev/null
@@ -1,313 +0,0 @@
-/* Copyright 2017-2019 Nikolaus Wittenstein <nikolaus.wittenstein@gmail.com>
- *
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
- * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
- * FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
- * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
- * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
- * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
- * PERFORMANCE OF THIS SOFTWARE.
- */
-
-#include QMK_KEYBOARD_H
-
-#include <stdbool.h>
-
-/* Datahand features not supported:
- * * All online reprogramming (user settings using the reset button).
- * * Program Selection features.
- * * Macros.
- * * Direct substitutions.
- * * L/R Modf.
- * * Mouse Click Lock (Function Direct Access + Mouse Button key).
- * * Different mouse movement speeds with the two pointer fingers, and using both pointer fingers to move even faster.
- *
- * As far as I know, everything else works.
- */
-
-enum layer {
- NORMAL,
-#ifdef DATAHAND_THUMB_RETURN_COMMAND
- NORMAL_THUMB_RETURN_COMMAND,
-#endif
- FUNCTION_MOUSE,
- FUNCTION_ARROWS,
- NAS,
- NAS_NUMLOCK,
- NAS_TENKEY,
- NAS_TENKEY_NUMLOCK,
-
- NUM_LAYERS
-};
-
-enum custom_keycodes {
- N = SAFE_RANGE, /* Normal */
- NS, /* NAS */
- NSL, /* NAS Lock */
- NLK, /* Numlock */
- FN, /* Function mode - needs to be able to switch to mouse or arrow layer */
- TK0, /* Ten-key off button */
- TK1, /* Ten-key on button */
- AR, /* FN arrow mode */
- MS, /* FN mouse mode */
- DZ, /* Double zero button */
-};
-
-static bool mouse_enabled = true;
-static bool tenkey_enabled = false;
-static bool numlock_enabled = false;
-static bool nas_locked = false;
-
-/* Declared weak so that it can easily be overridden. */
-__attribute__((weak)) const uint16_t PROGMEM keymaps[NUM_LAYERS][MATRIX_ROWS][MATRIX_COLS] = {
-[NORMAL] = LAYOUT(
- KC_Q, KC_W, KC_E, KC_R, KC_U, KC_I, KC_O, KC_P,
-KC_DEL, KC_A, KC_LBRC, KC_ESC, KC_S, KC_B, KC_GRV, KC_D, KC_T, KC_DQT, KC_F, KC_G, KC_H, KC_J, KC_QUOT, KC_Y, KC_K, KC_COLN, KC_N, KC_L, KC_ENT, KC_RBRC, KC_SCLN, KC_BSLS,
- KC_Z, KC_X, KC_C, KC_V, KC_M, KC_COMM, KC_DOT, KC_SLSH,
- KC_ENT, KC_TAB, KC_BSPC, KC_SPC,
- KC_LSFT, NS,
- KC_CAPS, NSL,
- N, KC_LCTL, KC_LALT, FN),
-
-#ifdef DATAHAND_THUMB_RETURN_COMMAND
-[NORMAL_THUMB_RETURN_COMMAND] = LAYOUT(
- _______, _______, _______, _______, _______, _______, _______, _______,
-_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______,
- KC_LCMD, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-#endif
-
-[FUNCTION_MOUSE] = LAYOUT(
- KC_F2, KC_F4, KC_F6, KC_MS_U, KC_MS_U, KC_F8, KC_F10, KC_PGUP,
-_______, KC_NO, KC_SLCK, _______, KC_BTN3, NLK, KC_BTN1, MS, KC_BTN2, KC_MS_L, KC_BTN1, KC_MS_R, KC_MS_L, KC_BTN2, KC_MS_R, KC_END, AR, KC_LSFT, KC_INS, KC_9, KC_ENT, KC_F11, KC_0, KC_F12,
- KC_F1, KC_F3, KC_F5, KC_MS_D, KC_MS_D, KC_F7, KC_F9, KC_PGDN,
- _______, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-[FUNCTION_ARROWS] = LAYOUT(
- _______, _______, _______, KC_UP, KC_UP, _______, _______, _______,
-_______, _______, _______, _______, KC_LCTL, _______, _______, _______, _______, KC_LEFT, KC_HOME, KC_RGHT, KC_LEFT, KC_HOME, KC_RGHT, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, KC_DOWN, KC_DOWN, _______, _______, _______,
- _______, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-[NAS] = LAYOUT(
- KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN,
-_______, KC_1, KC_TILD, _______, KC_2, NLK, KC_LABK, KC_3, KC_RABK, KC_SLSH, KC_4, KC_5, KC_6, KC_7, KC_UNDS, KC_CIRC, KC_8, KC_ENT, KC_SCLN, KC_9, KC_BSLS, TK0, KC_0, TK1,
- KC_EQL, KC_X, KC_PERC, KC_MINS, KC_PLUS, KC_DOT, KC_SLSH, KC_QUES,
- _______, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-[NAS_NUMLOCK] = LAYOUT(
- _______, _______, _______, _______, _______, KC_PAST, _______, _______,
-_______, KC_KP_1, _______, _______, KC_KP_2, _______, _______, KC_KP_3, _______, KC_PSLS, KC_KP_4, KC_KP_5, KC_KP_6, KC_KP_7, _______, _______, KC_KP_8, _______, _______, KC_KP_9, KC_PENT, _______, KC_KP_0, _______,
- KC_PEQL, _______, _______, KC_PMNS, KC_PPLS, _______, KC_PDOT, _______,
- _______, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-[NAS_TENKEY] = LAYOUT(
- _______, _______, _______, KC_UP, KC_7, KC_8, KC_9, KC_ASTR,
-_______, KC_QUOT, _______, _______, KC_DLR, _______, _______, KC_AMPR, _______, KC_LEFT, KC_HOME, KC_RGHT, KC_0, KC_4, DZ, KC_PLUS, KC_5, KC_MINS, KC_EQL, KC_6, KC_ENT, _______, KC_DOT, _______,
- KC_LPRN, KC_RPRN, _______, KC_DOWN, KC_1, KC_2, KC_3, KC_SLSH,
- _______, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-[NAS_TENKEY_NUMLOCK] = LAYOUT(
- _______, _______, _______, _______, KC_KP_7, KC_KP_8, KC_KP_9, KC_PAST,
-_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_KP_0, KC_KP_4, _______, KC_PPLS, KC_KP_5, KC_PMNS, KC_PEQL, KC_KP_6, KC_PENT, _______, KC_PDOT, _______,
- _______, _______, _______, _______, KC_KP_1, KC_KP_2, KC_KP_3, KC_PSLS,
- _______, _______, _______, _______,
- _______, _______,
- _______, _______,
- _______, _______, _______, _______),
-};
-
-static void lock_led_set(bool on, uint8_t led) {
- if (on) {
- LED_LOCK_PORT &= ~led;
- } else {
- LED_LOCK_PORT |= led;
- }
-}
-
-static void mode_led_set(uint8_t led) {
- static const uint8_t ALL_MODE_LEDS = LED_FN | LED_NORMAL | LED_NAS | LED_TENKEY;
- LED_MODE_PORT |= ALL_MODE_LEDS;
- LED_MODE_PORT &= ~led;
-}
-
-static void layer_set(bool on, uint8_t layer) {
- if (on) {
- layer_on(layer);
- } else {
- layer_off(layer);
- }
-
- if (layer_state_is(NAS) || layer_state_is(NAS_NUMLOCK) || layer_state_is(NAS_TENKEY) || layer_state_is(NAS_TENKEY_NUMLOCK)) {
- if (tenkey_enabled) {
- mode_led_set(LED_NAS | LED_TENKEY);
- } else {
- mode_led_set(LED_NAS);
- }
- } else if (layer_state_is(FUNCTION_MOUSE) || layer_state_is(FUNCTION_ARROWS)) {
- mode_led_set(LED_FN);
- } else if (layer_state_is(NORMAL)) {
- mode_led_set(LED_NORMAL);
- }
-}
-
-static void set_normal(void) {
- layer_move(NORMAL);
-
-#ifdef DATAHAND_THUMB_RETURN_COMMAND
- layer_set(true, NORMAL_THUMB_RETURN_COMMAND);
-#endif
-
- /* Then call layer_set to update LEDs. */
- layer_set(true, NORMAL);
-}
-
-static void set_nas(bool on) {
- /* Always turn on the base NAS layer so other layers can fall through. */
- layer_set(on, NAS);
-
- layer_set(on && numlock_enabled, NAS_NUMLOCK);
- layer_set(on && tenkey_enabled, NAS_TENKEY);
- layer_set(on && tenkey_enabled && numlock_enabled, NAS_TENKEY_NUMLOCK);
-}
-
-static void set_tenkey(bool on) {
- tenkey_enabled = on;
-
- /* We have to be on the NAS layer in order to be able to toggle TK.
- * Re-toggle it on so that we move to the right layer (and set the right LED).
- */
- set_nas(true);
-}
-
-static void toggle_numlock(void) {
- numlock_enabled = !numlock_enabled;
- lock_led_set(numlock_enabled, LED_NUM_LOCK);
-
- if (layer_state_is(NAS)) {
- /* If we're already in NAS, re-set it so that we activate the numlock layer. */
- set_nas(true);
- }
-}
-
-static void set_function(void) {
- /* Make sure to turn off NAS if we're entering function */
- set_nas(false);
-
- /* Always turn on the mouse layer so the arrow layer can fall through. */
- layer_set(true, FUNCTION_MOUSE);
- layer_set(!mouse_enabled, FUNCTION_ARROWS);
-}
-
-static void set_mouse_enabled(bool on) {
- mouse_enabled = on;
-
- /* Re-run set_function to set our layers correctly. */
- set_function();
-}
-
-bool process_record_user(uint16_t keycode, keyrecord_t *record) {
- bool pressed = record->event.pressed;
-
- switch(keycode) {
- case N:
- if (pressed) {
- set_normal();
- }
- break;
-
- case NS:
- if (pressed) {
- nas_locked = false;
- }
- set_nas(pressed);
- break;
-
- case NSL:
- if (pressed) {
- nas_locked = true;
- set_nas(true);
- }
- break;
-
- case NLK:
- if (pressed) {
- toggle_numlock();
- SEND_STRING(SS_DOWN(X_NUMLOCK));
- } else {
- SEND_STRING(SS_UP(X_NUMLOCK));
- }
- break;
-
- case FN:
- if (pressed) {
- set_function();
- }
- break;
-
- case TK0:
- if (pressed) {
- set_tenkey(false);
- }
- break;
-
- case TK1:
- if (pressed) {
- set_tenkey(true);
- }
- break;
-
- case MS:
- if (pressed) {
- set_mouse_enabled(true);
- }
- break;
-
- case AR:
- if (pressed) {
- set_mouse_enabled(false);
- }
- break;
-
- case DZ:
- if (pressed) {
- SEND_STRING(SS_TAP(X_KP_0) SS_TAP(X_KP_0));
- }
- break;
- }
-
- return true;
-};
-
-void matrix_init_user(void) {
-#ifdef DATAHAND_THUMB_RETURN_COMMAND
- set_normal();
-#endif
-}
-
-void matrix_scan_user(void) {
-
-}
-
-void led_set_user(uint8_t usb_led) {
- lock_led_set(usb_led & (1<<USB_LED_NUM_LOCK), LED_NUM_LOCK);
- lock_led_set(usb_led & (1<<USB_LED_CAPS_LOCK), LED_CAPS_LOCK);
- lock_led_set(usb_led & (1<<USB_LED_SCROLL_LOCK), LED_SCROLL_LOCK);
-}