This repository has been archived on 2024-10-22. You can view files and clone it, but cannot push or open issues or pull requests.
spacemacs/layers/+intl/keyboard-layout/config.el

111 lines
3.4 KiB
EmacsLisp

;;; config.el --- keyboard-layout Layer configuration File for Spacemacs
;;
;; Copyright (c) 2012-2017 Sylvain Benner & Contributors
;;
;; Author: Fabien Dubosson <fabien.dubosson@gmail.com>
;; URL: https://github.com/syl20bnr/spacemacs
;;
;; This file is not part of GNU Emacs.
;;
;;; License: GPLv3
;;------------------------------------------------------------------------------
;; PUBLIC VARIABLES
;;------------------------------------------------------------------------------
(defvar kl-layout 'dvorak
"The keyboard-layout to use. Possible values are `colemak',
`dvorak', `bepo' and `workman'.")
(defvar kl-enabled-configurations nil
"If non nil, `keyboard-layout' will enable configurations only
for the passed list of symbols. Configurations that are also in
`kl-disabled-configurations' will not be loaded.")
(defvar kl-disabled-configurations nil
"If non nil, `keyboard-layout' will disable configurations for
the passed list of symbols. This list takes priority over
`kl-enabled-configurations', so they will not be loaded in
any case.")
;;------------------------------------------------------------------------------
;; PRIVATE VARIABLES
;;------------------------------------------------------------------------------
(defvar kl--base-rebinding-maps
'((bepo . (("c" . "h")
("t" . "j")
("s" . "k")
("r" . "l")
;;
("h" . "r")
("j" . "t")
("k" . "s")
("l" . "c")))
(colemak . (("n" . "h")
("e" . "j")
("i" . "k")
("o" . "l")
;;
("h" . "n")
("j" . "e")
("k" . "i")
("l" . "o")))
(dvp . (("d" . "h")
("h" . "j")
("t" . "k")
("n" . "l")
;;
("j" . "d")
("k" . "t")
("l" . "n")))
(dvorak . (("h" . "h")
("t" . "j")
("n" . "k")
("s" . "l")
;;
("h" . "h")
("j" . "t")
("k" . "n")
("l" . "s")))
(colemak . (("h" . "h")
("n" . "j")
("e" . "k")
("i" . "l")
;;
("h" . "h")
("j" . "n")
("k" . "e")
("l" . "i")))
(workman . (("y" . "h")
("n" . "j")
("e" . "k")
("o" . "l")
;;
("h" . "y")
("j" . "n")
("k" . "e")
("l" . "o"))))
"The base rebinding map. Dots should be read as `will behave
as'. It should be a bidirectional mapping, i.e. all present
keys should be once in each column.")
(defvar kl--rebinding-maps
(mapcar (lambda (map) `(,(car map) . ,(kl//generate-full-rebinding-map (cdr map))))
kl--base-rebinding-maps)
"The full rebinding map. Dots should be read as `will behave as'.")
(with-eval-after-load 'evil
(defvar kl--all-evil-states
(list evil-normal-state-map
evil-visual-state-map
evil-insert-state-map
evil-emacs-state-map
evil-motion-state-map)
"The list of all evil states.")
(defvar kl--all-evil-states-but-insert
(list evil-normal-state-map
evil-visual-state-map
evil-motion-state-map)
"The list of all evil states except insert."))