blob: 461b674518916ff4365e2fbb59eb95e1f8f4425f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
;;; input-conf.el --- My configurations of input methods -*- lexical-binding: t; -*-
;; Copyright (C) 2022 Jean Sévère Durand
;; Author: Jean Sévère Durand <durand@jsdurand.xyz>
;; Keywords: convenience, abbrev, emulations, i18n
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;; I want to use the built-in input methods for inserting in other
;; languages than English.
;;; Code:
;;; Chinese-zozy
;; This does not work. I shall find another way to do this.
(defun durand-zozy-remap-keys ()
"Remap smoe keys for the input method \"Chinese-zozy\"."
(let ((map (quail-translation-keymap)))
(define-key map (vector ?\") "3")))
(remove-hook 'quail-activate-hook #'durand-zozy-remap-keys)
;;; Default input method
(setq-default default-input-method "devanagari-kyoto-harvard")
;;; Short-cut headlong selection of input methods.
(defvar durand-input-method-list nil
"The list of input methods that I oft use.")
(setq durand-input-method-list
(list "devanagari-kyoto-harvard"
"tamil99"
"chinese-zozy"))
(defun durand-toggle-input ()
"Toggle input method with my customizations."
(interactive)
(cond
((null current-input-method)
(let ((input-method
(minibuffer-with-setup-hook
#'durand-headlong-minibuffer-setup-hook
(completing-read
"Input method: " durand-input-method-list
nil t nil nil "devanagari-kyoto-harvard"))))
(activate-input-method input-method)))
((deactivate-input-method))))
(define-key global-map (vector ?\C-\\) #'durand-toggle-input)
(define-key global-map (vector 3 ?i) #'durand-toggle-input)
;;; Custom french keyboard layout
;; I am used to the french keyboard, so it would be most convenient if
;; the quail packages can automatically translate the keys according
;; to this layout.
(cond
((assoc "durand-fr" quail-keyboard-layout-alist #'string=)
(setcdr
(assoc "durand-fr" quail-keyboard-layout-alist #'string=)
"\
\
&1é2\"3'4(5§6è7!8ç9à0)°-_<> \
aAzZeErRtTyYuUiIoOpP^¨$* \
qQsSdDfFgGhHjJkKlLmMù%`£ \
wWxXcCvVbBnN,?;.:/=+ \
"))
(t
(setq
quail-keyboard-layout-alist
(cons
(cons
"durand-fr"
"\
\
&1é2\"3'4(5§6è7!8ç9à0)°-_<> \
aAzZeErRtTyYuUiIoOpP^¨$* \
qQsSdDfFgGhHjJkKlLmMù%`£ \
wWxXcCvVbBnN,?;.:/=+ \
")
quail-keyboard-layout-alist))))
(quail-set-keyboard-layout "durand-fr")
(provide 'input-conf)
;;; input-conf.el ends here
|