summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.config/fish/config.fish29
-rw-r--r--.config/fish/fishfile2
-rw-r--r--.config/i3status/config58
-rw-r--r--.config/radicale/config4
-rw-r--r--.config/sway/blue0321
-rw-r--r--.config/sway/config69
-rw-r--r--.config/sway/defaults217
-rw-r--r--.config/sway/rock3
-rw-r--r--.config/systemd/user/radicale.service10
-rwxr-xr-x.local/bin/kill-kube-ns48
-rw-r--r--.local/var/lib/radicale/README.md1
-rw-r--r--.profile44
-rw-r--r--.vimrc61
-rw-r--r--.zshrc49
14 files changed, 596 insertions, 0 deletions
diff --git a/.config/fish/config.fish b/.config/fish/config.fish
new file mode 100644
index 0000000..1e54d8c
--- /dev/null
+++ b/.config/fish/config.fish
@@ -0,0 +1,29 @@
+# https://reckoning.dev/fish-shell/
+set -g theme_powerline_fonts yes
+set -g theme_nerd_fonts yes
+set -g theme_display_git_stashed_verbose yes
+set -g theme_display_git_master_branch yes
+set -g theme_display_git_untracked yes
+set -g theme_display_git_dirty yes
+set -g theme_display_nvm yes
+set -g theme_display_virtualenv yes
+set -g theme_color_scheme zenburn
+
+fundle plugin 'edc/bass'
+fundle plugin 'oh-my-fish/plugin-php'
+fundle plugin 'danhper/fish-fastdir'
+fundle plugin 'danhper/fish-theme-afowler'
+fundle plugin 'oh-my-fish/theme-bobthefish'
+
+fundle init
+
+# set path. See https://github.com/fish-shell/fish-shell/issues/527
+set PATH ~/.cargo/bin $PATH
+set PATH ~/.local/bin $PATH
+
+# Bootstrap fisher. See https://github.com/jorgebucaran/fisher
+if not functions -q fisher
+ set -q XDG_CONFIG_HOME; or set XDG_CONFIG_HOME ~/.config
+ curl https://git.io/fisher --create-dirs -sLo $XDG_CONFIG_HOME/fish/functions/fisher.fish
+ fish -c fisher
+end
diff --git a/.config/fish/fishfile b/.config/fish/fishfile
new file mode 100644
index 0000000..88abe6f
--- /dev/null
+++ b/.config/fish/fishfile
@@ -0,0 +1,2 @@
+oh-my-fish/plugin-bang-bang
+fishpkg/fish-prompt-mono
diff --git a/.config/i3status/config b/.config/i3status/config
new file mode 100644
index 0000000..36c8834
--- /dev/null
+++ b/.config/i3status/config
@@ -0,0 +1,58 @@
+# i3status configuration file.
+# see "man i3status" for documentation.
+
+# It is important that this file is edited as UTF-8.
+# The following line should contain a sharp s:
+# ß
+# If the above line is not correctly displayed, fix your editor first!
+
+general {
+ output_format = "i3bar"
+ colors = true
+ interval = 5
+}
+
+order += "ipv6"
+order += "memory"
+order += "disk /"
+order += "wireless _first_"
+#order += "ethernet _first_"
+order += "battery 0"
+order += "volume master"
+order += "load"
+order += "tztime local"
+order += "tztime tehran"
+
+wireless _first_ {
+ format_up = "W: (%quality at %essid) %ip"
+ format_down = "W: down"
+}
+
+ethernet _first_ {
+ # if you use %speed, i3status requires root privileges
+ format_up = "E: %ip (%speed)"
+ format_down = "E: down"
+}
+
+battery 0 {
+ format = "%status %percentage %remaining %emptytime"
+ #path = "/sys/class/power_supply/rk-bat/uevent"
+ path = "/sys/class/power_supply/cw2015-battery/uevent"
+}
+
+tztime local {
+ format = "%Y-%m-%d %H:%M:%S"
+}
+
+tztime tehran {
+ format = "Teh:%H:%M"
+ timezone = "Asia/Tehran"
+}
+
+load {
+ format = "%1min"
+}
+
+disk "/" {
+ format = "%avail"
+}
diff --git a/.config/radicale/config b/.config/radicale/config
new file mode 100644
index 0000000..454848d
--- /dev/null
+++ b/.config/radicale/config
@@ -0,0 +1,4 @@
+[storage]
+type = radicale_storage_decsync
+filesystem_folder = ~/.local/var/lib/radicale/collections
+decsync_dir = ~/.local/share/decsync
diff --git a/.config/sway/blue032 b/.config/sway/blue032
new file mode 100644
index 0000000..812b029
--- /dev/null
+++ b/.config/sway/blue032
@@ -0,0 +1 @@
+output eDP-1 pos 0 0
diff --git a/.config/sway/config b/.config/sway/config
new file mode 100644
index 0000000..69c2727
--- /dev/null
+++ b/.config/sway/config
@@ -0,0 +1,69 @@
+include ./defaults
+
+### Variables
+set $mod Mod4
+set $menu rofi -show run
+#bemenu-run
+set $term alacritty
+
+### Key Bindings
+# I repeat them here to add `--to-code --no-warn` flag to make the bindings layout agnostic.
+bindsym --to-code --no-warn {
+ $mod+$left focus left
+ $mod+$down focus down
+ $mod+$up focus up
+ $mod+$right focus right
+}
+bindsym --to-code --no-warn $mod+Return exec $term
+bindsym --to-code --no-warn $mod+Shift+q kill
+bindsym --to-code --no-warn $mod+d exec $menu
+bindsym --to-code --no-warn $mod+Shift+c reload
+
+input * {
+ xkb_layout "de,ir"
+ xkb_options "lv3:caps_switch,grp:lctrl_lwin_toggle,shift:both_shiftlock"
+}
+
+input type:touchpad {
+ tap disabled
+ natural_scroll enabled
+}
+
+bar {
+ status_command i3status
+}
+
+# Enable fzf-based floating app menu
+#for_window [app_id="^launcher$"] floating enable, sticky enable, resize set 30 ppt 60 ppt, border pixel 10
+#set $menu exec $term --class=launcher -e sway-launcher-desktop
+#bindsym --to-code --no-warn $mod+tab exec $menu
+
+#
+# Multimedia keys - Courtesy of great Arch Linux wiki and its awesome users.
+#
+bindsym XF86AudioRaiseVolume exec pactl set-sink-volume @DEFAULT_SINK@ +5%
+bindsym XF86AudioLowerVolume exec pactl set-sink-volume @DEFAULT_SINK@ -5%
+bindsym XF86AudioMute exec pactl set-sink-mute @DEFAULT_SINK@ toggle
+bindsym XF86AudioMicMute exec pactl set-source-mute @DEFAULT_SOURCE@ toggle
+bindsym XF86MonBrightnessDown exec brightnessctl set 5%-
+bindsym XF86MonBrightnessUp exec brightnessctl set +5%
+bindsym XF86AudioPlay exec playerctl play-pause
+bindsym XF86AudioNext exec playerctl next
+bindsym XF86AudioPrev exec playerctl previous
+bindsym XF86Search exec bemenu-run
+
+#
+# Screen capture
+# Thanks to Gentoo wiki at https://wiki.gentoo.org/wiki/Sway
+#
+set $ps1 Print
+set $ps2 Control+Print
+set $ps3 Alt+Print
+set $ps4 Alt+Control+Print
+
+bindsym $ps1 exec grim - | wl-copy
+bindsym $ps2 exec grim -g "$(slurp)" - | wl-copy
+bindsym $ps3 exec grim $(xdg-user-dir PICTURES)/Screenshots/ps_$(date +"%Y%m%d%H%M%S").png
+bindsym $ps4 exec grim -g "$(slurp)" $(xdg-user-dir PICTURES)/Screenshots/ps_$(date +"%Y%m%d%H%M%S").png
+
+include ~/.config/sway/`hostname`
diff --git a/.config/sway/defaults b/.config/sway/defaults
new file mode 100644
index 0000000..fa32210
--- /dev/null
+++ b/.config/sway/defaults
@@ -0,0 +1,217 @@
+# Default config for sway
+#
+# Copy this to ~/.config/sway/config and edit it to your liking.
+#
+# Read `man 5 sway` for a complete reference.
+
+### Variables
+#
+# Logo key. Use Mod1 for Alt.
+set $mod Mod4
+# Home row direction keys, like vim
+set $left h
+set $down j
+set $up k
+set $right l
+# Your preferred terminal emulator
+set $term alacritty
+# Your preferred application launcher
+# Note: pass the final command to swaymsg so that the resulting window can be opened
+# on the original workspace that the command was run on.
+set $menu dmenu_path | dmenu | xargs swaymsg exec --
+
+### Output configuration
+#
+# Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/)
+output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill
+#
+# Example configuration:
+#
+# output HDMI-A-1 resolution 1920x1080 position 1920,0
+#
+# You can get the names of your outputs by running: swaymsg -t get_outputs
+
+### Idle configuration
+#
+# Example configuration:
+#
+# exec swayidle -w \
+# timeout 300 'swaylock -f -c 000000' \
+# timeout 600 'swaymsg "output * dpms off"' resume 'swaymsg "output * dpms on"' \
+# before-sleep 'swaylock -f -c 000000'
+#
+# This will lock your screen after 300 seconds of inactivity, then turn off
+# your displays after another 300 seconds, and turn your screens back on when
+# resumed. It will also lock your screen before your computer goes to sleep.
+
+### Input configuration
+#
+# Example configuration:
+#
+# input "2:14:SynPS/2_Synaptics_TouchPad" {
+# dwt enabled
+# tap enabled
+# natural_scroll enabled
+# middle_emulation enabled
+# }
+#
+# You can get the names of your inputs by running: swaymsg -t get_inputs
+# Read `man 5 sway-input` for more information about this section.
+
+### Key bindings
+#
+# Basics:
+#
+ # Start a terminal
+ bindsym --to-code $mod+Return exec $term
+
+ # Kill focused window
+ bindsym --to-code $mod+Shift+q kill
+
+ # Start your launcher
+ bindsym --to-code $mod+d exec $menu
+
+ # Drag floating windows by holding down $mod and left mouse button.
+ # Resize them with right mouse button + $mod.
+ # Despite the name, also works for non-floating windows.
+ # Change normal to inverse to use left mouse button for resizing and right
+ # mouse button for dragging.
+ floating_modifier $mod normal
+
+ # Reload the configuration file
+ bindsym --to-code $mod+Shift+c reload
+
+ # Exit sway (logs you out of your Wayland session)
+ bindsym --to-code $mod+Shift+e exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -b 'Yes, exit sway' 'swaymsg exit'
+#
+# Moving around:
+#
+ # Move your focus around
+ bindsym --to-code $mod+$left focus left
+ bindsym --to-code $mod+$down focus down
+ bindsym --to-code $mod+$up focus up
+ bindsym --to-code $mod+$right focus right
+ # Or use $mod+[up|down|left|right]
+ bindsym --to-code $mod+Left focus left
+ bindsym --to-code $mod+Down focus down
+ bindsym --to-code $mod+Up focus up
+ bindsym --to-code $mod+Right focus right
+
+ # Move the focused window with the same, but add Shift
+ bindsym --to-code $mod+Shift+$left move left
+ bindsym --to-code $mod+Shift+$down move down
+ bindsym --to-code $mod+Shift+$up move up
+ bindsym --to-code $mod+Shift+$right move right
+ # Ditto, with arrow keys
+ bindsym --to-code $mod+Shift+Left move left
+ bindsym --to-code $mod+Shift+Down move down
+ bindsym --to-code $mod+Shift+Up move up
+ bindsym --to-code $mod+Shift+Right move right
+#
+# Workspaces:
+#
+ # Switch to workspace
+ bindsym --to-code $mod+1 workspace number 1
+ bindsym --to-code $mod+2 workspace number 2
+ bindsym --to-code $mod+3 workspace number 3
+ bindsym --to-code $mod+4 workspace number 4
+ bindsym --to-code $mod+5 workspace number 5
+ bindsym --to-code $mod+6 workspace number 6
+ bindsym --to-code $mod+7 workspace number 7
+ bindsym --to-code $mod+8 workspace number 8
+ bindsym --to-code $mod+9 workspace number 9
+ bindsym --to-code $mod+0 workspace number 10
+ # Move focused container to workspace
+ bindsym --to-code $mod+Shift+1 move container to workspace number 1
+ bindsym --to-code $mod+Shift+2 move container to workspace number 2
+ bindsym --to-code $mod+Shift+3 move container to workspace number 3
+ bindsym --to-code $mod+Shift+4 move container to workspace number 4
+ bindsym --to-code $mod+Shift+5 move container to workspace number 5
+ bindsym --to-code $mod+Shift+6 move container to workspace number 6
+ bindsym --to-code $mod+Shift+7 move container to workspace number 7
+ bindsym --to-code $mod+Shift+8 move container to workspace number 8
+ bindsym --to-code $mod+Shift+9 move container to workspace number 9
+ bindsym --to-code $mod+Shift+0 move container to workspace number 10
+ # Note: workspaces can have any name you want, not just numbers.
+ # We just use 1-10 as the default.
+#
+# Layout stuff:
+#
+ # You can "split" the current object of your focus with
+ # $mod+b or $mod+v, for horizontal and vertical splits
+ # respectively.
+ bindsym --to-code $mod+b splith
+ bindsym --to-code $mod+v splitv
+
+ # Switch the current container between different layout styles
+ bindsym --to-code $mod+s layout stacking
+ bindsym --to-code $mod+w layout tabbed
+ bindsym --to-code $mod+e layout toggle split
+
+ # Make the current focus fullscreen
+ bindsym --to-code $mod+f fullscreen
+
+ # Toggle the current focus between tiling and floating mode
+ bindsym --to-code $mod+Shift+space floating toggle
+
+ # Swap focus between the tiling area and the floating area
+ bindsym --to-code $mod+space focus mode_toggle
+
+ # Move focus to the parent container
+ bindsym --to-code $mod+a focus parent
+#
+# Scratchpad:
+#
+ # Sway has a "scratchpad", which is a bag of holding for windows.
+ # You can send windows there and get them back later.
+
+ # Move the currently focused window to the scratchpad
+ bindsym --to-code $mod+Shift+minus move scratchpad
+
+ # Show the next scratchpad window or hide the focused scratchpad window.
+ # If there are multiple scratchpad windows, this command cycles through them.
+ bindsym --to-code $mod+minus scratchpad show
+#
+# Resizing containers:
+#
+mode "resize" {
+ # left will shrink the containers width
+ # right will grow the containers width
+ # up will shrink the containers height
+ # down will grow the containers height
+ bindsym --to-code $left resize shrink width 10px
+ bindsym --to-code $down resize grow height 10px
+ bindsym --to-code $up resize shrink height 10px
+ bindsym --to-code $right resize grow width 10px
+
+ # Ditto, with arrow keys
+ bindsym --to-code Left resize shrink width 10px
+ bindsym --to-code Down resize grow height 10px
+ bindsym --to-code Up resize shrink height 10px
+ bindsym --to-code Right resize grow width 10px
+
+ # Return to default mode
+ bindsym --to-code Return mode "default"
+ bindsym --to-code Escape mode "default"
+}
+bindsym --to-code $mod+r mode "resize"
+
+#
+# Status Bar:
+#
+# Read `man 5 sway-bar` for more information about this section.
+bar {
+ position top
+
+ # When the status_command prints a new line to stdout, swaybar updates.
+ # The default just shows the current date and time.
+ status_command while date +'%Y-%m-%d %l:%M:%S %p'; do sleep 1; done
+
+ colors {
+ statusline #ffffff
+ background #323232
+ inactive_workspace #32323200 #32323200 #5c5c5c
+ }
+}
+
+include /etc/sway/config.d/*
diff --git a/.config/sway/rock b/.config/sway/rock
new file mode 100644
index 0000000..27956d7
--- /dev/null
+++ b/.config/sway/rock
@@ -0,0 +1,3 @@
+set $menu bemenu-run
+set $term termite
+
diff --git a/.config/systemd/user/radicale.service b/.config/systemd/user/radicale.service
new file mode 100644
index 0000000..92efe26
--- /dev/null
+++ b/.config/systemd/user/radicale.service
@@ -0,0 +1,10 @@
+# See https://radicale.org/2.1.html#documentation/basic-setup/running-as-a-service/linux-with-systemd-as-a-user
+[Unit]
+Description=A simple CalDAV (calendar) and CardDAV (contact) server
+
+[Service]
+ExecStart=/usr/bin/env python3 -m radicale
+Restart=on-failure
+
+[Install]
+WantedBy=default.target
diff --git a/.local/bin/kill-kube-ns b/.local/bin/kill-kube-ns
new file mode 100755
index 0000000..6fc9cc0
--- /dev/null
+++ b/.local/bin/kill-kube-ns
@@ -0,0 +1,48 @@
+#!/bin/bash
+
+###############################################################################
+# Copyright (c) 2018 Red Hat Inc
+#
+# See the NOTICE file(s) distributed with this work for additional
+# information regarding copyright ownership.
+#
+# This program and the accompanying materials are made available under the
+# terms of the Eclipse Public License 2.0 which is available at
+# http://www.eclipse.org/legal/epl-2.0
+#
+# SPDX-License-Identifier: EPL-2.0
+###############################################################################
+
+set -eo pipefail
+
+die() { echo "$*" 1>&2 ; exit 1; }
+
+need() {
+ which "$1" &>/dev/null || die "Binary '$1' is missing but required"
+}
+
+# checking pre-reqs
+
+need "jq"
+need "curl"
+need "kubectl"
+
+PROJECT="$1"
+shift
+
+test -n "$PROJECT" || die "Missing arguments: kill-ns <namespace>"
+
+kubectl proxy &>/dev/null &
+PROXY_PID=$!
+killproxy () {
+ kill $PROXY_PID
+}
+trap killproxy EXIT
+
+sleep 1 # give the proxy a second
+
+kubectl get namespace "$PROJECT" -o json | jq 'del(.spec.finalizers[] | select("kubernetes"))' | curl -s -k -H "Content-Type: application/json" -X PUT -o /dev/null --data-binary @- http://localhost:8001/api/v1/namespaces/$PROJECT/finalize && echo "Killed namespace: $PROJECT"
+
+# proxy will get killed by the trap
+
+
diff --git a/.local/var/lib/radicale/README.md b/.local/var/lib/radicale/README.md
new file mode 100644
index 0000000..3ff9441
--- /dev/null
+++ b/.local/var/lib/radicale/README.md
@@ -0,0 +1 @@
+This is a place holder to be able to add this directory to git.
diff --git a/.profile b/.profile
new file mode 100644
index 0000000..38c74f0
--- /dev/null
+++ b/.profile
@@ -0,0 +1,44 @@
+# Generic
+export LANG=en_US.UTF-8
+export EDITOR=vim
+export TIMER_FORMAT='%d'
+export TIMER_PRECISION=2
+
+# Main shadow bin directory
+export PATH=$HOME/.local/bin:$PATH
+
+# Other bin directories
+export PATH=$HOME/.local/bin/`hostname`:$PATH
+export PATH=$HOME/.cargo/bin:$PATH
+export PATH=$HOME/.yarn/bin:$PATH
+
+# Go
+export GOPATH="$HOME/.go"
+export PATH=$GOPATH/bin:$PATH
+
+export ANDROID_SDK_ROOT=$HOME/Android/Sdk
+
+# Building
+export MAKEFLAGS=-j`lscpu | grep '^CPU(s):' | awk -F' ' '{ print $2 }'`
+export CFLAGS="-O2 -pipe -march=native"
+export CXXFLAGS="${CFLAGS}"
+
+# Sway compatiblity
+if [ "$XDG_SESSION_DESKTOP" = "sway" ] ; then
+ # https://github.com/swaywm/sway/issues/595
+ export _JAVA_AWT_WM_NONREPARENTING=1
+fi
+
+# Preferred editor for local and remote sessions
+# if [[ -n $SSH_CONNECTION ]]; then
+# export EDITOR='vim'
+# else
+# export EDITOR='mvim'
+# fi
+
+# Compilation flags
+# export ARCHFLAGS="-arch x86_64"
+
+# ssh
+# export SSH_KEY_PATH="~/.ssh/rsa_id"
+
diff --git a/.vimrc b/.vimrc
new file mode 100644
index 0000000..5c8c116
--- /dev/null
+++ b/.vimrc
@@ -0,0 +1,61 @@
+set nocompatible " required
+filetype off " required
+
+" set the runtime path to include Vundle and initialize
+set rtp+=~/.vim/bundle/Vundle.vim
+call vundle#begin()
+
+" alternatively, pass a path where Vundle should install plugins
+"call vundle#begin('~/some/path/here')
+
+" let Vundle manage Vundle, required
+Plugin 'gmarik/Vundle.vim'
+
+" add all your plugins here (note older versions of Vundle
+" used Bundle instead of Plugin)
+
+Plugin 'vim-syntastic/syntastic'
+Plugin 'vim-airline/vim-airline'
+Plugin 'vim-airline/vim-airline-themes'
+Plugin 'nvie/vim-flake8'
+Plugin 'scrooloose/nerdtree'
+Plugin 'kien/ctrlp.vim'
+Plugin 'rust-lang/rust.vim'
+Plugin 'racer-rust/vim-racer'
+Plugin 'ConradIrwin/vim-bracketed-paste'
+"Bundle 'Valloric/YouCompleteMe'
+Plugin 'junegunn/fzf'
+" Save the buffer whenever text is changed.
+" https://stackoverflow.com/a/55761306
+" autocmd TextChanged,TextChangedI <buffer> silent write
+
+
+" All of your Plugins must be added before the following line
+call vundle#end() " required
+filetype plugin indent on " required
+
+let python_highlight_all=1
+let g:airline_theme='wombat'
+set encoding=utf-8
+set mouse-=a
+syntax on
+
+"split navigations
+nnoremap <C-J> <C-W><C-J>
+nnoremap <C-K> <C-W><C-K>
+nnoremap <C-L> <C-W><C-L>
+nnoremap <C-H> <C-W><C-H>
+
+au BufNewFile,BufRead *.py
+ \ set tabstop=4 |
+ \ set softtabstop=4 |
+ \ set shiftwidth=4 |
+ \ set textwidth=79 |
+ \ set expandtab |
+ \ set autoindent |
+ \ set fileformat=unix
+
+"au BufRead,BufNewFile *.py,*.pyw,*.c,*.h match BadWhitespace /\s\+$/
+let NERDTreeIgnore=['\.pyc$', '\~$'] "ignore files in NERDTree
+map <C-n> :NERDTreeToggle<CR>
+
diff --git a/.zshrc b/.zshrc
new file mode 100644
index 0000000..8446c99
--- /dev/null
+++ b/.zshrc
@@ -0,0 +1,49 @@
+# Path to your oh-my-zsh installation.
+if [ ! -d "/usr/share/oh-my-zsh" ]; then
+ export ZSH=$HOME/.oh-my-zsh
+else
+ export ZSH="/usr/share/oh-my-zsh"
+fi
+
+# simple, frisk, mrtazz, lambda, maran, robbyrussel, random
+ZSH_THEME=simple
+
+# Uncomment the following line to use case-sensitive completion.
+CASE_SENSITIVE="false"
+
+# HYPHEN_INSENSITIVE="true"
+DISABLE_AUTO_UPDATE="true"
+
+# Standard plugins can be found in ~/.oh-my-zsh/plugins/*
+# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/
+plugins=(git autojump history-substring-search)# timer gem rust cargo)
+
+# Activate oh-my-zsh
+source $ZSH/oh-my-zsh.sh
+
+_direnv_hook() {
+ eval "$("/usr/bin/direnv" export zsh)";
+}
+typeset -ag precmd_functions;
+if [[ -z ${precmd_functions[(r)_direnv_hook]} ]]; then
+ precmd_functions+=_direnv_hook;
+fi
+
+# nvm settings (good)
+#export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")"
+#[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
+
+if [[ -a `which kubectl` ]]; then
+ source <(kubectl completion zsh 2> /dev/null);
+fi
+
+# For X.org
+#setxkbmap \
+# -layout de,ir \
+# -variant nodeadkeys,pes_keypad \
+# -option '' \
+# -option 'grp:alt_shift_toggle' \
+# -option 'shift:both_shiftlock' \
+# -option 'lv3:caps_switch' \
+# -option 'terminate:ctrl_alt_bkspc' \
+# -option 'eurosign:e'