-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtry-tbl.el
246 lines (214 loc) · 12.1 KB
/
try-tbl.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
;;; try-tbl.el --- Try-Code dependent data
;; Copyright (C) 1989--2001 Kaoru Maeda, Yasushi Saito and KITAJIMA Akira.
;; Author: Kaoru Maeda <[email protected]>
;; Yasushi Saito <[email protected]>
;; KITAJIMA Akira <[email protected]>
;; $Id: tc-tbl.el,v 1.10 2002/12/18 02:03:31 kitajima Exp $
;; 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 2 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, write to the Free Software
;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
;;; Commentary:
;;
;; set following variables:
;; tcode-input-method
;; tcode-transparent-mode-indicator
;; tcode-tcode-mode-indicator
;; tcode-alnum-2byte-tcode-mode-indicator
;; tcode-hiragana-mode-indicator
;; tcode-katakana-mode-indicator
;; tcode-tbl
;; tcode-non-2-stroke-char-list
;; tcode-another-table
;; tcode-special-commands-alist
;; tcode-mode-help-string
;; tcode-stroke-file-name
;; eelll-text
;;; Code:
(require 'tc)
(setq tcode-input-method 'trycode)
(setq tcode-transparent-mode-indicator "--"
tcode-tcode-mode-indicator "TC"
tcode-alnum-2byte-tcode-mode-indicator "T"
tcode-hiragana-mode-indicator ""
tcode-katakana-mode-indicator "")
(setq tcode-tbl [
"■■■■■■■■■■ヮヰヱヵヶ請境系探象ゎゐゑ沖縄盛革突温捕肺宙泉署奮依繊借須訳"
"■■■■■■■■■■丑臼宴縁曳尚賀岸責漁於汚乙穏捨益援周域荒拝暖誠縮腹織父枚乱香"
"■■■■■■■■■■鬼虚狭脅驚舎喜幹丘糖奇既菊却享康徒景処ぜ届誕聖縦晩譲ヘ模降走"
"■■■■■■■■■■孤誇黄后耕布苦圧恵固巧克懇困昏邦舞雑漢緊潮臓仁尺班激干彦均又"
"■■■■■■■■■■奉某貌卜鋼姿絶密秘押詞至蚕穀磁衆節杉肉除俳頂染城陛測血散笑弁"
"■■■■■■■■■■湖礼著移郷息詩拾暑昭償欧努底亜悲柱笛童畑禁硝樹句礎皇像肥沿吸"
"■■■■■■■■■■端飾郵塩群鳴星析遷宣紅傷豪維脱鼠曹奏尊刀絹被源願臨胸謝損俵灰"
"■■■■■■■■■■刷寿順危砂庶粧丈称蒸舗充喫腕暴冬貝犬森林批慶渉竜併敬舌敵貧閣"
"■■■■■■■■■■震扱片札乞暗乃如尼帳輪倒操柄魚馬歌絵弓晴就駐揮丹鮮穴銭銅墓机"
"■■■■■■■■■■弘痛票訴遺欄龍略慮累則存倍牛釈麦弟兄姉妹綱潟創背皮孝祖燃預貴"
"ヲ哀暇啓把酸昼炭稲湯果告策首農歩回務島開報紙館夜位給員ど代レ欠夏彼妻善相家的対歴"
"ゥ逢牙掲伐貿捜異隣旧概買詳由死キせ区百木音王放々応分よル千ア財針裏居差付プばュ作"
"ヴ宛壊携避攻焼闘奈夕武残両在! や出タ手保案曲情引職7 か( トれ従骨厚顔量内工八テ見"
"ヂ囲較劇卑盤帯易速拡風階能論増コ山者発立横興刺側覚きっ日国二適類御宇推九名川機チ"
"ヅ庵寒賢藩汽換延雪互細古利ペゃナ金マ和女崎白ぐ官球上く8 え年母奥因酒伸サ建パ第入"
"簡徴触宗植鼻索射濁慢害賃整軽評佐法数郎談服声任検豊美題井洋実爆仲茶率比昔短岩巨敗"
"承章候途複氷冊需詑迷撃折追隊角接備最急験変審改昇芸宿制集安画陽構旅施曜遠ォ将ぞ塚"
"快否歯筆里油皿輯蓄戻浴秀糸春幸記朝知ワ送限研労統役セ運ツ特谷ァ導認健尾序振練念働"
"包納頼逃寝緑賛瞬貯羊積程断低減モ資士費ィ逆企精ざ印神び打勤ャ殺負何履般耳授版効視"
"唱暮憲勉罪芽飲盾虫泳故鉱提児敷無石屋解募令違装然確優公品語演券悪秋非便示即難普辺"
"ぱ慰我兼菱桜瀬鳥催障収際太園船中スもお定種岡結進真3 と〇てるヒ江別考権ッ人三京ち"
"ぴ為掛嫌紐典博筋忠乳若雄査ふ賞わラ東生ろ宅熟待取科ーした一が及久蔵早造ロク万方フ"
"ぷ陰敢顕描採謡希仏察指氏丸続ェう4 ) 十リ料土活ね参い、の5 1 投義算半県んまンつ四"
"ぺ隠甘牽憤君純副盟標ぎ格次習火あこ6 学月受予切育池。◆0 ・2 込沢軍青清けイす電地"
"ぽ胃患厳弊犯余堀肩療思術広門聞本さら高シ英ボ加室少ではになを転空性使級業時「長み"
"朱遅甲致汎旗衰滋沈己病終起路越む南原駅物勢必講愛管要設水藤有素兵専親寮ホ共ブ平楽"
"陣鶴鹿貨絡泣趨湿添已常張薬防得ケ式戦関男輸形助◇流連鉄教力ベ毛永申袋良私ゴ来信午"
"眼繁誌招季救垂甚徹巳寺質づ港条話座線ダ橋基好味宝争デ現エ他度等浅頃落命村ガ製校ご"
"執紹夢卸阿鏡粋荷爪巴停領容玉右べ民ソ点遇足草築観言車成天世文板客師税飛ノ完重約各"
"岳刑弱雲窓訓寸瞳陶祭河置供試席期ゾ歳強係婦段衛額渋主映書可へ伝庭課着坂近外米ョ光"
"ぁ熊瓦幕梨呼幅歓功盗徳渡守登退店持町所ほ件友卒初慣行ド円小ジヨ誤証含% 海道ず西げ"
"ぃ媛覧棒埼紀破郡抗幡械刊訪融雨全じ自議明宮伊求技写通カ社野同判規感値ギ当理メウグ"
"ぅ阪卵亡栃房績識属衣帝始了極熱バ部六経動局頭配黒院だり—め大済吉ゆ器照不合面政オ"
"ぇ岐翌閉茨去疑ぢ綿離読鈴恐督況後間場ニ産向府富直倉新」9 子五説週号葉派委化ビ目市"
"ぉ阜律幼俺秒範核影麻族丁未才返問ム七住北割ぶ番望元事田会前そ休省央福毎気売下都株"
"欲巣茂述朗似臣灯牧往帰庁昨跡ゲ洗羽個医静億録赤想消支協用表正図挙険ゼ波ヤ心界意今"
"迫災恋脳老仮径束毒脈監寄裁達芝響忘討史環色貸販編仕先多商ハ交之末ぼ街免再ネ〜口台"
"留列刻豆看潔菜孫梅勇竹注介具失司迎華許補左態花栄ザ調混ポ決ミ州払乗庫状団計夫食総"
"替沼? 辞献枝祝兆飯液ゅ修究答養復並浦ユ冷ぬ展警型誰組選党択体例満津準遊戸ひょ価与"
"還更占箱矢飼松腸粉恩志抜航層深担陸巻競護根様独止堂銀以ヌ営治字材過諸単身ピ勝反ズ"
])
(setq tcode-non-2-stroke-char-list
(mapcar (function
(lambda (str)
(tcode-string-to-char str)))
'("■" "◆" "◇")))
(setq tcode-another-table nil)
(setq tcode-special-commands-alist
'(((0 0) . (lambda () (tcode-show-tables nil nil)))
; 11 : LL表の表示
((0 9) . (lambda () (tcode-show-tables nil t)))
; 10 : LR表の表示
((9 0) . (lambda () (tcode-show-tables t nil)))
; 01 : RL表の表示
((9 9) . (lambda () (tcode-show-tables t t)))
; 00 : RR表の表示
((1 1) . tcode-start-jiscode)
; 22 : JIS コード表入力
((2 2) . tcode-toggle-alnum-mode)
; 33 : 1-2バイト切り換え
((2 1) . tcode-switch-variable)
; 32 : 句読点のトグル
((3 3) . (lambda ()
(tcode-display-stroke-sequence tcode-last-help-char-list)))
; 44 : ヘルプ
((4 4) . (lambda () (tcode-query-stroke (point))))
; 55 : ヘルプ
((6 6) . tcode-bushu-begin-alternate-conversion)
; 77 : postfix 部首合成変換
((7 7) . (lambda () (tcode-transpose-strokes nil)))
; 88 : transpose-strokes
((8 8) . tcode-clear)
; 99 : 部首合成変換などのキャンセル
((26 23) . tcode-bushu-begin-conversion) ; jf : 部首合成変換の開始
((25 23) . tcode-kuten)
((26 22) . tcode-touten)
((23 26) . tcode-mazegaki-begin-conversion)
; fj: 交ぜ書き変換
((9 8) . tcode-mazegaki-begin-alternate-conversion)
; 前置・後置が逆の交ぜ書き変換
;; 「18」で読み1文字の後置型交ぜ書き変換
((0 7) . (lambda ()
(tcode-mazegaki-convert 1 current-prefix-arg)))
;; 「28」で読み2文字の後置型交ぜ書き変換
((1 7) . (lambda ()
(tcode-mazegaki-convert 2 current-prefix-arg)))
;; 「38」で読み3文字の後置型交ぜ書き変換
((2 7) . (lambda ()
(tcode-mazegaki-convert 3 current-prefix-arg)))
;; 「48」で読み4文字の後置型交ぜ書き変換
((3 7) . (lambda ()
(tcode-mazegaki-convert 4 current-prefix-arg)))
;; 「58」で活用する語を対象とした後置型交ぜ書き変換
((4 7) . (lambda () (tcode-mazegaki-convert nil t)))
;; 「29」で読み2文字の活用する語を対象とした
;; 後置型交ぜ書き変換
((1 8) . (lambda () (tcode-mazegaki-convert 2 t)))
;; 「39」で読み3文字の活用する語を対象とした
;; 後置型交ぜ書き変換
((2 8) . (lambda () (tcode-mazegaki-convert 3 t)))
;; 「49」で読み4文字の活用する語を対象とした
;; 後置型交ぜ書き変換
((3 8) . (lambda () (tcode-mazegaki-convert 4 t)))
;; 「59」で読み5文字の活用する語を対象とした
;; 後置型交ぜ書き変換
((4 8) . (lambda () (tcode-mazegaki-convert 5 t)))))
(setq tcode-mode-help-string "\
Tコードモード中のキー操作は次のとおり。
jf : 部首合成変換モードに入る。jfを打ち続けると再帰的に部首合成変換を
行うことができる(see variable `tcode-use-postfix-bushu-as-default')。
fj : 交ぜ書き変換を行う(see variable `tcode-use-prefix-mazegaki')。
00, 01, 10, 11 : Tコードの表を表示する(0が左、1が右)。
22 : JIS コード一覧表による入力。
32 : 、。と, . を切り替える。(see variable `tcode-switch-table-list')。
33 : Tコード表にある英数字・記号の文字コードの1バイト・2バイト切り替え。
44 : 直前に表示した打ち方を再表示する。
55 : ポイント位置にある文字の打ち方を表示する。
58 : 活用語を優先して交ぜ書き変換を行う。
77 : ポイント前にある2文字で部首合成変換を行う。
88 : ポイント位置にある文字を逆ストローク化する(例: 味->の)。
行末ではポイントの直前の文字を変換する。
99 : 交ぜ書き変換モードや部首合成変換モードにいた時に、
それらを全部キャンセルする。また、ヘルプを消す。
[1-4]8, [2-5]9: 文字数を指定して交ぜ書き変換を行う。
\\[toggle-input-method] : Tコードモードを抜ける。
初めて起動された時には,`tcode-ready-hook' を実行する。
また、起動される度に`tcode-toggle-hook'を実行する。")
(setq tcode-stroke-file-name (concat tcode-data-directory "trycode.st"))
(setq eelll-text "EELLLTXT")
(setq tcode-key-num 41
tcode-ext-keys '(32))
(let ((i 0))
(while (< i 40)
(setq tcode-special-commands-alist
(cons (cons (list i 40)
'try-code-verbose-stroke)
tcode-special-commands-alist))
(setq i (1+ i))))
(defun try-code-verbose-stroke ()
(interactive)
(let ((l tcode-this-command-keys) x)
(while (cdr l)
(insert (car l))
(setq l (cdr l)))))
(setq tcode-special-prefix-alist
'(((40) "try-etbl" "■" "■" "□" "回")))
(setq tcode-stroke-to-string-function 'try-code-stroke-to-string)
(defvar try-code-stroke-to-string-use-association 'stroke)
(defun try-code-stroke-to-string (stroke)
(let ((dat (tcode-stroke-prefix-match stroke)))
(if (null dat)
(tcode-stroke-to-string stroke)
(let ((x (and try-code-stroke-to-string-use-association
(tcode-decode (cdr dat)))))
(if (not (and (eq 'complete (car x))
(char-or-string-p (cdr x))))
(setq x nil)
(setq x (cdr x))
(if (not (stringp x))
(setq x (char-to-string x))))
(concat (nth 2 (car dat))
(if x
(if (eq try-code-stroke-to-string-use-association 'stroke)
(concat x (tcode-stroke-to-string (cdr dat)))
x)
(if (equal '(40) (cdr dat))
(tcode-key-to-help-string 40)
(tcode-stroke-to-string (cdr dat))))))
)))
;;; try-tbl.el ends here