Compare commits
No commits in common. "main" and "v2.0.0" have entirely different histories.
7 changed files with 151 additions and 314 deletions
191
.github/workflows/build-user-config.yml
vendored
191
.github/workflows/build-user-config.yml
vendored
|
@ -1,191 +0,0 @@
|
||||||
name: Reusable user config build
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_call:
|
|
||||||
inputs:
|
|
||||||
build_matrix_path:
|
|
||||||
description: "Path to the build matrix file"
|
|
||||||
default: "build.yaml"
|
|
||||||
required: false
|
|
||||||
type: string
|
|
||||||
config_path:
|
|
||||||
description: "Path to the config directory"
|
|
||||||
default: "config"
|
|
||||||
required: false
|
|
||||||
type: string
|
|
||||||
fallback_binary:
|
|
||||||
description: "Fallback binary format, if no *.uf2 file was built"
|
|
||||||
default: "bin"
|
|
||||||
required: false
|
|
||||||
type: string
|
|
||||||
archive_name:
|
|
||||||
description: "Archive output file name"
|
|
||||||
default: "firmware"
|
|
||||||
required: false
|
|
||||||
type: string
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
matrix:
|
|
||||||
runs-on: docker
|
|
||||||
name: Fetch Build Keyboards
|
|
||||||
outputs:
|
|
||||||
build_matrix: ${{ env.build_matrix }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
run: printf "/home/runner/externals/node20/bin\n" >> $GITHUB_PATH
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Install Dependencies
|
|
||||||
run: apt-get update
|
|
||||||
- run: apt-get -y install python3-pip jq
|
|
||||||
|
|
||||||
- name: Install yaml2json
|
|
||||||
run: python3 -m pip install remarshal
|
|
||||||
|
|
||||||
- name: Fetch Build Matrix
|
|
||||||
run: |
|
|
||||||
echo "build_matrix=$(yaml2json '${{ inputs.build_matrix_path }}' | jq -c .)" >> $GITHUB_ENV
|
|
||||||
yaml2json "${{ inputs.build_matrix_path }}" | jq
|
|
||||||
|
|
||||||
build:
|
|
||||||
runs-on: docker
|
|
||||||
container:
|
|
||||||
image: zmkfirmware/zmk-build-arm:stable
|
|
||||||
needs: matrix
|
|
||||||
name: Build
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix: ${{ fromJson(needs.matrix.outputs.build_matrix) }}
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
run: printf "/home/runner/externals/node20/bin\n" >> $GITHUB_PATH
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Create build directory
|
|
||||||
run: |
|
|
||||||
echo "build_dir=$(mktemp -d)" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Prepare variables
|
|
||||||
shell: sh -x {0}
|
|
||||||
env:
|
|
||||||
board: ${{ matrix.board }}
|
|
||||||
shield: ${{ matrix.shield }}
|
|
||||||
artifact_name: ${{ matrix.artifact-name }}
|
|
||||||
snippet: ${{ matrix.snippet }}
|
|
||||||
run: |
|
|
||||||
if [ -e zephyr/module.yml ]; then
|
|
||||||
export zmk_load_arg=" -DZMK_EXTRA_MODULES='${GITHUB_WORKSPACE}'"
|
|
||||||
new_tmp_dir="${TMPDIR:-/tmp}/zmk-config"
|
|
||||||
mkdir -p "${new_tmp_dir}"
|
|
||||||
echo "base_dir=${new_tmp_dir}" >> $GITHUB_ENV
|
|
||||||
else
|
|
||||||
echo "base_dir=${GITHUB_WORKSPACE}" >> $GITHUB_ENV
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "${snippet}" ]; then
|
|
||||||
extra_west_args="-S \"${snippet}\""
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "zephyr_version=${ZEPHYR_VERSION}" >> $GITHUB_ENV
|
|
||||||
echo "extra_west_args=${extra_west_args}" >> $GITHUB_ENV
|
|
||||||
echo "extra_cmake_args=${shield:+-DSHIELD=\"$shield\"}${zmk_load_arg}" >> $GITHUB_ENV
|
|
||||||
echo "display_name=${shield:+$shield - }${board}" >> $GITHUB_ENV
|
|
||||||
echo "artifact_name=${artifact_name:-${shield:+$shield-}${board}-zmk}" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Copy config files to isolated temporary directory
|
|
||||||
run: |
|
|
||||||
if [ "${{ env.base_dir }}" != "${GITHUB_WORKSPACE}" ]; then
|
|
||||||
mkdir "${{ env.base_dir }}/${{ inputs.config_path }}"
|
|
||||||
cp -R ${{ inputs.config_path }}/* "${{ env.base_dir }}/${{ inputs.config_path }}/"
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Cache west modules
|
|
||||||
run: printf "/home/runner/externals/node20/bin\n" >> $GITHUB_PATH
|
|
||||||
- uses: actions/cache@v4
|
|
||||||
continue-on-error: true
|
|
||||||
env:
|
|
||||||
cache_name: cache-zephyr-${{ env.zephyr_version }}-modules
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
${{ env.base_dir }}/modules/
|
|
||||||
${{ env.base_dir }}/tools/
|
|
||||||
${{ env.base_dir }}/zephyr/
|
|
||||||
${{ env.base_dir }}/bootloader/
|
|
||||||
${{ env.base_dir }}/zmk/
|
|
||||||
key: ${{ runner.os }}-build-${{ env.cache_name }}-${{ hashFiles('**/west.yml', '**/build.yaml') }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-build-${{ env.cache_name }}-
|
|
||||||
${{ runner.os }}-build-
|
|
||||||
${{ runner.os }}-
|
|
||||||
|
|
||||||
- name: West Init
|
|
||||||
working-directory: ${{ env.base_dir }}
|
|
||||||
run: west init -l "${{ env.base_dir }}/${{ inputs.config_path }}"
|
|
||||||
|
|
||||||
- name: West Update
|
|
||||||
working-directory: ${{ env.base_dir }}
|
|
||||||
run: west update
|
|
||||||
|
|
||||||
- name: West Zephyr export
|
|
||||||
working-directory: ${{ env.base_dir }}
|
|
||||||
run: west zephyr-export
|
|
||||||
|
|
||||||
- name: West Build (${{ env.display_name }})
|
|
||||||
working-directory: ${{ env.base_dir }}
|
|
||||||
shell: sh -x {0}
|
|
||||||
run: west build -s zmk/app -d "${{ env.build_dir }}" -b "${{ matrix.board }}" ${{ env.extra_west_args }} -- -DZMK_CONFIG=${{ env.base_dir }}/${{ inputs.config_path }} ${{ env.extra_cmake_args }} ${{ matrix.cmake-args }}
|
|
||||||
|
|
||||||
- name: ${{ env.display_name }} Kconfig file
|
|
||||||
run: |
|
|
||||||
if [ -f "${{ env.build_dir }}/zephyr/.config" ]
|
|
||||||
then
|
|
||||||
grep -v -e "^#" -e "^$" "${{ env.build_dir }}/zephyr/.config" | sort
|
|
||||||
else
|
|
||||||
echo "No Kconfig output"
|
|
||||||
fi
|
|
||||||
if: ${{ !cancelled() }}
|
|
||||||
|
|
||||||
- name: ${{ env.display_name }} Devicetree file
|
|
||||||
run: |
|
|
||||||
if [ -f "${{ env.build_dir }}/zephyr/zephyr.dts" ]
|
|
||||||
then
|
|
||||||
cat "${{ env.build_dir }}/zephyr/zephyr.dts"
|
|
||||||
elif [ -f "${{ env.build_dir }}/zephyr/zephyr.dts.pre" ]
|
|
||||||
then
|
|
||||||
cat -s "${{ env.build_dir }}/zephyr/zephyr.dts.pre"
|
|
||||||
else
|
|
||||||
echo "No Devicetree output"
|
|
||||||
fi
|
|
||||||
if: ${{ !cancelled() }}
|
|
||||||
|
|
||||||
- name: Rename artifacts
|
|
||||||
shell: sh -x {0}
|
|
||||||
run: |
|
|
||||||
mkdir "${{ env.build_dir }}/artifacts"
|
|
||||||
if [ -f "${{ env.build_dir }}/zephyr/zmk.uf2" ]
|
|
||||||
then
|
|
||||||
cp "${{ env.build_dir }}/zephyr/zmk.uf2" "${{ env.build_dir }}/artifacts/${{ env.artifact_name }}.uf2"
|
|
||||||
elif [ -f "${{ env.build_dir }}/zephyr/zmk.${{ inputs.fallback_binary }}" ]
|
|
||||||
then
|
|
||||||
cp "${{ env.build_dir }}/zephyr/zmk.${{ inputs.fallback_binary }}" "${{ env.build_dir }}/artifacts/${{ env.artifact_name }}.${{ inputs.fallback_binary }}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Archive (${{ env.display_name }})
|
|
||||||
run: printf "/home/runner/externals/node20/bin\n" >> $GITHUB_PATH
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: artifact-${{ env.artifact_name }}
|
|
||||||
path: ${{ env.build_dir }}/artifacts
|
|
||||||
|
|
||||||
merge:
|
|
||||||
runs-on: docker
|
|
||||||
needs: build
|
|
||||||
name: Merge Output Artifacts
|
|
||||||
steps:
|
|
||||||
- name: Merge Artifacts
|
|
||||||
run: printf "/home/runner/externals/node20/bin\n" >> $GITHUB_PATH
|
|
||||||
- uses: actions/upload-artifact/merge@v4
|
|
||||||
with:
|
|
||||||
name: ${{ inputs.archive_name }}
|
|
||||||
pattern: artifact-*
|
|
||||||
delete-merged: true
|
|
46
.github/workflows/build.yml
vendored
46
.github/workflows/build.yml
vendored
|
@ -2,48 +2,4 @@ on: [push, pull_request, workflow_dispatch]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: docker
|
uses: urob/zmk/.github/workflows/build-user-config.yml@build-with-submodules
|
||||||
container:
|
|
||||||
image: zmkfirmware/zmk-build-arm:stable
|
|
||||||
steps:
|
|
||||||
- name: Install Dependencies
|
|
||||||
run: |
|
|
||||||
apt-get update
|
|
||||||
apt-get install tree curl -y
|
|
||||||
|
|
||||||
- name: Install Node.JS Workarround, see https://github.com/nektos/act/issues/973
|
|
||||||
run: |
|
|
||||||
curl -fsSL https://deb.nodesource.com/setup_20.x | bash -
|
|
||||||
apt install -y nodejs
|
|
||||||
node --version
|
|
||||||
|
|
||||||
- name: Git checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- name: Clone ZMK Repo
|
|
||||||
run: git clone -b feat/pointers-move-scroll https://github.com/petejohanson/zmk.git
|
|
||||||
|
|
||||||
- name: Initialize ZMK
|
|
||||||
working-directory: ./zmk
|
|
||||||
run: |
|
|
||||||
west init -l app/
|
|
||||||
west update
|
|
||||||
- name: Build Left Shield
|
|
||||||
working-directory: ./zmk/app
|
|
||||||
run: west build -d build/left -b nice_nano_v2 -- -DSHIELD=corne_left -DZMK_CONFIG="../../config"
|
|
||||||
- name: Build Right Shield
|
|
||||||
working-directory: ./zmk/app
|
|
||||||
run: west build -d build/right -b nice_nano_v2 -- -DSHIELD=corne_right -DZMK_CONFIG="../../config"
|
|
||||||
|
|
||||||
- name: Rename artifacts
|
|
||||||
working-directory: .
|
|
||||||
run: |
|
|
||||||
mkdir "./artifacts"
|
|
||||||
cp ./zmk/app/build/left/zephyr/zmk.uf2 ./artifacts/corne_left-nice_nano_v2-zmk.uf2
|
|
||||||
cp ./zmk/app/build/right/zephyr/zmk.uf2 ./artifacts/corne_right-nice_nano_v2-zmk.uf2
|
|
||||||
|
|
||||||
- name: Upload Artifacts
|
|
||||||
if: ${{ true }}
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: firmware
|
|
||||||
path: ./artifacts
|
|
||||||
|
|
3
.gitmodules
vendored
3
.gitmodules
vendored
|
@ -0,0 +1,3 @@
|
||||||
|
[submodule "zmk-nodefree-config"]
|
||||||
|
path = zmk-nodefree-config
|
||||||
|
url = https://github.com/urob/zmk-nodefree-config
|
Binary file not shown.
|
@ -4,12 +4,3 @@
|
||||||
|
|
||||||
# Uncomment the following line to enable the Corne OLED Display
|
# Uncomment the following line to enable the Corne OLED Display
|
||||||
# CONFIG_ZMK_DISPLAY=y
|
# CONFIG_ZMK_DISPLAY=y
|
||||||
|
|
||||||
# RGB underglow
|
|
||||||
CONFIG_ZMK_RGB_UNDERGLOW=y
|
|
||||||
CONFIG_WS2812_STRIP=y
|
|
||||||
|
|
||||||
# RGB backlight
|
|
||||||
CONFIG_ZMK_BACKLIGHT_ON_START=y
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -6,18 +6,13 @@
|
||||||
|
|
||||||
#include <behaviors.dtsi>
|
#include <behaviors.dtsi>
|
||||||
#include <dt-bindings/zmk/keys.h>
|
#include <dt-bindings/zmk/keys.h>
|
||||||
#include <dt-bindings/zmk/rgb.h>
|
|
||||||
|
|
||||||
&led_strip {
|
|
||||||
chain-length = <27>;
|
|
||||||
};
|
|
||||||
|
|
||||||
/ {
|
/ {
|
||||||
combos {
|
combos {
|
||||||
compatible = "zmk,combos";
|
compatible = "zmk,combos";
|
||||||
|
|
||||||
number_layer {
|
number_layer {
|
||||||
bindings = <&mo 5>;
|
bindings = <&mo 4>;
|
||||||
key-positions = <37 41>;
|
key-positions = <37 41>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -28,108 +23,199 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
macros {
|
macros {
|
||||||
sym_sec: sym_sec {
|
alt_trans: alt_trans {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp S &kp O>;
|
bindings =
|
||||||
label = "sym_sec";
|
<¯o_press>,
|
||||||
|
<&kp RALT>,
|
||||||
|
<¯o_tap>,
|
||||||
|
<&trans>,
|
||||||
|
<¯o_release>,
|
||||||
|
<&kp RALT>;
|
||||||
|
|
||||||
|
label = "ALT_TRANS";
|
||||||
|
};
|
||||||
|
|
||||||
|
sym_section: sym_section {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&kp RALT &kp S &kp O>;
|
||||||
|
label = "SYM_SECTION";
|
||||||
};
|
};
|
||||||
|
|
||||||
de_ue: de_ue {
|
de_ue: de_ue {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp U &kp DQT>;
|
bindings = <&kp RALT &kp U &kp DQT>;
|
||||||
label = "DE_UE";
|
label = "DE_UE";
|
||||||
};
|
};
|
||||||
|
|
||||||
de_ae: de_ae {
|
de_ae: de_ae {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp A &kp DQT>;
|
bindings = <&kp RALT &kp A &kp DQT>;
|
||||||
label = "DE_AE";
|
label = "DE_AE";
|
||||||
};
|
};
|
||||||
|
|
||||||
de_oe: de_oe {
|
de_oe: de_oe {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp O &kp DQT>;
|
bindings = <&kp RALT &kp O &kp DQT>;
|
||||||
label = "DE_OE";
|
label = "DE_OE";
|
||||||
};
|
};
|
||||||
|
|
||||||
de_ss: de_ss {
|
de_ss: de_ss {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp S &kp S>;
|
bindings = <&kp RALT &kp S &kp S>;
|
||||||
label = "DE_SS";
|
label = "DE_SS";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_eur: sym_eur {
|
sym_eur: sym_eur {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp C &kp EQUAL>;
|
bindings = <&kp RALT &kp C &kp EQUAL>;
|
||||||
label = "SYM_EUR";
|
label = "SYM_EUR";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_ss1: sym_ss1 {
|
sym_ss1: sym_ss1 {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp CARET &kp KP_NUMBER_1>;
|
bindings = <&kp RALT &kp CARET &kp KP_NUMBER_1>;
|
||||||
label = "SYM_SS1";
|
label = "SYM_SS1";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_ss2: sym_ss2 {
|
sym_ss2: sym_ss2 {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp CARET &kp KP_NUMBER_2>;
|
bindings = <&kp RALT &kp CARET &kp KP_NUMBER_2>;
|
||||||
label = "SYM_SS2";
|
label = "SYM_SS2";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_ss3: sym_ss3 {
|
sym_ss3: sym_ss3 {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp CARET &kp KP_NUMBER_3>;
|
bindings = <&kp RALT &kp CARET &kp KP_NUMBER_3>;
|
||||||
label = "SYM_SS3";
|
label = "SYM_SS3";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_tm: sym_tm {
|
sym_tm: sym_tm {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp T &kp M>;
|
bindings = <&kp RALT &kp T &kp M>;
|
||||||
label = "SYM_TM";
|
label = "SYM_TM";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_reg: sym_reg {
|
sym_reg: sym_reg {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp O &kp R>;
|
bindings = <&kp RALT &kp O &kp R>;
|
||||||
label = "SYM_REG";
|
label = "SYM_REG";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_copy: sym_copy {
|
sym_copy: sym_copy {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp O &kp C>;
|
bindings = <&kp RALT &kp O &kp C>;
|
||||||
label = "SYM_COPY";
|
label = "SYM_COPY";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
nav_space_next: nav_space_next {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings =
|
||||||
|
<¯o_press>,
|
||||||
|
<&kp LCTRL &kp LGUI>,
|
||||||
|
<¯o_tap>,
|
||||||
|
<&kp RIGHT>,
|
||||||
|
<¯o_release>,
|
||||||
|
<&kp LGUI &kp LCTRL>;
|
||||||
|
|
||||||
|
label = "NAV_SPACE_NEXT";
|
||||||
|
};
|
||||||
|
|
||||||
|
nav_space_prev: nav_space_prev {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&sk LCTRL &sk LGUI &kp LEFT>;
|
||||||
|
label = "NAV_SPACE_PREV";
|
||||||
|
};
|
||||||
|
|
||||||
|
nav_win_next: nav_win_next {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&sk LALT &kp TAB>;
|
||||||
|
label = "NAV_WIN_NEXT";
|
||||||
|
};
|
||||||
|
|
||||||
|
nav_win_prev: nav_win_prev {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&sk LALT &sk LSHIFT &kp TAB>;
|
||||||
|
label = "NAV_WIN_PREV";
|
||||||
|
};
|
||||||
|
|
||||||
|
nav_desktop: nav_desktop {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&sk LGUI &kp D>;
|
||||||
|
label = "NAV_DESKTOP";
|
||||||
|
};
|
||||||
|
|
||||||
|
shift_trans: shift_trans {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings =
|
||||||
|
<¯o_press>,
|
||||||
|
<&kp LSHIFT>,
|
||||||
|
<¯o_tap>,
|
||||||
|
<&trans>,
|
||||||
|
<¯o_release>,
|
||||||
|
<&kp LSHIFT>;
|
||||||
|
|
||||||
|
label = "SHIFT_TRANS";
|
||||||
|
};
|
||||||
|
|
||||||
sym_deg: sym_deg {
|
sym_deg: sym_deg {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp O &kp O>;
|
bindings = <&kp RALT &kp O &kp O>;
|
||||||
label = "SYM_DEG";
|
label = "SYM_DEG";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
de_ue_gr: de_ue_gr {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&kp RALT &kp LS(U) &kp DQT>;
|
||||||
|
label = "DE_UE_GR";
|
||||||
|
};
|
||||||
|
|
||||||
|
de_ae_gr: de_ae_gr {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&kp RALT &kp LS(A) &kp DQT>;
|
||||||
|
label = "DE_AE_GR";
|
||||||
|
};
|
||||||
|
|
||||||
|
de_oe_gr: de_oe_gr {
|
||||||
|
compatible = "zmk,behavior-macro";
|
||||||
|
#binding-cells = <0>;
|
||||||
|
bindings = <&kp RALT &kp LS(O) &kp DQT>;
|
||||||
|
label = "DE_OE_GR";
|
||||||
|
};
|
||||||
|
|
||||||
sym_mu: sym_mu {
|
sym_mu: sym_mu {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp M &kp U>;
|
bindings = <&kp RALT &kp M &kp U>;
|
||||||
label = "SYM_MU";
|
label = "SYM_MU";
|
||||||
};
|
};
|
||||||
|
|
||||||
sym_acute: sym_acute {
|
sym_acute: sym_acute {
|
||||||
compatible = "zmk,behavior-macro";
|
compatible = "zmk,behavior-macro";
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
bindings = <&kp SLCK &kp SQT &kp SQT>;
|
bindings = <&kp RALT &kp SQT &kp SQT>;
|
||||||
label = "SYM_ACUTE";
|
label = "SYM_ACUTE";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -171,18 +257,18 @@
|
||||||
mods = <(MOD_RALT)>;
|
mods = <(MOD_RALT)>;
|
||||||
};
|
};
|
||||||
|
|
||||||
de_lt_mt_pipe: de_lt_mt_pipe {
|
de_less_more_pipe: de_less_more_pipe {
|
||||||
compatible = "zmk,behavior-mod-morph";
|
compatible = "zmk,behavior-mod-morph";
|
||||||
label = "de_lt_mt_pipe";
|
label = "DE_LESS_MORE_PIPE";
|
||||||
bindings = <&part_less_pipe>, <&kp GREATER_THAN>;
|
bindings = <&part_less_pipe>, <&kp GREATER_THAN>;
|
||||||
|
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
mods = <(MOD_LSFT)>;
|
mods = <(MOD_LSFT)>;
|
||||||
};
|
};
|
||||||
|
|
||||||
de_car_deg: de_car_deg {
|
de_caret_degree: de_caret_degree {
|
||||||
compatible = "zmk,behavior-mod-morph";
|
compatible = "zmk,behavior-mod-morph";
|
||||||
label = "de_car_deg";
|
label = "DE_CARET_DEGREE";
|
||||||
bindings = <&kp CARET>, <&sym_deg>;
|
bindings = <&kp CARET>, <&sym_deg>;
|
||||||
|
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
|
@ -198,18 +284,18 @@
|
||||||
mods = <(MOD_RALT)>;
|
mods = <(MOD_RALT)>;
|
||||||
};
|
};
|
||||||
|
|
||||||
de_plus_str_tld: de_plus_str_tld {
|
de_plus_star_tilde: de_plus_star_tilde {
|
||||||
compatible = "zmk,behavior-mod-morph";
|
compatible = "zmk,behavior-mod-morph";
|
||||||
label = "de_plus_str_tld";
|
label = "DE_PLUS_STAR_TILDE";
|
||||||
bindings = <&part_plus_tilde>, <&kp STAR>;
|
bindings = <&part_plus_tilde>, <&kp STAR>;
|
||||||
|
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
mods = <(MOD_RALT)>;
|
mods = <(MOD_RALT)>;
|
||||||
};
|
};
|
||||||
|
|
||||||
dv_qmark_ss: dv_qmark_ss {
|
dv_qestion_ss: dv_qestion_ss {
|
||||||
compatible = "zmk,behavior-mod-morph";
|
compatible = "zmk,behavior-mod-morph";
|
||||||
label = "dv_qmark_ss";
|
label = "DV_QESTION_SS";
|
||||||
bindings = <&kp QMARK>, <&de_ss>;
|
bindings = <&kp QMARK>, <&de_ss>;
|
||||||
|
|
||||||
#binding-cells = <0>;
|
#binding-cells = <0>;
|
||||||
|
@ -238,63 +324,54 @@
|
||||||
keymap {
|
keymap {
|
||||||
compatible = "zmk,keymap";
|
compatible = "zmk,keymap";
|
||||||
|
|
||||||
base_colemak-dh {
|
default_layer {
|
||||||
bindings = <
|
|
||||||
&kp TAB &kp Q &kp W &kp F &kp P &kp B &kp J &kp L &kp U &kp Y &de_hash &trans
|
|
||||||
&kp ESC &kp A &kp R &kp S &kp T &kp G &kp M &kp N &kp E &kp I &kp O &trans
|
|
||||||
&trans &kp Z &kp X &kp C &kp D &kp V &kp K &kp H &de_comma &de_dot &kp MINUS &trans
|
|
||||||
&mo 2 &kp LSHIFT &kp RET &kp BSPC &kp SPACE &mo 4
|
|
||||||
>;
|
|
||||||
};
|
|
||||||
|
|
||||||
base_quertz-de {
|
|
||||||
// -----------------------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------------------
|
||||||
// | ESC | Q | W | E | R | T | | Y | U | I | O | P | \ |
|
// | TAB | Ü | , | . | P | Y | | F | G | C | T | Z | ? |
|
||||||
// | TAB | A | S | D | F | G | | H | J | K | L | ; | ' |
|
// | SHFT | A | O | E | I | U | | H | D | R | N | S | L |
|
||||||
// | SHIFT | Z | X | C | V | B | | N | M | , | . | / | CTRL |
|
// | Ä | Ö | Q | J | K | X | | B | M | , | . | # | - |
|
||||||
// | GUI | DEL | RET | | TAB | BSPC | R-ALT |
|
// | CTRL| GUI | SPC | | ENT | RSE | ALT |
|
||||||
|
|
||||||
bindings = <
|
bindings = <
|
||||||
&kp TAB &kp Q &kp W &kp E &kp R &kp T &kp Z &kp U &kp I &kp O &kp P &de_ue
|
&kp TAB &de_ue &de_comma &de_dot &kp P &kp Y &kp F &kp G &kp C &kp T &kp Z &kp BACKSPACE
|
||||||
&kp ESC &kp A &kp S &kp D &kp F &kp G &kp H &kp J &kp K &kp L &de_oe &de_ae
|
&kp ESCAPE &kp A &kp O &kp E &kp I &kp U &kp H &kp D &kp R &kp N &kp S &kp L
|
||||||
&kp LCTRL &kp Y &kp X &kp C &kp V &kp B &kp N &kp M &de_comma &de_dot &kp MINUS &de_hash
|
&de_ae &de_oe &kp Q &kp J &kp K &kp X &kp B &kp M &kp W &kp V &de_hash &kp MINUS
|
||||||
&none &mo 2 &kp LSHFT &kp SPACE &mo 4 &none
|
&mo 1 &kp LSHFT &kp ENTER &kp BACKSPACE &kp SPACE &mo 2
|
||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
|
|
||||||
extend_layer {
|
extend {
|
||||||
bindings = <
|
bindings = <
|
||||||
&trans &kp ESC &kp K_BACK &kp TAB &kp K_FORWARD &kp INS &kp HOME &kp PG_UP &kp UP &kp PG_DN &kp CAPS &trans
|
&kp ESC &kp DEL &kp C_AC_BACK &kp C_AC_FIND &kp C_AC_FORWARD &kp INS &kp PAGE_UP &kp HOME &kp UP &kp END &none &kp BSPC
|
||||||
&trans &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &sk RALT &kp END &kp LEFT &kp DOWN &kp RIGHT &kp DEL &trans
|
&none &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &sk RALT &kp PAGE_DOWN &kp LEFT &kp DOWN &kp RIGHT &none &kp ENTER
|
||||||
&trans &kp LC(Z) &kp LC(X) &kp LC(C) &kp LGUI &kp LC(V) &kp ENTER &kp BSPC &kp TAB &kp K_APP &kp PSCRN &trans
|
&none &kp LC(Z) &kp LC(X) &kp LC(C) &kp LGUI &kp LC(V) &none &none &kp TAB &kp K_APP &kp PRINTSCREEN &none
|
||||||
&trans &trans &trans &trans &kp RET &trans
|
&none &kp LSHFT &kp ENTER &kp BSPC &kp SPACE &none
|
||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
|
|
||||||
function_layer {
|
symbol {
|
||||||
bindings = <
|
bindings = <
|
||||||
&rgb_ug RGB_EFF &kp K_STOP &kp K_PREV &kp K_PLAY_PAUSE &kp K_NEXT &kp C_BRIGHTNESS_INC &kp F12 &kp F7 &kp F8 &kp F9 &kp SLCK &rgb_ug RGB_TOG
|
&de_caret_degree &kp LEFT_BRACE &kp LEFT_BRACKET &kp RIGHT_BRACKET &kp RIGHT_BRACE &kp DOLLAR &kp EXCL &kp DOUBLE_QUOTES &sym_copy &sym_tm &de_plus_star_tilde &de_acute_grave
|
||||||
&rgb_ug RGB_SPI &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &kp C_BRI_DEC &kp F11 &kp F4 &kp F5 &kp F6 &to 1 &rgb_ug RGB_BRI
|
&none &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &sk RALT &dv_qestion_ss &sym_section &sym_reg &kp LPAR &kp RPAR &dv_slash
|
||||||
&rgb_ug RGB_SPD &kp K_MUTE &kp C_VOL_DN &kp LC(LS(C)) &kp C_VOL_UP &kp LC(LS(V)) &kp F10 &kp F1 &kp F2 &kp F3 &to 0 &rgb_ug RGB_BRD
|
&none &de_less_more_pipe &none &none &kp AT &sym_eur &kp PERCENT &sym_mu &kp AMPERSAND &kp EQUAL &de_hash &kp MINUS
|
||||||
&none &trans &trans &kp ENTER &trans &none
|
&none &kp LSHFT &kp ENTER &kp BSPC &kp SPACE &none
|
||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
|
|
||||||
symbol_layer {
|
function {
|
||||||
bindings = <
|
bindings = <
|
||||||
&trans &de_ae &kp EXCL &sym_eur &kp DOLLAR &kp PERCENT &sym_deg &kp GRAVE &de_ue &kp DQT &de_oe &trans
|
&trans &kp C_STOP &kp C_PREV &kp C_PP &kp C_NEXT &kp C_BRI_UP &kp F12 &kp F7 &kp F8 &kp F9 &kp SLCK &trans
|
||||||
&trans &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &kp PIPE &kp CARET &kp LEFT_PARENTHESIS &kp LBRC &kp LBKT &kp LT &trans
|
&trans &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &kp C_BRI_DN &kp F11 &kp F4 &kp F5 &kp F6 &trans &trans
|
||||||
&trans &kp AT &kp QMARK &kp BSLH &kp AMPS &trans &kp TILDE &kp RIGHT_PARENTHESIS &kp RBRC &kp RBKT &kp GT &trans
|
&trans &kp C_MUTE &kp C_VOLUME_DOWN &kp LS(LC(C)) &kp C_VOLUME_UP &kp LC(LS(V)) &kp F10 &kp F1 &kp F2 &kp F3 &none &trans
|
||||||
&none &mo 3 &mo 5 &trans &none &none
|
&trans &kp LSHFT &kp ENTER &kp BSPC &kp SPACE &trans
|
||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
|
|
||||||
number_layer {
|
number {
|
||||||
bindings = <
|
bindings = <
|
||||||
&trans &trans &trans &trans &trans &kp LNLCK &kp EQUAL &kp N7 &kp N8 &kp N9 &kp PLUS &trans
|
&none &de_less_more_pipe &de_comma &de_dot &none &none &kp EQUAL &kp N7 &kp N8 &kp N9 &kp PLUS &kp BSPC
|
||||||
&trans &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &sk RALT &kp STAR &kp N4 &kp N5 &kp N6 &kp MINUS &trans
|
&none &sk LALT &sk LGUI &sk LSHFT &sk LCTRL &sk RALT &kp STAR &kp N4 &kp N5 &kp N6 &kp MINUS &kp RET
|
||||||
&trans &trans &kp K_APP &kp TAB &kp BSPC &kp RET &kp N0 &kp N1 &kp N2 &kp N3 &kp FSLH &trans
|
&none &none &kp Y &kp TAB &kp BSPC &kp ENTER &kp N0 &kp N1 &kp N2 &kp N3 &kp FSLH &none
|
||||||
&none &trans &none &trans &none &none
|
&none &kp LSHFT &kp ENTER &kp BSPC &kp SPACE &none
|
||||||
>;
|
>;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
1
zmk-nodefree-config
Submodule
1
zmk-nodefree-config
Submodule
|
@ -0,0 +1 @@
|
||||||
|
Subproject commit 4bdd8e85dca9ee1c817065bba4a70a7e1fd78eae
|
Loading…
Add table
Reference in a new issue