442
|
1 /* CANNA interface -*- coding: euc-jp -*-
|
428
|
2
|
|
3 Copyright (C) 1995 Free Software Foundation, Inc.
|
|
4 Copyright (C) 1995 Sun Microsystems, Inc.
|
|
5
|
|
6 This file is part of XEmacs.
|
|
7
|
|
8 XEmacs is free software; you can redistribute it and/or modify it
|
|
9 under the terms of the GNU General Public License as published by the
|
|
10 Free Software Foundation; either version 2, or (at your option) any
|
|
11 later version.
|
|
12
|
|
13 XEmacs is distributed in the hope that it will be useful, but WITHOUT
|
|
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
16 for more details.
|
|
17
|
|
18 You should have received a copy of the GNU General Public License
|
|
19 along with XEmacs; see the file COPYING. If not, write to
|
|
20 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
21 Boston, MA 02111-1307, USA. */
|
|
22
|
|
23 /* Synched up with: Mule 2.3. Not in FSF. */
|
|
24
|
448
|
25 /* Japanese comments were translated 2000-12-06 by Stephen Turnbull
|
|
26 <stephen@xemacs.org>. I haven't verified that the Japanese comments
|
|
27 were correct. YMMV, NO WARRANTY, not even the implied warranty of
|
|
28 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. (^^;;; as the
|
|
29 Japanese say. */
|
428
|
30
|
|
31 /*
|
|
32
|
|
33 Authors: Akira Kon (kon@uxd.fc.nec.co.jp)
|
|
34 Ichiro Hirakura (hirakura@uxd.fc.nec.co.jp)
|
|
35
|
|
36 Functions defined in this file are
|
|
37
|
|
38 (canna-key-proc key)
|
|
39 key: single STRING
|
|
40 RETURNS:
|
|
41 Length of converted string if no error occurs.
|
|
42 Error string if error occurs.
|
|
43 DESCRIPTION:
|
|
44 Convert a key input to a set of strings. The
|
|
45 strings contain both well-formed string and a
|
|
46 intermediate result to show the translation
|
|
47 information to a user. converted strings are
|
|
48 stored in specific variables.
|
|
49
|
|
50 (canna-initialize)
|
|
51 RETURNS:
|
|
52 List of the following things:
|
|
53 - list of keys to toggle Japanese-mode
|
|
54 - error message
|
|
55 - list of warning messages
|
|
56 DESCRIPTION:
|
|
57 Initialize ``canna'', which is a kana-to-kanji
|
613
|
58 converter for XEmacs. The first arg
|
428
|
59 specifies if inserting space character between
|
|
60 BUNSETSU when candidates are displayed. The
|
|
61 second arg specifies server. The third arg
|
|
62 specifies a file which will be used as a
|
|
63 customization description. If nil is
|
|
64 specified for each arg, the default value will
|
|
65 be used.
|
|
66
|
|
67 (canna-finalize)
|
|
68 RETURNS:
|
|
69 list of warning messages
|
|
70 DESCRIPTION:
|
|
71 finalize ``canna'', which is a kana-to-kanji
|
613
|
72 converter for XEmacs. This cause to write
|
428
|
73 miscellaneous informations to kana-to-kanji
|
|
74 dictionary.
|
|
75
|
|
76 (canna-touroku-string string)
|
|
77 string:
|
|
78 String to register to a dictionary.
|
|
79 RETURNS:
|
|
80 The same thing returns as canna-key-proc does.
|
|
81 DESCRIPTION:
|
|
82 Register Kanji words into kana-to-kanji
|
|
83 conversion dictionary.
|
|
84
|
|
85 (canna-set-width width)
|
|
86 width:
|
|
87 Column width of the place where the candidates
|
|
88 of kana-to-kanji conversion will be shown.
|
|
89 RETURNS:
|
|
90 nil
|
|
91 DESCRIPTION:
|
|
92 Set status-line width information, which is
|
|
93 used to display kanji candidates.
|
|
94
|
|
95 (canna-change-mode num)
|
|
96 num:
|
|
97 The mode number of Canna.
|
|
98 RETURNS:
|
|
99 The same thing returns as canna-key-proc does.
|
|
100 DESCRIPTION:
|
|
101 Change Japanese pre-edit mode.
|
|
102
|
|
103 (canna-store-yomi yomi roma)
|
|
104 yomi:
|
|
105 ``Yomi'' to be stored.
|
|
106 roma:
|
|
107 ``Romaji'' which corresponds to the ``Yomi''.
|
|
108 RETURNS:
|
|
109 The same thing returns as canna-key-proc does.
|
|
110 DESCRIPTION:
|
|
111 Store yomi characters as a YOMI of
|
|
112 kana-to-kanji conversion.
|
|
113
|
|
114 (canna-do-function num ch)
|
|
115 num:
|
|
116 A function number to be called.
|
|
117 ch:
|
|
118 A character will be specified in order to feed
|
|
119 the character to the function if the function
|
|
120 needs a input character.
|
|
121 RETURNS:
|
|
122 The same thing returns as canna-key-proc does.
|
|
123 DESCRIPTION:
|
|
124 Do specified function at current mode.
|
|
125
|
|
126 (canna-parse string)
|
|
127 string:
|
|
128 To be parsed.
|
|
129 RETURNS:
|
|
130 List of warning messages.
|
|
131 DESCRIPTION:
|
|
132 Parse customize string.
|
|
133
|
|
134 (canna-query-mode)
|
|
135 RETURNS:
|
|
136 A string which indicate the current mode.
|
|
137 DESCRIPTION:
|
|
138 Get current mode string.
|
|
139
|
|
140 Functions below are used for KKCP compatible library. These
|
|
141 functions provides a base kana-to-kanji conversion system for EGG.
|
|
142 These functions may be used when users want to change the engine
|
|
143 from Wnn to Canna without changing user interface of Japanese input.
|
|
144
|
|
145 (canna-henkan-begin)
|
|
146 (canna-henkan-next)
|
|
147 (canna-bunsetu-henkou)
|
|
148 (canna-henkan-kakutei)
|
|
149 (canna-henkan-end)
|
|
150 (canna-henkan-quit)
|
|
151
|
|
152 */
|
|
153
|
|
154 #include <config.h>
|
|
155 #include "lisp.h"
|
|
156
|
|
157 #include "buffer.h"
|
|
158 #include "file-coding.h"
|
|
159
|
|
160 #ifdef CANNA2
|
|
161 #define IROHA_BC
|
2276
|
162 #define CANNA_NEW_WCHAR_AWARE
|
428
|
163 #include "canna/jrkanji.h"
|
|
164 #include "canna/RK.h"
|
|
165 #else /* !CANNA2 */
|
|
166 #include "iroha/jrkanji.h"
|
|
167 #include "iroha/RK.h"
|
2276
|
168 extern int (*jrBeepFunc) (void);
|
428
|
169 #endif /* !CANNA2 */
|
|
170 extern char *jrKanjiError;
|
|
171
|
448
|
172 /* #### is this global really necessary? */
|
428
|
173 #define KEYTOSTRSIZE 2048
|
1650
|
174 static char key_buffer[KEYTOSTRSIZE];
|
428
|
175 static char **warning;
|
|
176
|
|
177 static int canna_empty_info, canna_through_info;
|
|
178 static int canna_underline;
|
|
179 static int canna_inhibit_hankakukana;
|
|
180
|
|
181 static Lisp_Object Vcanna_kakutei_string;
|
|
182 static Lisp_Object Vcanna_kakutei_yomi;
|
|
183 static Lisp_Object Vcanna_kakutei_romaji;
|
|
184 static Lisp_Object Vcanna_henkan_string;
|
458
|
185 static Fixnum canna_henkan_length;
|
|
186 static Fixnum canna_henkan_revPos;
|
|
187 static Fixnum canna_henkan_revLen;
|
428
|
188 static Lisp_Object Vcanna_ichiran_string;
|
458
|
189 static Fixnum canna_ichiran_length;
|
|
190 static Fixnum canna_ichiran_revPos;
|
|
191 static Fixnum canna_ichiran_revLen;
|
428
|
192 static Lisp_Object Vcanna_mode_string;
|
|
193
|
|
194 static int IRCP_context;
|
|
195
|
1650
|
196 static Lisp_Object storeResults (char *, int, jrKanjiStatus *);
|
428
|
197 static Lisp_Object kanjiYomiList (int, int);
|
442
|
198 static Lisp_Object CANNA_mode_keys (void);
|
428
|
199
|
|
200 #ifdef CANNA_MULE
|
|
201 static void m2c (unsigned char *, int, unsigned char *);
|
|
202 static Lisp_Object mule_make_string (unsigned char *, int);
|
|
203 static int mule_strlen (unsigned char *, int);
|
458
|
204 static void count_char (unsigned char *,int, int, int, Fixnum *, Fixnum *, Fixnum *);
|
428
|
205 #define make_string mule_make_string
|
|
206 #endif
|
|
207
|
|
208 /* Lisp functions definition */
|
|
209
|
|
210 DEFUN ("canna-key-proc", Fcanna_key_proc, 1, 1, 0, /*
|
|
211 Translate a key input to a set of strings. The strings contain both
|
|
212 well-formed string and intermediate result to show the translation
|
|
213 information to a user. Converted strings are stored in specific
|
|
214 variables.
|
|
215 */
|
|
216 (ch))
|
|
217 {
|
|
218 jrKanjiStatus ks;
|
|
219 int len;
|
|
220
|
|
221 CHECK_CHAR_COERCE_INT (ch);
|
448
|
222 len = jrKanjiString (0, XCHAR (ch), key_buffer, KEYTOSTRSIZE, &ks);
|
|
223 return storeResults (key_buffer, len, &ks);
|
428
|
224 }
|
|
225
|
|
226 static Lisp_Object
|
1650
|
227 storeResults (char *buf, int len, jrKanjiStatus *ks)
|
428
|
228 {
|
|
229 Lisp_Object val = Qnil;
|
|
230
|
|
231 if (len < 0)
|
|
232 { /* Error detected */
|
|
233 val = make_string ((unsigned char*) jrKanjiError, strlen (jrKanjiError));
|
|
234 }
|
|
235 else
|
|
236 {
|
448
|
237 /* ³ÎÄꤷ¤¿Ê¸»úÎó (the confirmed string) */
|
1650
|
238 Vcanna_kakutei_string = make_string ((unsigned char *) buf, len);
|
428
|
239 val = make_int (len);
|
448
|
240 /* ³ÎÄꤷ¤¿Ê¸»úÎó¤ÎÆɤߤξðÊó...
|
|
241 (info about the reading of the confirmed string) */
|
428
|
242 Vcanna_kakutei_yomi = Vcanna_kakutei_romaji = Qnil;
|
|
243 if (ks->info & KanjiYomiInfo)
|
|
244 {
|
1650
|
245 char *p = buf + len + 1;
|
428
|
246 int yomilen = strlen (p);
|
|
247
|
|
248 if (len + yomilen + 1 < KEYTOSTRSIZE)
|
|
249 {
|
|
250 int yomilen2;
|
|
251
|
1650
|
252 Vcanna_kakutei_yomi =
|
|
253 make_string ((unsigned char *) p, yomilen); /* ÆÉ¤ß (reading) */
|
428
|
254 p += yomilen + 1;
|
|
255 yomilen2 = strlen (p);
|
|
256 if (len + yomilen + yomilen2 + 2 < KEYTOSTRSIZE)
|
|
257 {
|
1650
|
258 Vcanna_kakutei_romaji =
|
|
259 make_string ((unsigned char *) p, yomilen2);
|
448
|
260 /* ¥í¡¼¥Þ»ú (romanization) */
|
428
|
261 }
|
|
262 }
|
|
263 }
|
|
264
|
|
265
|
448
|
266 /* ¸õÊäɽ¼¨¤Îʸ»úÎó¤Ç¤¹¡£
|
|
267 (string for displaying candidate translations) */
|
428
|
268 Vcanna_henkan_string = Qnil;
|
|
269 if (ks->length >= 0)
|
|
270 {
|
|
271 Vcanna_henkan_string = make_string (ks->echoStr, ks->length);
|
|
272 #ifndef CANNA_MULE
|
|
273 canna_henkan_length = ks->length;
|
|
274 canna_henkan_revPos = ks->revPos;
|
|
275 canna_henkan_revLen = ks->revLen;
|
|
276 #else /* CANNA_MULE */
|
|
277 if (canna_underline)
|
|
278 {
|
|
279 canna_henkan_length = mule_strlen (ks->echoStr,ks->length);
|
|
280 canna_henkan_revPos = mule_strlen (ks->echoStr,ks->revPos);
|
448
|
281 canna_henkan_revLen = mule_strlen (ks->echoStr+ks->revPos,
|
|
282 ks->revLen);
|
428
|
283 }
|
|
284 else
|
|
285 {
|
|
286 count_char (ks->echoStr, ks->length, ks->revPos, ks->revLen,
|
|
287 &canna_henkan_length, &canna_henkan_revPos,
|
|
288 &canna_henkan_revLen);
|
|
289 }
|
|
290 #endif /* CANNA_MULE */
|
|
291 }
|
|
292
|
448
|
293 /* °ìÍ÷¤Î¾ðÊó (information about the echo area menu) */
|
428
|
294 Vcanna_ichiran_string = Qnil;
|
|
295 if (ks->info & KanjiGLineInfo && ks->gline.length >= 0)
|
|
296 {
|
448
|
297 Vcanna_ichiran_string = make_string (ks->gline.line,
|
|
298 ks->gline.length);
|
428
|
299 #ifndef CANNA_MULE
|
|
300 canna_ichiran_length = ks->gline.length;
|
|
301 canna_ichiran_revPos = ks->gline.revPos;
|
|
302 canna_ichiran_revLen = ks->gline.revLen;
|
|
303 #else /* CANNA_MULE */
|
|
304 count_char (ks->gline.line, ks->gline.length,
|
448
|
305 ks->gline.revPos, ks->gline.revLen,
|
|
306 &canna_ichiran_length,
|
428
|
307 &canna_ichiran_revPos, &canna_ichiran_revLen);
|
|
308 #endif /* CANNA_MULE */
|
|
309 }
|
|
310
|
448
|
311 /* ¥â¡¼¥É¤Î¾ðÊó (mode information) */
|
428
|
312 Vcanna_mode_string = Qnil;
|
|
313 if (ks->info & KanjiModeInfo)
|
|
314 {
|
1650
|
315 Vcanna_mode_string =
|
|
316 make_string (ks->mode, strlen ((const char *) ks->mode));
|
428
|
317 }
|
|
318
|
448
|
319 /* ¤½¤Î¾¤Î¾ðÊó (other information) */
|
428
|
320 canna_empty_info = (ks->info & KanjiEmptyInfo) ? 1 : 0;
|
|
321 canna_through_info = (ks->info & KanjiThroughInfo) ? 1 : 0;
|
|
322 }
|
|
323
|
|
324 return val;
|
|
325 }
|
|
326
|
|
327 DEFUN ("canna-set-bunsetsu-kugiri", Fcanna_set_bunsetsu, 0, 1, 0, /*
|
|
328 This function sets the clause separator.
|
|
329 If non-nil value is specified, the white space separator will be used.
|
|
330 No separator will be used otherwise.
|
|
331 */
|
|
332 (num))
|
|
333 {
|
448
|
334 int kugiri; /* ʸÀá¶èÀÚ¤ê¤ò¤¹¤ë¤«¡© (display clause separator?) */
|
428
|
335
|
|
336 kugiri = NILP (num) ? 0 : 1;
|
|
337
|
|
338 jrKanjiControl (0, KC_SETBUNSETSUKUGIRI, (char *) kugiri);
|
|
339
|
|
340 return Qnil;
|
|
341 }
|
|
342
|
|
343 /* For whatever reason, calling Fding directly from libCanna loses */
|
2276
|
344 static int
|
442
|
345 call_Fding (void)
|
428
|
346 {
|
|
347 Fding (Qnil, Qnil, Qnil);
|
2276
|
348 return 0;
|
428
|
349 }
|
|
350
|
|
351 DEFUN ("canna-initialize", Fcanna_initialize, 0, 3, 0, /*
|
613
|
352 Initialize ``canna'', which is a kana-to-kanji converter for XEmacs.
|
428
|
353 The first arg specifies if inserting space character between BUNSETSU when
|
|
354 candidates are displayed.
|
|
355 The second arg specifies server.
|
|
356 The third arg specifies a file which will be used as a customization
|
|
357 description.
|
|
358 If nil is specified for each arg, the default value will be used.
|
|
359 */
|
|
360 (num, server, rcfile))
|
|
361 {
|
|
362 Lisp_Object val;
|
|
363 int res;
|
|
364 unsigned char **p, **q;
|
|
365
|
448
|
366 int kugiri; /* ʸÀá¶èÀÚ¤ê¤ò¤¹¤ë¤«¡© (display clause separator?) */
|
428
|
367
|
|
368 IRCP_context = -1;
|
|
369
|
|
370 if (NILP (num))
|
|
371 {
|
|
372 kugiri = 1;
|
|
373 }
|
|
374 else
|
|
375 {
|
|
376 CHECK_INT (num);
|
|
377 kugiri = XINT (num);
|
|
378 kugiri = (kugiri == 1) ? 1 : 0;
|
|
379 }
|
|
380
|
|
381 if (NILP (server))
|
|
382 {
|
|
383 jrKanjiControl (0, KC_SETSERVERNAME, (char *) 0);
|
|
384 }
|
|
385 else
|
|
386 {
|
|
387 char servername[256];
|
|
388
|
|
389 CHECK_STRING (server);
|
1650
|
390 strncpy (servername, (const char *) XSTRING_DATA (server),
|
|
391 XSTRING_LENGTH (server));
|
428
|
392 servername[XSTRING_LENGTH (server)] = '\0';
|
|
393 jrKanjiControl (0, KC_SETSERVERNAME, servername);
|
|
394 }
|
|
395
|
|
396 if (NILP (rcfile))
|
|
397 {
|
|
398 jrKanjiControl (0, KC_SETINITFILENAME, (char *) 0);
|
|
399 }
|
|
400 else
|
|
401 {
|
|
402 char rcname[256];
|
|
403
|
|
404 CHECK_STRING (rcfile);
|
1650
|
405 strncpy (rcname, (const char *) XSTRING_DATA (rcfile),
|
|
406 XSTRING_LENGTH (rcfile));
|
428
|
407 rcname[XSTRING_LENGTH (rcfile)] = '\0';
|
|
408 jrKanjiControl (0, KC_SETINITFILENAME, rcname);
|
|
409 }
|
|
410
|
|
411 warning = (char **) 0;
|
|
412 #ifdef nec_ews_svr4
|
|
413 stop_polling ();
|
|
414 #endif /* nec_ews_svr4 */
|
|
415 res = jrKanjiControl (0, KC_INITIALIZE, (char *)&warning);
|
|
416 #ifdef nec_ews_svr4
|
|
417 start_polling ();
|
|
418 #endif /* nec_ews_svr4 */
|
|
419 val = Qnil;
|
|
420 if (warning)
|
|
421 {
|
|
422 for (p = q = (unsigned char **) warning ; *q ; q++)
|
|
423 ;
|
|
424 while (p < q)
|
|
425 {
|
|
426 q--;
|
1650
|
427 val = Fcons (make_string (*q, strlen ((const char *) *q)), val);
|
428
|
428 }
|
|
429 }
|
|
430 val = Fcons (val, Qnil);
|
|
431
|
|
432 if (res == -1)
|
|
433 {
|
1650
|
434 val = Fcons (make_string ((unsigned char *) jrKanjiError,
|
428
|
435 strlen (jrKanjiError)), val);
|
448
|
436 /* ¥¤¥Ë¥·¥ã¥é¥¤¥º¤Ç¼ºÇÔ¤·¤¿¾ì¹ç¡£ (on initialization failure) */
|
428
|
437 return Fcons (Qnil, val);
|
|
438 }
|
|
439 else
|
|
440 {
|
|
441 jrBeepFunc = call_Fding;
|
|
442
|
|
443 #ifdef KC_SETAPPNAME
|
|
444 #ifndef CANNA_MULE
|
|
445 wcKanjiControl (0, KC_SETAPPNAME, "nemacs");
|
|
446 #else /* CANNA_MULE */
|
|
447 wcKanjiControl (0, KC_SETAPPNAME, "mule");
|
|
448 #endif /* CANNA_MULE */
|
|
449 #endif /* KC_SETAPPNAME */
|
|
450
|
|
451 jrKanjiControl (0, KC_SETBUNSETSUKUGIRI, (char *) kugiri);
|
|
452 jrKanjiControl (0, KC_SETWIDTH, (char *) 78);
|
|
453 #ifndef CANNA_MULE
|
|
454 jrKanjiControl (0, KC_INHIBITHANKAKUKANA, (char *) 1);
|
|
455 #else
|
448
|
456 /* mule ¤À¤Ã¤¿¤éȾ³Ñ¥«¥¿¥«¥Ê¤â»È¤¨¤ë
|
|
457 (Mule can use half-width katakana) */
|
428
|
458 if (canna_inhibit_hankakukana)
|
|
459 jrKanjiControl (0, KC_INHIBITHANKAKUKANA, (char *) 1);
|
|
460 #endif
|
448
|
461 jrKanjiControl (0, KC_YOMIINFO, (char *) 2); /* ¢¨£²: ¥í¡¼¥Þ»ú¤Þ¤ÇÊÖ¤¹
|
|
462 (*2: return to
|
|
463 romanized form) */
|
428
|
464 val = Fcons (Qnil, val);
|
|
465 return Fcons (CANNA_mode_keys (), val);
|
|
466 }
|
|
467 }
|
|
468
|
|
469 DEFUN ("canna-finalize", Fcanna_finalize, 0, 0, 0, /*
|
613
|
470 finalize ``canna'', which is a kana-to-kanji converter for XEmacs.
|
428
|
471 This cause to write miscellaneous informations to kana-to-kanji dictionary.
|
|
472 */
|
|
473 ())
|
|
474 {
|
|
475 Lisp_Object val;
|
|
476 unsigned char **p;
|
|
477
|
|
478 jrKanjiControl (0, KC_FINALIZE, (char *)&warning);
|
|
479
|
|
480 val = Qnil;
|
|
481 if (warning)
|
|
482 {
|
|
483 for (p = (unsigned char**) warning ; *p ; p++)
|
|
484 {
|
1650
|
485 val = Fcons (make_string (*p, strlen ((const char *) *p)), val);
|
428
|
486 }
|
|
487 }
|
|
488 val = Fcons (val, Qnil);
|
|
489 IRCP_context = -1;
|
|
490 return val;
|
|
491 }
|
|
492
|
|
493 DEFUN ("canna-touroku-string", Fcanna_touroku_string, 1, 1, 0, /*
|
|
494 Register Kanji words into kana-to-kanji conversion dictionary.
|
|
495 */
|
|
496 (str))
|
|
497 {
|
|
498 jrKanjiStatusWithValue ksv;
|
|
499 jrKanjiStatus ks;
|
|
500 int len;
|
|
501 #ifdef CANNA_MULE
|
|
502 unsigned char cbuf[4096];
|
|
503 #endif
|
|
504
|
|
505 CHECK_STRING (str);
|
448
|
506 ksv.buffer = (unsigned char *) key_buffer;
|
428
|
507 ksv.bytes_buffer = KEYTOSTRSIZE;
|
|
508 #ifndef CANNA_MULE
|
|
509 ks.echoStr = XSTRING_DATA (str);
|
|
510 ks.length = XSTRING_LENGTH (str);
|
|
511 #else /* CANNA_MULE */
|
|
512 m2c (XSTRING_DATA (str), XSTRING_LENGTH (str), cbuf);
|
|
513 ks.echoStr = cbuf;
|
1650
|
514 ks.length = strlen ((const char *) cbuf);
|
428
|
515 #endif /* CANNA_MULE */
|
|
516 ksv.ks = &ks;
|
|
517 len = jrKanjiControl (0, KC_DEFINEKANJI, (char *)&ksv);
|
793
|
518 return storeResults (key_buffer, ksv.val, ksv.ks);
|
428
|
519 }
|
|
520
|
|
521 DEFUN ("canna-set-width", Fcanna_set_width, 1, 1, 0, /*
|
|
522 Set status-line width information, which is used to display
|
|
523 kanji candidates.
|
|
524 */
|
|
525 (num))
|
|
526 {
|
|
527 CHECK_INT (num);
|
|
528
|
|
529 jrKanjiControl (0, KC_SETWIDTH, (char *) XINT (num));
|
|
530 return Qnil;
|
|
531 }
|
|
532
|
|
533 DEFUN ("canna-change-mode", Fcanna_change_mode, 1, 1, 0, /*
|
|
534 Change Japanese pre-edit mode.
|
|
535 */
|
|
536 (num))
|
|
537 {
|
|
538 jrKanjiStatusWithValue ksv;
|
|
539 jrKanjiStatus ks;
|
|
540
|
|
541 CHECK_INT (num);
|
|
542
|
448
|
543 ksv.buffer = (unsigned char *) key_buffer;
|
428
|
544 ksv.bytes_buffer = KEYTOSTRSIZE;
|
|
545 ksv.ks = &ks;
|
|
546 ksv.val = XINT (num);
|
|
547 jrKanjiControl (0, KC_CHANGEMODE, (char *)&ksv);
|
793
|
548 return storeResults (key_buffer, ksv.val, ksv.ks);
|
428
|
549 }
|
|
550
|
442
|
551 static Lisp_Object
|
428
|
552 CANNA_mode_keys (void)
|
|
553 {
|
|
554 #define CANNAWORKBUFSIZE 32
|
|
555 char xxx[CANNAWORKBUFSIZE];
|
|
556 Lisp_Object val;
|
|
557 int i, n;
|
|
558
|
|
559 n = jrKanjiControl (0, KC_MODEKEYS, xxx);
|
|
560 val = Qnil;
|
|
561 for (i = n ; i > 0 ;)
|
|
562 {
|
|
563 --i;
|
|
564 /* !!#### something fucked here */
|
|
565 val = Fcons (make_char ((int)(0xFF & (unsigned char) xxx[i])), val);
|
|
566 }
|
|
567 return val;
|
|
568 }
|
|
569
|
|
570 DEFUN ("canna-store-yomi", Fcanna_store_yomi, 1, 2, 0, /*
|
|
571 Store yomi characters as a YOMI of kana-to-kanji conversion.
|
|
572 */
|
|
573 (yomi, roma))
|
|
574 {
|
|
575 jrKanjiStatusWithValue ksv;
|
|
576 jrKanjiStatus ks;
|
|
577
|
|
578 CHECK_STRING (yomi);
|
|
579 #ifndef CANNA_MULE
|
448
|
580 strncpy (key_buffer, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi));
|
428
|
581 ks.length = XSTRING_LENGTH (yomi);
|
448
|
582 key_buffer[ks.length] = '\0';
|
428
|
583 #else /* CANNA_MULE */
|
1650
|
584 m2c (XSTRING_DATA (yomi), XSTRING_LENGTH (yomi),
|
|
585 (unsigned char *) key_buffer);
|
448
|
586 ks.length = strlen (key_buffer);
|
428
|
587 #endif /* CANNA_MULE */
|
|
588
|
|
589 if (NILP (roma))
|
|
590 {
|
|
591 ks.mode = 0;
|
|
592 }
|
|
593 else
|
|
594 {
|
|
595 CHECK_STRING (roma);
|
|
596
|
|
597 #ifndef CANNA_MULE
|
448
|
598 strncpy (key_buffer + XSTRING_LENGTH (yomi) + 1, XSTRING_DATA (roma),
|
428
|
599 XSTRING_LENGTH (roma));
|
448
|
600 key_buffer[XSTRING_LENGTH (yomi) + 1 + XSTRING_LENGTH (roma)] = '\0';
|
|
601 ks.mode = (unsigned char *)(key_buffer + XSTRING_LENGTH (yomi) + 1);
|
428
|
602 #else /* CANNA_MULE */
|
448
|
603 ks.mode = (unsigned char *)(key_buffer + ks.length + 1);
|
1650
|
604 m2c (XSTRING_DATA (roma), XSTRING_LENGTH (roma),
|
|
605 (unsigned char *) ks.mode);
|
428
|
606 #endif /* CANNA_MULE */
|
|
607 }
|
|
608
|
448
|
609 ks.echoStr = (unsigned char *) key_buffer;
|
|
610 ksv.buffer = (unsigned char *) key_buffer; /* ÊÖÃÍÍÑ (return value) */
|
428
|
611 ksv.bytes_buffer = KEYTOSTRSIZE;
|
|
612 ksv.ks = &ks;
|
|
613
|
|
614 jrKanjiControl (0, KC_STOREYOMI, (char *)&ksv);
|
|
615
|
448
|
616 return storeResults (key_buffer, ksv.val, ksv.ks);
|
428
|
617 }
|
|
618
|
|
619 DEFUN ("canna-do-function", Fcanna_do_function, 1, 2, 0, /*
|
|
620 Do specified function at current mode.
|
|
621 */
|
|
622 (num, ch))
|
|
623 {
|
|
624 jrKanjiStatusWithValue ksv;
|
|
625 jrKanjiStatus ks;
|
|
626
|
|
627 CHECK_INT (num);
|
|
628
|
|
629 if (NILP (ch))
|
|
630 {
|
448
|
631 *key_buffer = '@';
|
428
|
632 }
|
|
633 else
|
|
634 {
|
|
635 CHECK_CHAR (ch);
|
448
|
636 *key_buffer = XCHAR (ch);
|
428
|
637 }
|
|
638
|
448
|
639 ksv.buffer = (unsigned char *) key_buffer;
|
428
|
640 ksv.bytes_buffer = KEYTOSTRSIZE;
|
|
641 ksv.ks = &ks;
|
|
642 ksv.val = XINT (num);
|
|
643 jrKanjiControl (0, KC_DO, (char *) &ksv);
|
793
|
644 return storeResults (key_buffer, ksv.val, ksv.ks);
|
428
|
645 }
|
|
646
|
|
647 DEFUN ("canna-parse", Fcanna_parse, 1, 1, 0, /*
|
|
648 Parse customize string.
|
|
649 */
|
|
650 (str))
|
|
651 {
|
|
652 Lisp_Object val;
|
|
653 unsigned char **p;
|
|
654 int n;
|
|
655
|
|
656 CHECK_STRING (str);
|
|
657
|
|
658 #ifndef CANNA_MULE
|
448
|
659 strncpy (key_buffer, XSTRING_DATA (str), XSTRING_LENGTH (str));
|
|
660 key_buffer[XSTRING_LENGTH (str)] = '\0';
|
428
|
661 #else /* CANNA_MULE */
|
1650
|
662 m2c (XSTRING_DATA (str), XSTRING_LENGTH (str), (unsigned char *) key_buffer);
|
428
|
663 #endif /* CANNA_MULE */
|
448
|
664 p = (unsigned char**) key_buffer;
|
428
|
665 n = jrKanjiControl (0, KC_PARSE, (char *) &p);
|
|
666 val = Qnil;
|
|
667 while (n > 0)
|
|
668 {
|
|
669 n--;
|
1650
|
670 val = Fcons (make_string (p[n], strlen ((const char *) p[n])), val);
|
428
|
671 }
|
|
672 return val;
|
|
673 }
|
|
674
|
|
675 DEFUN ("canna-query-mode", Fcanna_query_mode, 0, 0, 0, /*
|
|
676 Get current mode string.
|
|
677 */
|
|
678 ())
|
|
679 {
|
1650
|
680 char buf[256];
|
428
|
681
|
|
682 jrKanjiControl (0, KC_QUERYMODE, buf);
|
1650
|
683 return make_string ((unsigned char *) buf, strlen (buf));
|
428
|
684 }
|
|
685
|
|
686 /*
|
|
687 * Functions following this line are for KKCP interface compatible
|
|
688 * library. These functions may be used by MILK system.
|
|
689 */
|
|
690
|
|
691 #define RKBUFSIZE 1024
|
|
692
|
|
693 static unsigned char yomibuf[RKBUFSIZE];
|
|
694 static short kugiri[RKBUFSIZE / 2];
|
|
695
|
|
696 static int
|
|
697 confirmContext (void)
|
|
698 {
|
|
699 if (IRCP_context < 0)
|
|
700 {
|
|
701 int context;
|
|
702
|
|
703 if ((context = jrKanjiControl (0, KC_GETCONTEXT, (char *) 0)) == -1)
|
|
704 {
|
|
705 return 0;
|
|
706 }
|
|
707 IRCP_context = context;
|
|
708 }
|
|
709 return 1;
|
|
710 }
|
|
711
|
|
712 static int
|
|
713 byteLen (int bun, int len)
|
|
714 {
|
|
715 int i = 0, offset = 0, ch;
|
|
716
|
|
717 if (0 <= bun && bun < RKBUFSIZE)
|
|
718 {
|
|
719 offset = kugiri[bun];
|
|
720 }
|
|
721
|
|
722 while (len-- > 0 && (ch = (int) yomibuf[offset + i]))
|
|
723 {
|
|
724 i++;
|
|
725 if (ch & 0x80)
|
|
726 {
|
|
727 i++;
|
|
728 }
|
|
729 }
|
|
730 return i;
|
|
731 }
|
|
732
|
|
733 DEFUN ("canna-henkan-begin", Fcanna_henkan_begin, 1, 1, 0, /*
|
442
|
734 Return the result of kana-to-kanji conversion.
|
|
735 Clause separator is set.
|
428
|
736 */
|
|
737 (yomi))
|
|
738 {
|
|
739 int nbun;
|
|
740
|
|
741 CHECK_STRING (yomi);
|
|
742 if (confirmContext () == 0)
|
|
743 {
|
|
744 return Qnil;
|
|
745 }
|
|
746 #ifndef CANNA_MULE
|
|
747 strncpy (yomibuf, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi));
|
|
748 yomibuf[XSTRING_LENGTH (yomi)] = '\0';
|
|
749 nbun = RkBgnBun (IRCP_context, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi),
|
|
750 (RK_XFER << RK_XFERBITS) | RK_KFER);
|
|
751 #else /* CANNA_MULE */
|
|
752 m2c (XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), yomibuf);
|
1650
|
753 nbun = RkBgnBun (IRCP_context, (char *) yomibuf,
|
|
754 strlen ((const char *) yomibuf),
|
428
|
755 (RK_XFER << RK_XFERBITS) | RK_KFER);
|
|
756 #endif /* CANNA_MULE */
|
|
757
|
|
758 return kanjiYomiList (IRCP_context, nbun);
|
|
759 }
|
|
760
|
|
761 static Lisp_Object
|
|
762 kanjiYomiList (int context, int nbun)
|
|
763 {
|
|
764 Lisp_Object val, res = Qnil;
|
|
765 unsigned char RkBuf[RKBUFSIZE];
|
|
766 int len, i, total;
|
|
767
|
|
768 for (i = nbun ; i > 0 ; )
|
|
769 {
|
|
770 i--;
|
|
771 RkGoTo (context, i);
|
|
772 len = RkGetKanji (context, RkBuf, RKBUFSIZE);
|
|
773 val = make_string (RkBuf, len);
|
|
774 len = RkGetYomi (context, RkBuf, RKBUFSIZE);
|
|
775 res = Fcons (Fcons (val, make_string (RkBuf, len)), res);
|
|
776 if (i < RKBUFSIZE / 2)
|
|
777 {
|
|
778 kugiri[i] = len;
|
|
779 }
|
|
780 }
|
|
781 for (i = 0, total = 0 ; i < nbun ; i++)
|
|
782 {
|
|
783 int temp = kugiri[i];
|
|
784 kugiri[i] = total;
|
|
785 total += temp;
|
|
786 }
|
|
787 return res;
|
|
788 }
|
|
789
|
|
790 DEFUN ("canna-henkan-next", Fcanna_henkan_next, 1, 1, 0, /*
|
442
|
791 Return the list of candidates.
|
428
|
792 */
|
|
793 (bunsetsu))
|
|
794 {
|
|
795 int i, slen, len;
|
|
796 unsigned char *p, RkBuf[RKBUFSIZE];
|
|
797 Lisp_Object res = Qnil, endp;
|
|
798
|
|
799 CHECK_INT (bunsetsu);
|
|
800 if (confirmContext () == 0)
|
|
801 {
|
|
802 return Qnil;
|
|
803 }
|
|
804 RkGoTo (IRCP_context, XINT (bunsetsu));
|
|
805 len = RkGetKanjiList (IRCP_context, RkBuf, RKBUFSIZE);
|
|
806 p = RkBuf;
|
|
807 for (i = 0 ; i < len ; i++)
|
|
808 {
|
1650
|
809 slen = strlen ((const char *) p);
|
428
|
810 if (NILP(res))
|
|
811 {
|
|
812 endp = res = Fcons (make_string (p, slen), Qnil);
|
|
813 }
|
|
814 else
|
|
815 {
|
442
|
816 endp = XCDR (res) = Fcons (make_string (p, slen), Qnil);
|
428
|
817 }
|
|
818 p += slen + 1;
|
|
819 }
|
|
820 return res;
|
|
821 }
|
|
822
|
|
823 DEFUN ("canna-bunsetu-henkou", Fcanna_bunsetu_henkou, 2, 2, 0, /*
|
442
|
824 Specify the length of a clause.
|
428
|
825 */
|
|
826 (bunsetsu, bunlen))
|
|
827 {
|
|
828 int nbun, len;
|
|
829
|
|
830 CHECK_INT (bunsetsu);
|
|
831 CHECK_INT (bunlen);
|
|
832
|
|
833 nbun = XINT (bunsetsu);
|
|
834 if (confirmContext () == 0)
|
|
835 {
|
|
836 return Qnil;
|
|
837 }
|
|
838 RkGoTo (IRCP_context, nbun);
|
|
839 len = byteLen (nbun, XINT (bunlen));
|
|
840 return kanjiYomiList (IRCP_context, RkResize (IRCP_context, len));
|
|
841 }
|
|
842
|
|
843 DEFUN ("canna-henkan-kakutei", Fcanna_henkan_kakutei, 2, 2, 0, /*
|
442
|
844 Select a candidate.
|
428
|
845 */
|
|
846 (bun, kouho))
|
|
847 {
|
|
848 int nbun, nkouho;
|
|
849
|
|
850 if (confirmContext () == 0)
|
|
851 {
|
|
852 return Qnil;
|
|
853 }
|
|
854 nbun = XINT(bun);
|
|
855 RkGoTo (IRCP_context, nbun);
|
|
856
|
|
857 nkouho = XINT(kouho);
|
|
858 RkXfer (IRCP_context, nkouho);
|
|
859 return Qt;
|
|
860 }
|
|
861
|
|
862 DEFUN ("canna-henkan-end", Fcanna_henkan_end, 0, 0, 0, /*
|
442
|
863 End conversion.
|
428
|
864 */
|
|
865 ())
|
|
866 {
|
|
867 if (confirmContext () == 0)
|
|
868 {
|
|
869 return Qnil;
|
|
870 }
|
448
|
871 RkEndBun (IRCP_context, 1); /* ³Ø½¬¤Ï¤¤¤Ä¤Ç¤â¹Ô¤Ã¤ÆÎɤ¤¤â¤Î¤Ê¤Î¤«¡©
|
|
872 (is it OK to invoke learning function
|
|
873 at arbitrary times?) */
|
428
|
874 return Qt;
|
|
875 }
|
|
876
|
|
877 DEFUN ("canna-henkan-quit", Fcanna_henkan_quit, 0, 0, 0, /*
|
442
|
878 Quit conversion.
|
428
|
879 */
|
|
880 ())
|
|
881 {
|
|
882 if (confirmContext () == 0)
|
|
883 {
|
|
884 return Qnil;
|
|
885 }
|
|
886 RkEndBun (IRCP_context, 0);
|
|
887 return Qt;
|
|
888 }
|
|
889
|
|
890 /* variables below this line is constants of Canna */
|
|
891
|
458
|
892 static Fixnum canna_mode_AlphaMode;
|
|
893 static Fixnum canna_mode_EmptyMode;
|
|
894 static Fixnum canna_mode_KigoMode;
|
|
895 static Fixnum canna_mode_YomiMode;
|
|
896 static Fixnum canna_mode_JishuMode;
|
|
897 static Fixnum canna_mode_TankouhoMode;
|
|
898 static Fixnum canna_mode_IchiranMode;
|
|
899 static Fixnum canna_mode_YesNoMode;
|
|
900 static Fixnum canna_mode_OnOffMode;
|
428
|
901 #ifdef CANNA_MODE_AdjustBunsetsuMode
|
458
|
902 static Fixnum canna_mode_AdjustBunsetsuMode;
|
428
|
903 #endif
|
|
904 #ifdef CANNA_MODE_ChikujiYomiMode
|
458
|
905 static Fixnum canna_mode_ChikujiYomiMode;
|
|
906 static Fixnum canna_mode_ChikujiTanMode;
|
428
|
907 #endif
|
|
908
|
458
|
909 static Fixnum canna_mode_HenkanMode;
|
428
|
910 #ifdef CANNA_MODE_HenkanNyuryokuMode
|
458
|
911 static Fixnum canna_mode_HenkanNyuryokuMode;
|
428
|
912 #endif
|
|
913 #ifdef CANNA_MODE_ZenHiraHenkanMode
|
458
|
914 static Fixnum canna_mode_ZenHiraHenkanMode;
|
428
|
915 #ifdef CANNA_MODE_HanHiraHenkanMode
|
458
|
916 static Fixnum canna_mode_HanHiraHenkanMode;
|
428
|
917 #endif
|
458
|
918 static Fixnum canna_mode_ZenKataHenkanMode;
|
|
919 static Fixnum canna_mode_HanKataHenkanMode;
|
|
920 static Fixnum canna_mode_ZenAlphaHenkanMode;
|
|
921 static Fixnum canna_mode_HanAlphaHenkanMode;
|
428
|
922 #endif
|
458
|
923 static Fixnum canna_mode_ZenHiraKakuteiMode;
|
428
|
924 #ifdef CANNA_MODE_HanHiraKakuteiMode
|
458
|
925 static Fixnum canna_mode_HanHiraKakuteiMode;
|
428
|
926 #endif
|
458
|
927 static Fixnum canna_mode_ZenKataKakuteiMode;
|
|
928 static Fixnum canna_mode_HanKataKakuteiMode;
|
|
929 static Fixnum canna_mode_ZenAlphaKakuteiMode;
|
|
930 static Fixnum canna_mode_HanAlphaKakuteiMode;
|
|
931 static Fixnum canna_mode_HexMode;
|
|
932 static Fixnum canna_mode_BushuMode;
|
|
933 static Fixnum canna_mode_ExtendMode;
|
|
934 static Fixnum canna_mode_RussianMode;
|
|
935 static Fixnum canna_mode_GreekMode;
|
|
936 static Fixnum canna_mode_LineMode;
|
|
937 static Fixnum canna_mode_ChangingServerMode;
|
|
938 static Fixnum canna_mode_HenkanMethodMode;
|
|
939 static Fixnum canna_mode_DeleteDicMode;
|
|
940 static Fixnum canna_mode_TourokuMode;
|
|
941 static Fixnum canna_mode_TourokuEmptyMode;
|
|
942 static Fixnum canna_mode_TourokuHinshiMode;
|
|
943 static Fixnum canna_mode_TourokuDicMode;
|
|
944 static Fixnum canna_mode_QuotedInsertMode;
|
|
945 static Fixnum canna_mode_BubunMuhenkanMode;
|
|
946 static Fixnum canna_mode_MountDicMode;
|
428
|
947
|
458
|
948 static Fixnum canna_fn_SelfInsert;
|
|
949 static Fixnum canna_fn_FunctionalInsert;
|
|
950 static Fixnum canna_fn_QuotedInsert;
|
|
951 static Fixnum canna_fn_JapaneseMode;
|
|
952 static Fixnum canna_fn_AlphaMode;
|
|
953 static Fixnum canna_fn_HenkanNyuryokuMode;
|
|
954 static Fixnum canna_fn_Forward;
|
|
955 static Fixnum canna_fn_Backward;
|
|
956 static Fixnum canna_fn_Next;
|
|
957 static Fixnum canna_fn_Prev;
|
|
958 static Fixnum canna_fn_BeginningOfLine;
|
|
959 static Fixnum canna_fn_EndOfLine;
|
|
960 static Fixnum canna_fn_DeleteNext;
|
|
961 static Fixnum canna_fn_DeletePrevious;
|
|
962 static Fixnum canna_fn_KillToEndOfLine;
|
|
963 static Fixnum canna_fn_Henkan;
|
|
964 static Fixnum canna_fn_Kakutei;
|
|
965 static Fixnum canna_fn_Extend;
|
|
966 static Fixnum canna_fn_Shrink;
|
428
|
967 #ifdef CANNA_FN_AdjustBunsetsu
|
458
|
968 static Fixnum canna_fn_AdjustBunsetsu;
|
428
|
969 #endif
|
458
|
970 static Fixnum canna_fn_Quit;
|
|
971 static Fixnum canna_fn_ConvertAsHex;
|
|
972 static Fixnum canna_fn_ConvertAsBushu;
|
|
973 static Fixnum canna_fn_KouhoIchiran;
|
|
974 static Fixnum canna_fn_BubunMuhenkan;
|
|
975 static Fixnum canna_fn_Zenkaku;
|
|
976 static Fixnum canna_fn_Hankaku;
|
|
977 static Fixnum canna_fn_ToUpper;
|
|
978 static Fixnum canna_fn_Capitalize;
|
|
979 static Fixnum canna_fn_ToLower;
|
|
980 static Fixnum canna_fn_Hiragana;
|
|
981 static Fixnum canna_fn_Katakana;
|
|
982 static Fixnum canna_fn_Romaji;
|
428
|
983 #ifdef CANNA_FN_BaseHiragana
|
458
|
984 static Fixnum canna_fn_BaseHiragana;
|
|
985 static Fixnum canna_fn_BaseKatakana;
|
|
986 static Fixnum canna_fn_BaseEisu;
|
|
987 static Fixnum canna_fn_BaseZenkaku;
|
|
988 static Fixnum canna_fn_BaseHankaku;
|
|
989 static Fixnum canna_fn_BaseKana;
|
|
990 static Fixnum canna_fn_BaseKakutei;
|
|
991 static Fixnum canna_fn_BaseHenkan;
|
|
992 static Fixnum canna_fn_BaseHiraKataToggle;
|
|
993 static Fixnum canna_fn_BaseZenHanToggle;
|
|
994 static Fixnum canna_fn_BaseKanaEisuToggle;
|
|
995 static Fixnum canna_fn_BaseKakuteiHenkanToggle;
|
|
996 static Fixnum canna_fn_BaseRotateForward;
|
|
997 static Fixnum canna_fn_BaseRotateBackward;
|
428
|
998 #endif
|
458
|
999 static Fixnum canna_fn_ExtendMode;
|
|
1000 static Fixnum canna_fn_Touroku;
|
|
1001 static Fixnum canna_fn_HexMode;
|
|
1002 static Fixnum canna_fn_BushuMode;
|
|
1003 static Fixnum canna_fn_KigouMode;
|
428
|
1004 #ifdef CANNA_FN_Mark
|
458
|
1005 static Fixnum canna_fn_Mark;
|
428
|
1006 #endif
|
|
1007 #ifdef CANNA_FN_TemporalMode
|
458
|
1008 static Fixnum canna_fn_TemporalMode;
|
428
|
1009 #endif
|
|
1010
|
458
|
1011 static Fixnum canna_key_Nfer;
|
|
1012 static Fixnum canna_key_Xfer;
|
|
1013 static Fixnum canna_key_Up;
|
|
1014 static Fixnum canna_key_Left;
|
|
1015 static Fixnum canna_key_Right;
|
|
1016 static Fixnum canna_key_Down;
|
|
1017 static Fixnum canna_key_Insert;
|
|
1018 static Fixnum canna_key_Rollup;
|
|
1019 static Fixnum canna_key_Rolldown;
|
|
1020 static Fixnum canna_key_Home;
|
|
1021 static Fixnum canna_key_Help;
|
|
1022 static Fixnum canna_key_KP_Key;
|
|
1023 static Fixnum canna_key_Shift_Nfer;
|
|
1024 static Fixnum canna_key_Shift_Xfer;
|
|
1025 static Fixnum canna_key_Shift_Up;
|
|
1026 static Fixnum canna_key_Shift_Left;
|
|
1027 static Fixnum canna_key_Shift_Right;
|
|
1028 static Fixnum canna_key_Shift_Down;
|
|
1029 static Fixnum canna_key_Cntrl_Nfer;
|
|
1030 static Fixnum canna_key_Cntrl_Xfer;
|
|
1031 static Fixnum canna_key_Cntrl_Up;
|
|
1032 static Fixnum canna_key_Cntrl_Left;
|
|
1033 static Fixnum canna_key_Cntrl_Right;
|
|
1034 static Fixnum canna_key_Cntrl_Down;
|
428
|
1035
|
|
1036 Lisp_Object VCANNA; /* by MORIOKA Tomohiko <morioka@jaist.ac.jp>
|
|
1037 1996/6/7 */
|
|
1038
|
|
1039 void
|
|
1040 syms_of_mule_canna (void)
|
|
1041 {
|
|
1042 DEFSUBR (Fcanna_key_proc);
|
|
1043 DEFSUBR (Fcanna_initialize);
|
|
1044 DEFSUBR (Fcanna_finalize);
|
|
1045 DEFSUBR (Fcanna_touroku_string);
|
|
1046 DEFSUBR (Fcanna_set_width);
|
|
1047 DEFSUBR (Fcanna_change_mode);
|
|
1048 DEFSUBR (Fcanna_store_yomi);
|
|
1049 DEFSUBR (Fcanna_do_function);
|
|
1050 DEFSUBR (Fcanna_parse);
|
|
1051 DEFSUBR (Fcanna_query_mode);
|
|
1052 DEFSUBR (Fcanna_set_bunsetsu);
|
|
1053
|
|
1054 DEFSUBR (Fcanna_henkan_begin);
|
|
1055 DEFSUBR (Fcanna_henkan_next);
|
|
1056 DEFSUBR (Fcanna_bunsetu_henkou);
|
|
1057 DEFSUBR (Fcanna_henkan_kakutei);
|
|
1058 DEFSUBR (Fcanna_henkan_end);
|
|
1059 DEFSUBR (Fcanna_henkan_quit);
|
|
1060 }
|
|
1061
|
|
1062 void
|
|
1063 vars_of_mule_canna (void)
|
|
1064 {
|
|
1065 DEFVAR_LISP ("CANNA", &VCANNA); /* hir@nec, 1992.5.21 */
|
|
1066 VCANNA = Qt; /* hir@nec, 1992.5.21 */
|
|
1067
|
|
1068 DEFVAR_LISP ("canna-kakutei-string", &Vcanna_kakutei_string /*
|
|
1069
|
|
1070 */ );
|
|
1071 Vcanna_kakutei_string = Qnil;
|
|
1072
|
|
1073 DEFVAR_LISP ("canna-kakutei-yomi", &Vcanna_kakutei_yomi /*
|
|
1074
|
|
1075 */ );
|
|
1076 Vcanna_kakutei_yomi = Qnil;
|
|
1077
|
|
1078 DEFVAR_LISP ("canna-kakutei-romaji", &Vcanna_kakutei_romaji /*
|
|
1079
|
|
1080 */ );
|
|
1081 Vcanna_kakutei_romaji = Qnil;
|
|
1082
|
|
1083 DEFVAR_LISP ("canna-henkan-string", &Vcanna_henkan_string /*
|
|
1084
|
|
1085 */ );
|
|
1086 Vcanna_henkan_string = Qnil;
|
|
1087
|
|
1088 DEFVAR_INT ("canna-henkan-length", &canna_henkan_length /*
|
|
1089
|
|
1090 */ );
|
|
1091 canna_henkan_length = 0;
|
|
1092
|
|
1093 DEFVAR_INT ("canna-henkan-revpos", &canna_henkan_revPos /*
|
|
1094
|
|
1095 */ );
|
|
1096 canna_henkan_revPos = 0;
|
|
1097
|
|
1098 DEFVAR_INT ("canna-henkan-revlen", &canna_henkan_revLen /*
|
|
1099
|
|
1100 */ );
|
|
1101 canna_henkan_revLen = 0;
|
|
1102
|
|
1103 DEFVAR_LISP ("canna-ichiran-string", &Vcanna_ichiran_string /*
|
|
1104
|
|
1105 */ );
|
|
1106 Vcanna_ichiran_string = Qnil;
|
|
1107
|
|
1108 DEFVAR_INT ("canna-ichiran-length", &canna_ichiran_length /*
|
|
1109
|
|
1110 */ );
|
|
1111 canna_ichiran_length = 0;
|
|
1112
|
|
1113 DEFVAR_INT ("canna-ichiran-revpos", &canna_ichiran_revPos /*
|
|
1114
|
|
1115 */ );
|
|
1116 canna_ichiran_revPos = 0;
|
|
1117
|
|
1118 DEFVAR_INT ("canna-ichiran-revlen", &canna_ichiran_revLen /*
|
|
1119
|
|
1120 */ );
|
|
1121 canna_ichiran_revLen = 0;
|
|
1122
|
|
1123 DEFVAR_LISP ("canna-mode-string", &Vcanna_mode_string /*
|
|
1124
|
|
1125 */ );
|
|
1126 Vcanna_mode_string = Qnil;
|
|
1127
|
|
1128 DEFVAR_BOOL ("canna-empty-info", &canna_empty_info /*
|
|
1129 For canna
|
|
1130 */ );
|
|
1131 canna_empty_info = 0;
|
|
1132
|
|
1133 DEFVAR_BOOL ("canna-through-info", &canna_through_info /*
|
|
1134 For canna
|
|
1135 */ );
|
|
1136 canna_through_info = 0;
|
|
1137
|
|
1138 DEFVAR_BOOL ("canna-underline", &canna_underline /*
|
|
1139 For canna
|
|
1140 */ );
|
|
1141 canna_underline = 0;
|
|
1142
|
|
1143 DEFVAR_BOOL ("canna-inhibit-hankakukana", &canna_inhibit_hankakukana /*
|
|
1144 For canna
|
|
1145 */ );
|
|
1146 canna_inhibit_hankakukana = 0;
|
|
1147
|
|
1148 DEFVAR_INT ("canna-mode-alpha-mode", &canna_mode_AlphaMode /*
|
|
1149
|
|
1150 */ );
|
|
1151 canna_mode_AlphaMode = IROHA_MODE_AlphaMode;
|
|
1152
|
|
1153 DEFVAR_INT ("canna-mode-empty-mode", &canna_mode_EmptyMode /*
|
|
1154
|
|
1155 */ );
|
|
1156 canna_mode_EmptyMode = IROHA_MODE_EmptyMode;
|
|
1157
|
|
1158 DEFVAR_INT ("canna-mode-kigo-mode", &canna_mode_KigoMode /*
|
|
1159
|
|
1160 */ );
|
|
1161 canna_mode_KigoMode = IROHA_MODE_KigoMode;
|
|
1162
|
|
1163 DEFVAR_INT ("canna-mode-yomi-mode", &canna_mode_YomiMode /*
|
|
1164
|
|
1165 */ );
|
|
1166 canna_mode_YomiMode = IROHA_MODE_YomiMode;
|
|
1167
|
|
1168 DEFVAR_INT ("canna-mode-jishu-mode", &canna_mode_JishuMode /*
|
|
1169
|
|
1170 */ );
|
|
1171 canna_mode_JishuMode = IROHA_MODE_JishuMode;
|
|
1172
|
|
1173 DEFVAR_INT ("canna-mode-tankouho-mode", &canna_mode_TankouhoMode /*
|
|
1174
|
|
1175 */ );
|
|
1176 canna_mode_TankouhoMode = IROHA_MODE_TankouhoMode;
|
|
1177
|
|
1178 DEFVAR_INT ("canna-mode-ichiran-mode", &canna_mode_IchiranMode /*
|
|
1179
|
|
1180 */ );
|
|
1181 canna_mode_IchiranMode = IROHA_MODE_IchiranMode;
|
|
1182
|
|
1183 DEFVAR_INT ("canna-mode-yes-no-mode", &canna_mode_YesNoMode /*
|
|
1184
|
|
1185 */ );
|
|
1186 canna_mode_YesNoMode = IROHA_MODE_YesNoMode;
|
|
1187
|
|
1188 DEFVAR_INT ("canna-mode-on-off-mode", &canna_mode_OnOffMode /*
|
|
1189
|
|
1190 */ );
|
|
1191 canna_mode_OnOffMode = IROHA_MODE_OnOffMode;
|
|
1192
|
|
1193 #ifdef CANNA_MODE_AdjustBunsetsuMode
|
|
1194 DEFVAR_INT ("canna-mode-adjust-bunsetsu-mode",
|
|
1195 &canna_mode_AdjustBunsetsuMode /*
|
|
1196
|
|
1197 */ );
|
|
1198 canna_mode_AdjustBunsetsuMode = CANNA_MODE_AdjustBunsetsuMode;
|
|
1199 #endif
|
|
1200 #ifdef CANNA_MODE_ChikujiYomiMode
|
|
1201 DEFVAR_INT ("canna-mode-chikuji-yomi-mode", &canna_mode_ChikujiYomiMode /*
|
|
1202
|
|
1203 */ );
|
|
1204 canna_mode_ChikujiYomiMode = CANNA_MODE_ChikujiYomiMode;
|
|
1205
|
|
1206 DEFVAR_INT ("canna-mode-chikuji-bunsetsu-mode",
|
|
1207 &canna_mode_ChikujiTanMode /*
|
|
1208
|
|
1209 */ );
|
|
1210 canna_mode_ChikujiTanMode = CANNA_MODE_ChikujiTanMode;
|
|
1211 #endif
|
|
1212
|
|
1213 DEFVAR_INT ("canna-mode-henkan-mode", &canna_mode_HenkanMode /*
|
|
1214
|
|
1215 */ );
|
|
1216 canna_mode_HenkanMode = IROHA_MODE_HenkanMode;
|
|
1217
|
|
1218 #ifdef CANNA_MODE_HenkanNyuryokuMode
|
|
1219 DEFVAR_INT ("canna-mode-henkan-nyuuryoku-mode",
|
|
1220 &canna_mode_HenkanNyuryokuMode /*
|
|
1221
|
|
1222 */ );
|
|
1223 canna_mode_HenkanNyuryokuMode = CANNA_MODE_HenkanNyuryokuMode;
|
|
1224 #endif
|
|
1225 #ifdef CANNA_MODE_ZenHiraHenkanMode
|
|
1226 DEFVAR_INT ("canna-mode-zen-hira-henkan-mode",
|
|
1227 &canna_mode_ZenHiraHenkanMode /*
|
|
1228
|
|
1229 */ );
|
|
1230 canna_mode_ZenHiraHenkanMode = CANNA_MODE_ZenHiraHenkanMode;
|
|
1231 #ifdef CANNA_MODE_HanHiraHenkanMode
|
|
1232 DEFVAR_INT ("canna-mode-han-hira-henkan-mode",
|
|
1233 &canna_mode_HanHiraHenkanMode /*
|
|
1234
|
|
1235 */ );
|
|
1236 canna_mode_HanHiraHenkanMode = CANNA_MODE_HanHiraHenkanMode;
|
|
1237 #endif
|
|
1238 DEFVAR_INT ("canna-mode-zen-kata-henkan-mode",
|
|
1239 &canna_mode_ZenKataHenkanMode /*
|
|
1240
|
|
1241 */ );
|
|
1242 canna_mode_ZenKataHenkanMode = CANNA_MODE_ZenKataHenkanMode;
|
|
1243
|
|
1244 DEFVAR_INT ("canna-mode-han-kata-henkan-mode",
|
|
1245 &canna_mode_HanKataHenkanMode /*
|
|
1246
|
|
1247 */ );
|
|
1248 canna_mode_HanKataHenkanMode = CANNA_MODE_HanKataHenkanMode;
|
|
1249
|
|
1250 DEFVAR_INT ("canna-mode-zen-alpha-henkan-mode",
|
|
1251 &canna_mode_ZenAlphaHenkanMode /*
|
|
1252
|
|
1253 */ );
|
|
1254 canna_mode_ZenAlphaHenkanMode = CANNA_MODE_ZenAlphaHenkanMode;
|
|
1255
|
|
1256 DEFVAR_INT ("canna-mode-han-alpha-henkan-mode",
|
|
1257 &canna_mode_HanAlphaHenkanMode /*
|
|
1258
|
|
1259 */ );
|
|
1260 canna_mode_HanAlphaHenkanMode = CANNA_MODE_HanAlphaHenkanMode;
|
|
1261 #endif
|
|
1262 DEFVAR_INT ("canna-mode-zen-hira-kakutei-mode",
|
|
1263 &canna_mode_ZenHiraKakuteiMode /*
|
|
1264
|
|
1265 */ );
|
|
1266 canna_mode_ZenHiraKakuteiMode = IROHA_MODE_ZenHiraKakuteiMode;
|
|
1267 #ifdef CANNA_MODE_HanHiraKakuteiMode
|
|
1268 DEFVAR_INT ("canna-mode-han-hira-kakutei-mode",
|
|
1269 &canna_mode_HanHiraKakuteiMode /*
|
|
1270
|
|
1271 */ );
|
|
1272 canna_mode_HanHiraKakuteiMode = CANNA_MODE_HanHiraKakuteiMode;
|
|
1273 #endif
|
|
1274 DEFVAR_INT ("canna-mode-zen-kata-kakutei-mode",
|
|
1275 &canna_mode_ZenKataKakuteiMode /*
|
|
1276
|
|
1277 */ );
|
|
1278 canna_mode_ZenKataKakuteiMode = IROHA_MODE_ZenKataKakuteiMode;
|
|
1279
|
|
1280 DEFVAR_INT ("canna-mode-han-kata-kakutei-mode",
|
|
1281 &canna_mode_HanKataKakuteiMode /*
|
|
1282
|
|
1283 */ );
|
|
1284 canna_mode_HanKataKakuteiMode = IROHA_MODE_HanKataKakuteiMode;
|
|
1285
|
|
1286 DEFVAR_INT ("canna-mode-zen-alpha-kakutei-mode",
|
|
1287 &canna_mode_ZenAlphaKakuteiMode /*
|
|
1288
|
|
1289 */ );
|
|
1290 canna_mode_ZenAlphaKakuteiMode = IROHA_MODE_ZenAlphaKakuteiMode;
|
|
1291
|
|
1292 DEFVAR_INT ("canna-mode-han-alpha-kakutei-mode",
|
|
1293 &canna_mode_HanAlphaKakuteiMode /*
|
|
1294
|
|
1295 */ );
|
|
1296 canna_mode_HanAlphaKakuteiMode = IROHA_MODE_HanAlphaKakuteiMode;
|
|
1297
|
|
1298 DEFVAR_INT ("canna-mode-hex-mode", &canna_mode_HexMode /*
|
|
1299
|
|
1300 */ );
|
|
1301 canna_mode_HexMode = IROHA_MODE_HexMode;
|
|
1302
|
|
1303 DEFVAR_INT ("canna-mode-bushu-mode", &canna_mode_BushuMode /*
|
|
1304
|
|
1305 */ );
|
|
1306 canna_mode_BushuMode = IROHA_MODE_BushuMode;
|
|
1307
|
|
1308 DEFVAR_INT ("canna-mode-extend-mode", &canna_mode_ExtendMode /*
|
|
1309
|
|
1310 */ );
|
|
1311 canna_mode_ExtendMode = IROHA_MODE_ExtendMode;
|
|
1312
|
|
1313 DEFVAR_INT ("canna-mode-russian-mode", &canna_mode_RussianMode /*
|
|
1314
|
|
1315 */ );
|
|
1316 canna_mode_RussianMode = IROHA_MODE_RussianMode;
|
|
1317
|
|
1318 DEFVAR_INT ("canna-mode-greek-mode", &canna_mode_GreekMode /*
|
|
1319
|
|
1320 */ );
|
|
1321 canna_mode_GreekMode = IROHA_MODE_GreekMode;
|
|
1322
|
|
1323 DEFVAR_INT ("canna-mode-line-mode", &canna_mode_LineMode /*
|
|
1324
|
|
1325 */ );
|
|
1326 canna_mode_LineMode = IROHA_MODE_LineMode;
|
|
1327
|
|
1328 DEFVAR_INT ("canna-mode-changing-server-mode",
|
|
1329 &canna_mode_ChangingServerMode /*
|
|
1330
|
|
1331 */ );
|
|
1332 canna_mode_ChangingServerMode = IROHA_MODE_ChangingServerMode;
|
|
1333
|
|
1334 DEFVAR_INT ("canna-mode-henkan-method-mode",
|
|
1335 &canna_mode_HenkanMethodMode /*
|
|
1336
|
|
1337 */ );
|
|
1338 canna_mode_HenkanMethodMode = IROHA_MODE_HenkanMethodMode;
|
|
1339
|
|
1340 DEFVAR_INT ("canna-mode-delete-dic-mode", &canna_mode_DeleteDicMode /*
|
|
1341
|
|
1342 */ );
|
|
1343 canna_mode_DeleteDicMode = IROHA_MODE_DeleteDicMode;
|
|
1344
|
|
1345 DEFVAR_INT ("canna-mode-touroku-mode", &canna_mode_TourokuMode /*
|
|
1346
|
|
1347 */ );
|
|
1348 canna_mode_TourokuMode = IROHA_MODE_TourokuMode;
|
|
1349
|
|
1350 DEFVAR_INT ("canna-mode-touroku-empty-mode",
|
|
1351 &canna_mode_TourokuEmptyMode /*
|
|
1352
|
|
1353 */ );
|
|
1354 canna_mode_TourokuEmptyMode = IROHA_MODE_TourokuEmptyMode;
|
|
1355
|
|
1356 DEFVAR_INT ("canna-mode-touroku-hinshi-mode",
|
|
1357 &canna_mode_TourokuHinshiMode /*
|
|
1358
|
|
1359 */ );
|
|
1360 canna_mode_TourokuHinshiMode = IROHA_MODE_TourokuHinshiMode;
|
|
1361
|
|
1362 DEFVAR_INT ("canna-mode-touroku-dic-mode", &canna_mode_TourokuDicMode /*
|
|
1363
|
|
1364 */ );
|
|
1365 canna_mode_TourokuDicMode = IROHA_MODE_TourokuDicMode;
|
|
1366
|
|
1367 DEFVAR_INT ("canna-mode-quoted-insert-mode",
|
|
1368 &canna_mode_QuotedInsertMode /*
|
|
1369
|
|
1370 */ );
|
|
1371 canna_mode_QuotedInsertMode = IROHA_MODE_QuotedInsertMode;
|
|
1372
|
|
1373 DEFVAR_INT ("canna-mode-bubun-muhenkan-mode",
|
|
1374 &canna_mode_BubunMuhenkanMode /*
|
|
1375
|
|
1376 */ );
|
|
1377 canna_mode_BubunMuhenkanMode = IROHA_MODE_BubunMuhenkanMode;
|
|
1378
|
|
1379 DEFVAR_INT ("canna-mode-mount-dic-mode", &canna_mode_MountDicMode /*
|
|
1380
|
|
1381 */ );
|
|
1382 canna_mode_MountDicMode = IROHA_MODE_MountDicMode;
|
|
1383
|
|
1384 DEFVAR_INT ("canna-func-self-insert", &canna_fn_SelfInsert /*
|
|
1385
|
|
1386 */ );
|
|
1387 canna_fn_SelfInsert = IROHA_FN_SelfInsert;
|
|
1388
|
|
1389 DEFVAR_INT ("canna-func-functional-insert", &canna_fn_FunctionalInsert /*
|
|
1390
|
|
1391 */ );
|
|
1392 canna_fn_FunctionalInsert = IROHA_FN_FunctionalInsert;
|
|
1393
|
|
1394 DEFVAR_INT ("canna-func-quoted-insert", &canna_fn_QuotedInsert /*
|
|
1395
|
|
1396 */ );
|
|
1397 canna_fn_QuotedInsert = IROHA_FN_QuotedInsert;
|
|
1398
|
|
1399 DEFVAR_INT ("canna-func-japanese-mode", &canna_fn_JapaneseMode /*
|
|
1400
|
|
1401 */ );
|
|
1402 canna_fn_JapaneseMode = IROHA_FN_JapaneseMode;
|
|
1403
|
|
1404 DEFVAR_INT ("canna-func-alpha-mode", &canna_fn_AlphaMode /*
|
|
1405
|
|
1406 */ );
|
|
1407 canna_fn_AlphaMode = IROHA_FN_AlphaMode;
|
|
1408
|
|
1409 DEFVAR_INT ("canna-func-henkan-nyuryoku-mode",
|
|
1410 &canna_fn_HenkanNyuryokuMode /*
|
|
1411
|
|
1412 */ );
|
|
1413 canna_fn_HenkanNyuryokuMode = IROHA_FN_HenkanNyuryokuMode;
|
|
1414
|
|
1415 DEFVAR_INT ("canna-func-forward", &canna_fn_Forward /*
|
|
1416
|
|
1417 */ );
|
|
1418 canna_fn_Forward = IROHA_FN_Forward;
|
|
1419
|
|
1420 DEFVAR_INT ("canna-func-backward", &canna_fn_Backward /*
|
|
1421
|
|
1422 */ );
|
|
1423 canna_fn_Backward = IROHA_FN_Backward;
|
|
1424
|
|
1425 DEFVAR_INT ("canna-func-next", &canna_fn_Next /*
|
|
1426
|
|
1427 */ );
|
|
1428 canna_fn_Next = IROHA_FN_Next;
|
|
1429
|
|
1430 DEFVAR_INT ("canna-func-previous", &canna_fn_Prev /*
|
|
1431
|
|
1432 */ );
|
|
1433 canna_fn_Prev = IROHA_FN_Prev;
|
|
1434
|
|
1435 DEFVAR_INT ("canna-func-beginning-of-line", &canna_fn_BeginningOfLine /*
|
|
1436
|
|
1437 */ );
|
|
1438 canna_fn_BeginningOfLine = IROHA_FN_BeginningOfLine;
|
|
1439
|
|
1440 DEFVAR_INT ("canna-func-end-of-line", &canna_fn_EndOfLine /*
|
|
1441
|
|
1442 */ );
|
|
1443 canna_fn_EndOfLine = IROHA_FN_EndOfLine;
|
|
1444
|
|
1445 DEFVAR_INT ("canna-func-delete-next", &canna_fn_DeleteNext /*
|
|
1446
|
|
1447 */ );
|
|
1448 canna_fn_DeleteNext = IROHA_FN_DeleteNext;
|
|
1449
|
460
|
1450 DEFVAR_INT ("canna-func-delete-previous", &canna_fn_DeletePrevious /*
|
428
|
1451
|
|
1452 */ );
|
|
1453 canna_fn_DeletePrevious = IROHA_FN_DeletePrevious;
|
|
1454
|
|
1455 DEFVAR_INT ("canna-func-kill-to-end-of-line", &canna_fn_KillToEndOfLine /*
|
|
1456
|
|
1457 */ );
|
|
1458 canna_fn_KillToEndOfLine = IROHA_FN_KillToEndOfLine;
|
|
1459
|
|
1460 DEFVAR_INT ("canna-func-henkan", &canna_fn_Henkan /*
|
|
1461
|
|
1462 */ );
|
|
1463 canna_fn_Henkan = IROHA_FN_Henkan;
|
|
1464
|
|
1465 DEFVAR_INT ("canna-func-kakutei", &canna_fn_Kakutei /*
|
|
1466
|
|
1467 */ );
|
|
1468 canna_fn_Kakutei = IROHA_FN_Kakutei;
|
|
1469
|
|
1470 DEFVAR_INT ("canna-func-extend", &canna_fn_Extend /*
|
|
1471
|
|
1472 */ );
|
|
1473 canna_fn_Extend = IROHA_FN_Extend;
|
|
1474
|
|
1475 DEFVAR_INT ("canna-func-shrink", &canna_fn_Shrink /*
|
|
1476
|
|
1477 */ );
|
|
1478 canna_fn_Shrink = IROHA_FN_Shrink;
|
|
1479
|
|
1480 #ifdef CANNA_FN_AdjustBunsetsu
|
|
1481 DEFVAR_INT ("canna-func-adjust-bunsetsu", &canna_fn_AdjustBunsetsu /*
|
|
1482
|
|
1483 */ );
|
|
1484 canna_fn_AdjustBunsetsu = CANNA_FN_AdjustBunsetsu;
|
|
1485 #endif
|
|
1486 DEFVAR_INT ("canna-func-quit", &canna_fn_Quit /*
|
|
1487
|
|
1488 */ );
|
|
1489 canna_fn_Quit = IROHA_FN_Quit;
|
|
1490
|
|
1491 DEFVAR_INT ("canna-func-convert-as-hex", &canna_fn_ConvertAsHex /*
|
|
1492
|
|
1493 */ );
|
|
1494 canna_fn_ConvertAsHex = IROHA_FN_ConvertAsHex;
|
|
1495
|
|
1496 DEFVAR_INT ("canna-func-convert-as-bushu", &canna_fn_ConvertAsBushu /*
|
|
1497
|
|
1498 */ );
|
|
1499 canna_fn_ConvertAsBushu = IROHA_FN_ConvertAsBushu;
|
|
1500
|
|
1501 DEFVAR_INT ("canna-func-kouho-ichiran", &canna_fn_KouhoIchiran /*
|
|
1502
|
|
1503 */ );
|
|
1504 canna_fn_KouhoIchiran = IROHA_FN_KouhoIchiran;
|
|
1505
|
|
1506 DEFVAR_INT ("canna-func-bubun-muhenkan", &canna_fn_BubunMuhenkan /*
|
|
1507
|
|
1508 */ );
|
|
1509 canna_fn_BubunMuhenkan = IROHA_FN_BubunMuhenkan;
|
|
1510
|
|
1511 DEFVAR_INT ("canna-func-zenkaku", &canna_fn_Zenkaku /*
|
|
1512
|
|
1513 */ );
|
|
1514 canna_fn_Zenkaku = IROHA_FN_Zenkaku;
|
|
1515
|
|
1516 DEFVAR_INT ("canna-func-hankaku", &canna_fn_Hankaku /*
|
|
1517
|
|
1518 */ );
|
|
1519 canna_fn_Hankaku = IROHA_FN_Hankaku;
|
|
1520
|
|
1521 DEFVAR_INT ("canna-func-to-upper", &canna_fn_ToUpper /*
|
|
1522
|
|
1523 */ );
|
|
1524 canna_fn_ToUpper = IROHA_FN_ToUpper;
|
|
1525
|
|
1526 DEFVAR_INT ("canna-func-capitalize", &canna_fn_Capitalize /*
|
|
1527
|
|
1528 */ );
|
|
1529 canna_fn_Capitalize = IROHA_FN_Capitalize;
|
|
1530
|
|
1531 DEFVAR_INT ("canna-func-to-lower", &canna_fn_ToLower /*
|
|
1532
|
|
1533 */ );
|
|
1534 canna_fn_ToLower = IROHA_FN_ToLower;
|
|
1535
|
|
1536 DEFVAR_INT ("canna-func-hiragana", &canna_fn_Hiragana /*
|
|
1537
|
|
1538 */ );
|
|
1539 canna_fn_Hiragana = IROHA_FN_Hiragana;
|
|
1540
|
|
1541 DEFVAR_INT ("canna-func-katakana", &canna_fn_Katakana /*
|
|
1542
|
|
1543 */ );
|
|
1544 canna_fn_Katakana = IROHA_FN_Katakana;
|
|
1545
|
|
1546 DEFVAR_INT ("canna-func-romaji", &canna_fn_Romaji /*
|
|
1547
|
|
1548 */ );
|
|
1549 canna_fn_Romaji = IROHA_FN_Romaji;
|
|
1550
|
|
1551 #ifdef CANNA_FN_BaseHiragana
|
|
1552 DEFVAR_INT ("canna-func-base-hiragana", &canna_fn_BaseHiragana /*
|
|
1553
|
|
1554 */ );
|
|
1555 canna_fn_BaseHiragana = CANNA_FN_BaseHiragana;
|
|
1556
|
|
1557 DEFVAR_INT ("canna-func-base-katakana", &canna_fn_BaseKatakana /*
|
|
1558
|
|
1559 */ );
|
|
1560 canna_fn_BaseKatakana = CANNA_FN_BaseKatakana;
|
|
1561
|
|
1562 DEFVAR_INT ("canna-func-base-eisu", &canna_fn_BaseEisu /*
|
|
1563
|
|
1564 */ );
|
|
1565 canna_fn_BaseEisu = CANNA_FN_BaseEisu;
|
|
1566
|
|
1567 DEFVAR_INT ("canna-func-base-zenkaku", &canna_fn_BaseZenkaku /*
|
|
1568
|
|
1569 */ );
|
|
1570 canna_fn_BaseZenkaku = CANNA_FN_BaseZenkaku;
|
|
1571
|
|
1572 DEFVAR_INT ("canna-func-base-hankaku", &canna_fn_BaseHankaku /*
|
|
1573
|
|
1574 */ );
|
|
1575 canna_fn_BaseHankaku = CANNA_FN_BaseHankaku;
|
|
1576
|
|
1577 DEFVAR_INT ("canna-func-base-kana", &canna_fn_BaseKana /*
|
|
1578
|
|
1579 */ );
|
|
1580 canna_fn_BaseKana = CANNA_FN_BaseKana;
|
|
1581
|
|
1582 DEFVAR_INT ("canna-func-base-kakutei", &canna_fn_BaseKakutei /*
|
|
1583
|
|
1584 */ );
|
|
1585 canna_fn_BaseKakutei = CANNA_FN_BaseKakutei;
|
|
1586
|
|
1587 DEFVAR_INT ("canna-func-base-henkan", &canna_fn_BaseHenkan /*
|
|
1588
|
|
1589 */ );
|
|
1590 canna_fn_BaseHenkan = CANNA_FN_BaseHenkan;
|
|
1591
|
|
1592 DEFVAR_INT ("canna-func-base-hiragana-katakana-toggle",
|
|
1593 &canna_fn_BaseHiraKataToggle /*
|
|
1594
|
|
1595 */ );
|
|
1596 canna_fn_BaseHiraKataToggle = CANNA_FN_BaseHiraKataToggle;
|
|
1597
|
|
1598 DEFVAR_INT ("canna-func-base-zenkaku-hankaku-toggle",
|
|
1599 &canna_fn_BaseZenHanToggle /*
|
|
1600
|
|
1601 */ );
|
|
1602 canna_fn_BaseZenHanToggle = CANNA_FN_BaseZenHanToggle;
|
|
1603
|
|
1604 DEFVAR_INT ("canna-func-base-kana-eisu-toggle",
|
|
1605 &canna_fn_BaseKanaEisuToggle /*
|
|
1606
|
|
1607 */ );
|
|
1608 canna_fn_BaseKanaEisuToggle = CANNA_FN_BaseKanaEisuToggle;
|
|
1609
|
|
1610 DEFVAR_INT ("canna-func-base-kakutei-henkan-toggle",
|
|
1611 &canna_fn_BaseKakuteiHenkanToggle /*
|
|
1612
|
|
1613 */ );
|
|
1614 canna_fn_BaseKakuteiHenkanToggle = CANNA_FN_BaseKakuteiHenkanToggle;
|
|
1615
|
|
1616 DEFVAR_INT ("canna-func-base-rotate-forward",
|
|
1617 &canna_fn_BaseRotateForward /*
|
|
1618
|
|
1619 */ );
|
|
1620 canna_fn_BaseRotateForward = CANNA_FN_BaseRotateForward;
|
|
1621
|
|
1622 DEFVAR_INT ("canna-func-base-rotate-backward",
|
|
1623 &canna_fn_BaseRotateBackward /*
|
|
1624
|
|
1625 */ );
|
|
1626 canna_fn_BaseRotateBackward = CANNA_FN_BaseRotateBackward;
|
|
1627
|
|
1628 #endif
|
|
1629 DEFVAR_INT ("canna-func-extend-mode", &canna_fn_ExtendMode /*
|
|
1630
|
|
1631 */ );
|
|
1632 canna_fn_ExtendMode = IROHA_FN_ExtendMode;
|
|
1633
|
|
1634 DEFVAR_INT ("canna-func-touroku", &canna_fn_Touroku /*
|
|
1635
|
|
1636 */ );
|
|
1637 canna_fn_Touroku = IROHA_FN_Touroku;
|
|
1638
|
|
1639 DEFVAR_INT ("canna-func-hex-mode", &canna_fn_HexMode /*
|
|
1640
|
|
1641 */ );
|
|
1642 canna_fn_HexMode = IROHA_FN_HexMode;
|
|
1643
|
|
1644 DEFVAR_INT ("canna-func-bushu-mode", &canna_fn_BushuMode /*
|
|
1645
|
|
1646 */ );
|
|
1647 canna_fn_BushuMode = IROHA_FN_BushuMode;
|
|
1648
|
|
1649 DEFVAR_INT ("canna-func-kigo-mode", &canna_fn_KigouMode /*
|
|
1650
|
|
1651 */ );
|
|
1652 canna_fn_KigouMode = IROHA_FN_KigouMode;
|
|
1653
|
|
1654 #ifdef CANNA_FN_Mark
|
|
1655 DEFVAR_INT ("canna-func-mark", &canna_fn_Mark /*
|
|
1656
|
|
1657 */ );
|
|
1658 canna_fn_Mark = CANNA_FN_Mark;
|
|
1659 #endif
|
|
1660 #ifdef CANNA_FN_TemporalMode
|
|
1661 DEFVAR_INT ("canna-func-temporal-mode", &canna_fn_TemporalMode /*
|
|
1662
|
|
1663 */ );
|
|
1664 canna_fn_TemporalMode = CANNA_FN_TemporalMode;
|
|
1665 #endif
|
|
1666
|
|
1667 DEFVAR_INT ("canna-key-nfer", &canna_key_Nfer /*
|
|
1668
|
|
1669 */ );
|
|
1670 canna_key_Nfer = IROHA_KEY_Nfer;
|
|
1671
|
|
1672 DEFVAR_INT ("canna-key-xfer", &canna_key_Xfer /*
|
|
1673
|
|
1674 */ );
|
|
1675 canna_key_Xfer = IROHA_KEY_Xfer;
|
|
1676
|
|
1677 DEFVAR_INT ("canna-key-up", &canna_key_Up /*
|
|
1678
|
|
1679 */ );
|
|
1680 canna_key_Up = IROHA_KEY_Up;
|
|
1681
|
|
1682 DEFVAR_INT ("canna-key-left", &canna_key_Left /*
|
|
1683
|
|
1684 */ );
|
|
1685 canna_key_Left = IROHA_KEY_Left;
|
|
1686
|
|
1687 DEFVAR_INT ("canna-key-right", &canna_key_Right /*
|
|
1688
|
|
1689 */ );
|
|
1690 canna_key_Right = IROHA_KEY_Right;
|
|
1691
|
|
1692 DEFVAR_INT ("canna-key-down", &canna_key_Down /*
|
|
1693
|
|
1694 */ );
|
|
1695 canna_key_Down = IROHA_KEY_Down;
|
|
1696
|
|
1697 DEFVAR_INT ("canna-key-insert", &canna_key_Insert /*
|
|
1698
|
|
1699 */ );
|
|
1700 canna_key_Insert = IROHA_KEY_Insert;
|
|
1701
|
|
1702 DEFVAR_INT ("canna-key-rollup", &canna_key_Rollup /*
|
|
1703
|
|
1704 */ );
|
|
1705 canna_key_Rollup = IROHA_KEY_Rollup;
|
|
1706
|
|
1707 DEFVAR_INT ("canna-key-rolldown", &canna_key_Rolldown /*
|
|
1708
|
|
1709 */ );
|
|
1710 canna_key_Rolldown = IROHA_KEY_Rolldown;
|
|
1711
|
|
1712 DEFVAR_INT ("canna-key-home", &canna_key_Home /*
|
|
1713
|
|
1714 */ );
|
|
1715 canna_key_Home = IROHA_KEY_Home;
|
|
1716
|
|
1717 DEFVAR_INT ("canna-key-help", &canna_key_Help /*
|
|
1718
|
|
1719 */ );
|
|
1720 canna_key_Help = IROHA_KEY_Help;
|
|
1721
|
|
1722 DEFVAR_INT ("canna-key-kp-key", &canna_key_KP_Key /*
|
|
1723
|
|
1724 */ );
|
|
1725 canna_key_KP_Key = IROHA_KEY_KP_Key;
|
|
1726
|
|
1727 DEFVAR_INT ("canna-key-shift-nfer", &canna_key_Shift_Nfer /*
|
|
1728
|
|
1729 */ );
|
|
1730 canna_key_Shift_Nfer = IROHA_KEY_Shift_Nfer;
|
|
1731
|
|
1732 DEFVAR_INT ("canna-key-shift-xfer", &canna_key_Shift_Xfer /*
|
|
1733
|
|
1734 */ );
|
|
1735 canna_key_Shift_Xfer = IROHA_KEY_Shift_Xfer;
|
|
1736
|
|
1737 DEFVAR_INT ("canna-key-shift-up", &canna_key_Shift_Up /*
|
|
1738
|
|
1739 */ );
|
|
1740 canna_key_Shift_Up = IROHA_KEY_Shift_Up;
|
|
1741
|
|
1742 DEFVAR_INT ("canna-key-shift-left", &canna_key_Shift_Left /*
|
|
1743
|
|
1744 */ );
|
|
1745 canna_key_Shift_Left = IROHA_KEY_Shift_Left;
|
|
1746
|
|
1747 DEFVAR_INT ("canna-key-shift-right", &canna_key_Shift_Right /*
|
|
1748
|
|
1749 */ );
|
|
1750 canna_key_Shift_Right = IROHA_KEY_Shift_Right;
|
|
1751
|
|
1752 DEFVAR_INT ("canna-key-shift-down", &canna_key_Shift_Down /*
|
|
1753
|
|
1754 */ );
|
|
1755 canna_key_Shift_Down = IROHA_KEY_Shift_Down;
|
|
1756
|
|
1757 DEFVAR_INT ("canna-key-control-nfer", &canna_key_Cntrl_Nfer /*
|
|
1758
|
|
1759 */ );
|
|
1760 canna_key_Cntrl_Nfer = IROHA_KEY_Cntrl_Nfer;
|
|
1761
|
|
1762 DEFVAR_INT ("canna-key-control-xfer", &canna_key_Cntrl_Xfer /*
|
|
1763
|
|
1764 */ );
|
|
1765 canna_key_Cntrl_Xfer = IROHA_KEY_Cntrl_Xfer;
|
|
1766
|
|
1767 DEFVAR_INT ("canna-key-control-up", &canna_key_Cntrl_Up /*
|
|
1768
|
|
1769 */ );
|
|
1770 canna_key_Cntrl_Up = IROHA_KEY_Cntrl_Up;
|
|
1771
|
|
1772 DEFVAR_INT ("canna-key-control-left", &canna_key_Cntrl_Left /*
|
|
1773
|
|
1774 */ );
|
|
1775 canna_key_Cntrl_Left = IROHA_KEY_Cntrl_Left;
|
|
1776
|
|
1777 DEFVAR_INT ("canna-key-control-right", &canna_key_Cntrl_Right /*
|
|
1778
|
|
1779 */ );
|
|
1780 canna_key_Cntrl_Right = IROHA_KEY_Cntrl_Right;
|
|
1781
|
|
1782 DEFVAR_INT ("canna-key-control-down", &canna_key_Cntrl_Down /*
|
|
1783
|
|
1784 */ );
|
|
1785 canna_key_Cntrl_Down = IROHA_KEY_Cntrl_Down;
|
|
1786
|
|
1787 Fprovide(intern("CANNA"));
|
|
1788 }
|
|
1789
|
|
1790 #ifdef CANNA_MULE
|
|
1791 /* To handle MULE internal code and EUC.
|
|
1792 I assume CANNA can handle only Japanese EUC. */
|
|
1793
|
|
1794 /* EUC multibyte string to MULE internal string */
|
|
1795
|
|
1796 static void
|
442
|
1797 c2mu (unsigned char *cp, int l, unsigned char *mp)
|
428
|
1798 {
|
442
|
1799 unsigned char ch, *ep = cp+l;
|
428
|
1800
|
|
1801 while ((cp < ep) && (ch = *cp))
|
|
1802 {
|
|
1803 if ((unsigned char) ch == ISO_CODE_SS2)
|
|
1804 {
|
|
1805 *mp++ = LEADING_BYTE_KATAKANA_JISX0201;
|
|
1806 cp++;
|
|
1807 }
|
|
1808 else if ((unsigned char) ch == ISO_CODE_SS3)
|
|
1809 {
|
|
1810 *mp++ = LEADING_BYTE_JAPANESE_JISX0212;
|
|
1811 cp++;
|
|
1812 *mp++ = *cp++;
|
|
1813 }
|
|
1814 else if (ch & 0x80)
|
|
1815 {
|
|
1816 *mp++ = LEADING_BYTE_JAPANESE_JISX0208;
|
|
1817 *mp++ = *cp++;
|
|
1818 }
|
|
1819 *mp++ = *cp++;
|
|
1820 }
|
|
1821 *mp = 0;
|
|
1822 }
|
|
1823
|
|
1824 /* MULE internal string to EUC multibyte string */
|
|
1825
|
|
1826 static void
|
|
1827 m2c (unsigned char *mp, int l, unsigned char *cp)
|
|
1828 {
|
|
1829 unsigned char ch, *ep = mp + l;
|
|
1830
|
|
1831 while ((mp < ep) && (ch = *mp++))
|
|
1832 {
|
|
1833 switch (ch)
|
|
1834 {
|
|
1835 case LEADING_BYTE_KATAKANA_JISX0201:
|
|
1836 *cp++ = ISO_CODE_SS2;
|
|
1837 *cp++ = *mp++;
|
|
1838 break;
|
|
1839 case LEADING_BYTE_JAPANESE_JISX0212:
|
|
1840 *cp++ = ISO_CODE_SS3;
|
|
1841 case LEADING_BYTE_JAPANESE_JISX0208:
|
|
1842 *cp++ = *mp++;
|
|
1843 *cp++ = *mp++;
|
|
1844 break;
|
|
1845 default:
|
|
1846 *cp++ = ch;
|
|
1847 break;
|
|
1848 }
|
|
1849 }
|
|
1850 *cp = 0;
|
|
1851 }
|
|
1852
|
|
1853 #undef make_string
|
|
1854
|
|
1855 /* make_string after converting EUC string to MULE internal string */
|
|
1856 static Lisp_Object
|
|
1857 mule_make_string (unsigned char *p, int l)
|
|
1858 {
|
|
1859 unsigned char cbuf[4096];
|
|
1860
|
|
1861 c2mu (p,l,cbuf);
|
1650
|
1862 return (make_string (cbuf, strlen ((const char *) cbuf)));
|
428
|
1863 }
|
|
1864
|
|
1865 /* return the MULE internal string length of EUC string */
|
|
1866 /* Modified by sb to return a character count not byte count. */
|
|
1867 static int
|
|
1868 mule_strlen (unsigned char *p, int l)
|
|
1869 {
|
|
1870 unsigned char ch, *cp = p;
|
|
1871 int len = 0;
|
|
1872
|
|
1873 while ((cp < p + l) && (ch = *cp))
|
|
1874 {
|
|
1875 if ((unsigned char) ch == ISO_CODE_SS2)
|
|
1876 {
|
|
1877 len++;
|
|
1878 cp += 2;
|
|
1879 }
|
|
1880 else if ((unsigned char) ch == ISO_CODE_SS3)
|
|
1881 {
|
|
1882 len++;
|
|
1883 cp += 3;
|
|
1884 }
|
|
1885 else if (ch & 0x80)
|
|
1886 {
|
|
1887 len++;
|
|
1888 cp += 2;
|
|
1889 }
|
|
1890 else
|
|
1891 {
|
|
1892 len++;
|
|
1893 cp++;
|
|
1894 }
|
|
1895 }
|
|
1896 return (len);
|
|
1897 }
|
|
1898
|
|
1899 /* count number of characters */
|
|
1900 static void
|
458
|
1901 count_char (unsigned char *p, int len, int pos, int rev,
|
|
1902 Fixnum *clen, Fixnum *cpos, Fixnum *crev)
|
428
|
1903 {
|
|
1904 unsigned char *q = p;
|
|
1905
|
|
1906 *clen = *cpos = *crev = 0;
|
|
1907 if (len == 0) return;
|
|
1908 while (q < p + pos)
|
|
1909 {
|
|
1910 (*clen)++;
|
|
1911 (*cpos)++;
|
|
1912 if (*q++ & 0x80) q++;
|
|
1913 }
|
|
1914 while (q < p + pos + rev)
|
|
1915 {
|
|
1916 (*clen)++;
|
|
1917 (*crev)++;
|
|
1918 if (*q++ & 0x80) q++;
|
|
1919 }
|
|
1920 while (q < p + len)
|
|
1921 {
|
|
1922 (*clen)++;
|
|
1923 if (*q++ & 0x80) q++;
|
|
1924 }
|
|
1925 }
|
|
1926 #endif /* CANNA_MULE */
|