-
Notifications
You must be signed in to change notification settings - Fork 0
/
init-ddskk.el
82 lines (73 loc) · 4.61 KB
/
init-ddskk.el
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
;; azikを利用するように
(setq skk-use-azik t)
(setq skk-sticky-key ";")
(setq skk-azik-keyboard-type 'us101)
(add-hook 'skk-azik-load-hook
(lambda()
;; azikから追加された各種拡張を、SKK寄りに戻すための追加設定
;; 「ん」をqに割り当てるのは、ただでさえ負荷の高い左小指を酷使することになるので、元に戻す
;; qの役割を元に戻したので、「も元に戻す。というか利用しているキーボードだとそこが1キーで押せない。
(setq skk-rom-kana-rule-list (skk-del-alist "q" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "[" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist ";" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "vh" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "vj" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "vk" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "vl" skk-rom-kana-rule-list))
;; 促音はもともとのローマ字と同様に入力できるようにする
(setq skk-rom-kana-rule-list (skk-del-alist "tt" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "kk" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "ss" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "pp" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "dd" skk-rom-kana-rule-list))
(setq skk-rom-kana-rule-list (skk-del-alist "jj" skk-rom-kana-rule-list))
;; Xで辞書登録する場合があるので、この場合でもちゃんと破棄できるようにする
(setq skk-rom-kana-rule-list (append skk-rom-kana-rule-list
'(("!" nil skk-purge-from-jisyo)
("q" nil skk-toggle-characters)
("[" nil "「")
(";" nil skk-sticky-set-henkan-point)
("vh" nil "←")
("vj" nil "↓")
("vk" nil "↑")
("vl" nil "→")
("vv" nil "っ"))))
(setq skk-rule-tree (skk-compile-rule-list
skk-rom-kana-base-rule-list
skk-rom-kana-rule-list))))
;; 送り仮名が厳密に正しいものを優先して表示するようにする
(setq skk-henkan-strict-okuri-precedence t)
;; 変換モードでEnterを押しても改行しないように
(setq skk-egg-like-newline t)
;; 個人辞書の文字コード
(setq skk-jisyo-code 'utf-8-unix)
;; 辞書登録の際にミスを確認する
(setq skk-check-okurigana-on-touroku t)
;; 自動的に送り仮名の設定を行わないようにする
(setq skk-auto-okuri-process nil)
;; 自動的に対応する括弧を入力
(setq skk-auto-insert-paren t)
;; 動的な補完を有効にする
(setq skk-dcomp-activate t)
;; 単語間の学習を有効にする
(require 'skk-study)
(cond (my:use-skkserver
(setq skk-server-host "localhost"
skk-server-portnum "1178"
skk-large-jisyo nil)
(defun skk-open-server-decoding-utf-8 ()
"辞書サーバと接続する。サーバープロセスを返す。 decoding coding-system が euc ではなく utf8 となる。"
(unless (skk-server-live-p)
(setq skkserv-process (skk-open-server-1))
(when (skk-server-live-p)
(let ((code (cdr (assoc "euc" skk-coding-system-alist))))
(set-process-coding-system skkserv-process 'utf-8 code))))
skkserv-process)
(setq skk-mode-hook
'(lambda()
(advice-add 'skk-open-server :override 'skk-open-server-decoding-utf-8))))
(t
;; 辞書を取得する。ただし、ここで取得する辞書はEUC-JPであり、このままだと個人辞書とのcoding違いで読み込めない。
;; そのため、取得した辞書に対して変換をかける必要がある。
(setq skk-get-jisyo-directory (expand-file-name "skk-jisyo" user-emacs-directory)
skk-large-jisyo (expand-file-name "SKK-JISYO.L" skk-get-jisyo-directory))))