summaryrefslogtreecommitdiff
path: root/users/davidkristoffersen/macros/language.c
diff options
context:
space:
mode:
authorQMK Bot <hello@qmk.fm>2022-07-02 12:18:55 +0000
committerQMK Bot <hello@qmk.fm>2022-07-02 12:18:55 +0000
commitfa0aea2a5abf55237bc1c4a8180af68833f1935a (patch)
tree949b591e0e928f49f6b435359cba83a563ea06b8 /users/davidkristoffersen/macros/language.c
parent65832c0fc3e502582986a8fa7c561c39d9fc447f (diff)
parenta80943579c88255fff9de57978b8e577d184785c (diff)
Merge remote-tracking branch 'origin/master' into develop
Diffstat (limited to 'users/davidkristoffersen/macros/language.c')
-rw-r--r--users/davidkristoffersen/macros/language.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/users/davidkristoffersen/macros/language.c b/users/davidkristoffersen/macros/language.c
new file mode 100644
index 0000000000..9b6dca79ca
--- /dev/null
+++ b/users/davidkristoffersen/macros/language.c
@@ -0,0 +1,40 @@
+// Copyright 2022 David Kristoffersen (@davidkristoffersen)
+// SPDX-License-Identifier: GPL-3.0-or-later
+
+#include "macros.h"
+
+bool handle_language(uint16_t keycode) {
+#ifdef LAYER_NO
+ // Handle conversion of English to Norwegian codes
+ uint16_t org_keycode = keycode;
+ keycode = get_norwegian_code(keycode);
+#endif
+
+#ifndef NO_SPECIAL_SHIFT
+ // Handle conversion of special shift codes
+ if (get_mods() & MOD_MASK_SHIFT) {
+ uint16_t shifted_key = get_special_shifted_code(keycode);
+ if (shifted_key != keycode) {
+ // Tap shifted key while shift is disabled
+ unregister_code(KC_LSFT);
+ tap_code16(shifted_key);
+ register_code(KC_LSFT);
+ return false;
+ }
+ }
+#endif
+
+#ifdef LAYER_NO
+ // Tap new language key
+ if (keycode != org_keycode) {
+ tap_code16(keycode);
+ return false;
+ }
+#endif
+ return true;
+}
+
+bool process_language(uint16_t keycode, keyrecord_t* record) {
+ HANDLE_FALSE(handle_language(keycode));
+ return true;
+}