Mercurial > hg > xemacs-beta
changeset 3010:bd7174adf0f2
[xemacs-hg @ 2005-10-21 15:48:28 by stephent]
Revert rename of canna_api to canna-api. <87d5lylvqq.fsf@tleepslib.sk.tsukuba.ac.jp>
author | stephent |
---|---|
date | Fri, 21 Oct 2005 15:48:42 +0000 |
parents | 79943d344216 |
children | 4fb9692475d3 |
files | lisp/ChangeLog lisp/mule/canna-leim.el modules/ChangeLog modules/canna/Makefile.in.in modules/canna/canna-api.c modules/canna/canna_api.c modules/canna/configure.ac src/ChangeLog src/Makefile.in.in |
diffstat | 9 files changed, 2011 insertions(+), 1995 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/ChangeLog Fri Oct 21 14:08:15 2005 +0000 +++ b/lisp/ChangeLog Fri Oct 21 15:48:42 2005 +0000 @@ -1,3 +1,8 @@ +2005-10-21 Stephen J. Turnbull <stephen@xemacs.org> + + UNDO: + * mule/canna-leim.el: Rename canna_api to canna-api. + 2005-10-21 Stephen J. Turnbull <stephen@xemacs.org> * build-report.el: Note synch to XEmacs build package version 1.49.
--- a/lisp/mule/canna-leim.el Fri Oct 21 14:08:15 2005 +0000 +++ b/lisp/mule/canna-leim.el Fri Oct 21 15:48:42 2005 +0000 @@ -35,17 +35,17 @@ (globally-declare-boundp 'canna:*japanese-mode*) (globally-declare-fboundp '(canna canna-toggle-japanese-mode)) -;; use (locate-file "canna/canna-api" module-load-path module-extensions) +;; use (locate-file "canna/canna_api" module-load-path module-extensions) ;; to locate the module without loading it. ;; then we could autoload canna-activate and dump and/or autoload: -;; (and (locate-file "canna/canna-api" module-load-path module-extensions) +;; (and (locate-file "canna/canna_api" module-load-path module-extensions) ;; (locate-library "canna") ;; (register-input-method 'japanese-canna "Japanese" 'canna-activate nil ;; "Canna - a kana to kanji conversion program")) (defun canna-activate (&optional name) ;; XEmacs 21.5.10 and later have 3-argument require. - (unless (require 'CANNA "canna/canna-api" 'no-error) + (unless (require 'CANNA "canna/canna_api" 'no-error) (error 'file-error "No Canna API support!? See M-x describe-installation & C-h v module-load-path.")) (unless (require 'canna nil 'no-error)
--- a/modules/ChangeLog Fri Oct 21 14:08:15 2005 +0000 +++ b/modules/ChangeLog Fri Oct 21 15:48:42 2005 +0000 @@ -1,3 +1,10 @@ +2005-10-21 Stephen J. Turnbull <stephen@xemacs.org> + + UNDO: + * canna/canna-api.c: + * canna/Makefile.in.in (MODNAME,SRCS): + Rename module from canna_api to canna-api. + 2005-10-21 Stephen J. Turnbull <stephen@xemacs.org> * canna/configure: Create and CVS add.
--- a/modules/canna/Makefile.in.in Fri Oct 21 14:08:15 2005 +0000 +++ b/modules/canna/Makefile.in.in Fri Oct 21 15:48:42 2005 +0000 @@ -26,11 +26,11 @@ ## source tree. ### Specialize this part for your module -MODNAME=canna-api +MODNAME=canna_api MODVER=0.5.0 MODTITLE="Module wrapping Canna libraries for XEmacs" CFLAGS=@CFLAGS@ LDFLAGS=@LDFLAGS@ @ld_switch_all@ @canna_libs@ -SRCS=canna-api.c +SRCS=canna_api.c ## Note: modules/common/Makefile.common will be appended by configure
--- a/modules/canna/canna-api.c Fri Oct 21 14:08:15 2005 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1988 +0,0 @@ -/* CANNA interface -*- coding: euc-jp -*- - - Copyright (C) 1995 Free Software Foundation, Inc. - Copyright (C) 1995 Sun Microsystems, Inc. - -This file is part of XEmacs. - -XEmacs 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, or (at your option) any -later version. - -XEmacs 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 XEmacs; see the file COPYING. If not, write to -the Free Software Foundation, Inc., 59 Temple Place - Suite 330, -Boston, MA 02111-1307, USA. */ - -/* Synched up with: Mule 2.3. Not in FSF. */ - -/* Japanese comments were translated 2000-12-06 by Stephen Turnbull - <stephen@xemacs.org>. I haven't verified that the Japanese comments - were correct. YMMV, NO WARRANTY, not even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. (^^;;; as the - Japanese say. */ - -/* - - Authors: Akira Kon (kon@uxd.fc.nec.co.jp) - Ichiro Hirakura (hirakura@uxd.fc.nec.co.jp) - - Functions defined in this file are - - (canna-key-proc key) - key: single STRING - RETURNS: - Length of converted string if no error occurs. - Error string if error occurs. - DESCRIPTION: - Convert a key input to a set of strings. The - strings contain both well-formed string and a - intermediate result to show the translation - information to a user. converted strings are - stored in specific variables. - - (canna-initialize) - RETURNS: - List of the following things: - - list of keys to toggle Japanese-mode - - error message - - list of warning messages - DESCRIPTION: - Initialize ``canna'', which is a kana-to-kanji - converter for XEmacs. The first arg - specifies if inserting space character between - BUNSETSU when candidates are displayed. The - second arg specifies server. The third arg - specifies a file which will be used as a - customization description. If nil is - specified for each arg, the default value will - be used. - - (canna-finalize) - RETURNS: - list of warning messages - DESCRIPTION: - finalize ``canna'', which is a kana-to-kanji - converter for XEmacs. This cause to write - miscellaneous informations to kana-to-kanji - dictionary. - - (canna-touroku-string string) - string: - String to register to a dictionary. - RETURNS: - The same thing returns as canna-key-proc does. - DESCRIPTION: - Register Kanji words into kana-to-kanji - conversion dictionary. - - (canna-set-width width) - width: - Column width of the place where the candidates - of kana-to-kanji conversion will be shown. - RETURNS: - nil - DESCRIPTION: - Set status-line width information, which is - used to display kanji candidates. - - (canna-change-mode num) - num: - The mode number of Canna. - RETURNS: - The same thing returns as canna-key-proc does. - DESCRIPTION: - Change Japanese pre-edit mode. - - (canna-store-yomi yomi roma) - yomi: - ``Yomi'' to be stored. - roma: - ``Romaji'' which corresponds to the ``Yomi''. - RETURNS: - The same thing returns as canna-key-proc does. - DESCRIPTION: - Store yomi characters as a YOMI of - kana-to-kanji conversion. - - (canna-do-function num ch) - num: - A function number to be called. - ch: - A character will be specified in order to feed - the character to the function if the function - needs a input character. - RETURNS: - The same thing returns as canna-key-proc does. - DESCRIPTION: - Do specified function at current mode. - - (canna-parse string) - string: - To be parsed. - RETURNS: - List of warning messages. - DESCRIPTION: - Parse customize string. - - (canna-query-mode) - RETURNS: - A string which indicate the current mode. - DESCRIPTION: - Get current mode string. - - Functions below are used for KKCP compatible library. These - functions provides a base kana-to-kanji conversion system for EGG. - These functions may be used when users want to change the engine - from Wnn to Canna without changing user interface of Japanese input. - - (canna-henkan-begin) - (canna-henkan-next) - (canna-bunsetu-henkou) - (canna-henkan-kakutei) - (canna-henkan-end) - (canna-henkan-quit) - - */ - -#include <config.h> -#include "lisp.h" -#ifdef HAVE_SHLIB -#include "emodules.h" -#endif - -#include "buffer.h" -#include "file-coding.h" - -#ifdef CANNA2 -#define IROHA_BC -#define CANNA_NEW_WCHAR_AWARE -#include "canna/jrkanji.h" -#include "canna/RK.h" -#else /* !CANNA2 */ -#include "iroha/jrkanji.h" -#include "iroha/RK.h" -#endif /* !CANNA2 */ -extern char *jrKanjiError; - -extern int (*jrBeepFunc) (void); - -/* #### is this global really necessary? */ -#define KEYTOSTRSIZE 2048 -static char key_buffer[KEYTOSTRSIZE]; -static char **warning; - -static int canna_empty_info, canna_through_info; -static int canna_underline; -static int canna_inhibit_hankakukana; - -static Lisp_Object Vcanna_kakutei_string; -static Lisp_Object Vcanna_kakutei_yomi; -static Lisp_Object Vcanna_kakutei_romaji; -static Lisp_Object Vcanna_henkan_string; -static Fixnum canna_henkan_length; -static Fixnum canna_henkan_revPos; -static Fixnum canna_henkan_revLen; -static Lisp_Object Vcanna_ichiran_string; -static Fixnum canna_ichiran_length; -static Fixnum canna_ichiran_revPos; -static Fixnum canna_ichiran_revLen; -static Lisp_Object Vcanna_mode_string; - -static int IRCP_context; - -static Lisp_Object storeResults (char *, int, jrKanjiStatus *); -static Lisp_Object kanjiYomiList (int, int); -static Lisp_Object CANNA_mode_keys (void); - -#ifdef CANNA_MULE -static void m2c (unsigned char *, int, unsigned char *); -static Lisp_Object mule_make_string (unsigned char *, int); -static int mule_strlen (unsigned char *, int); -static void count_char (unsigned char *,int, int, int, Fixnum *, Fixnum *, Fixnum *); -#define make_string mule_make_string -#endif - -/* Lisp functions definition */ - -DEFUN ("canna-key-proc", Fcanna_key_proc, 1, 1, 0, /* -Translate a key input to a set of strings. The strings contain both -well-formed string and intermediate result to show the translation -information to a user. Converted strings are stored in specific -variables. -*/ - (ch)) -{ - jrKanjiStatus ks; - int len; - - CHECK_CHAR_COERCE_INT (ch); - len = jrKanjiString (0, XCHAR (ch), key_buffer, KEYTOSTRSIZE, &ks); - return storeResults (key_buffer, len, &ks); -} - -static Lisp_Object -storeResults (char *buf, int len, jrKanjiStatus *ks) -{ - Lisp_Object val = Qnil; - - if (len < 0) - { /* Error detected */ - val = make_string ((unsigned char*) jrKanjiError, strlen (jrKanjiError)); - } - else - { - /* 確定した文字列 (the confirmed string) */ - Vcanna_kakutei_string = make_string ((unsigned char *) buf, len); - val = make_int (len); - /* 確定した文字列の読みの情報... - (info about the reading of the confirmed string) */ - Vcanna_kakutei_yomi = Vcanna_kakutei_romaji = Qnil; - if (ks->info & KanjiYomiInfo) - { - char *p = buf + len + 1; - int yomilen = strlen (p); - - if (len + yomilen + 1 < KEYTOSTRSIZE) - { - int yomilen2; - - Vcanna_kakutei_yomi = - make_string ((unsigned char *) p, yomilen); /* 読み (reading) */ - p += yomilen + 1; - yomilen2 = strlen (p); - if (len + yomilen + yomilen2 + 2 < KEYTOSTRSIZE) - { - Vcanna_kakutei_romaji = - make_string ((unsigned char *) p, yomilen2); - /* ローマ字 (romanization) */ - } - } - } - - - /* 候補表示の文字列です。 - (string for displaying candidate translations) */ - Vcanna_henkan_string = Qnil; - if (ks->length >= 0) - { - Vcanna_henkan_string = make_string (ks->echoStr, ks->length); -#ifndef CANNA_MULE - canna_henkan_length = ks->length; - canna_henkan_revPos = ks->revPos; - canna_henkan_revLen = ks->revLen; -#else /* CANNA_MULE */ - if (canna_underline) - { - canna_henkan_length = mule_strlen (ks->echoStr,ks->length); - canna_henkan_revPos = mule_strlen (ks->echoStr,ks->revPos); - canna_henkan_revLen = mule_strlen (ks->echoStr+ks->revPos, - ks->revLen); - } - else - { - count_char (ks->echoStr, ks->length, ks->revPos, ks->revLen, - &canna_henkan_length, &canna_henkan_revPos, - &canna_henkan_revLen); - } -#endif /* CANNA_MULE */ - } - - /* 一覧の情報 (information about the echo area menu) */ - Vcanna_ichiran_string = Qnil; - if (ks->info & KanjiGLineInfo && ks->gline.length >= 0) - { - Vcanna_ichiran_string = make_string (ks->gline.line, - ks->gline.length); -#ifndef CANNA_MULE - canna_ichiran_length = ks->gline.length; - canna_ichiran_revPos = ks->gline.revPos; - canna_ichiran_revLen = ks->gline.revLen; -#else /* CANNA_MULE */ - count_char (ks->gline.line, ks->gline.length, - ks->gline.revPos, ks->gline.revLen, - &canna_ichiran_length, - &canna_ichiran_revPos, &canna_ichiran_revLen); -#endif /* CANNA_MULE */ - } - - /* モードの情報 (mode information) */ - Vcanna_mode_string = Qnil; - if (ks->info & KanjiModeInfo) - { - Vcanna_mode_string = - make_string (ks->mode, strlen ((const char *) ks->mode)); - } - - /* その他の情報 (other information) */ - canna_empty_info = (ks->info & KanjiEmptyInfo) ? 1 : 0; - canna_through_info = (ks->info & KanjiThroughInfo) ? 1 : 0; - } - - return val; -} - -DEFUN ("canna-set-bunsetsu-kugiri", Fcanna_set_bunsetsu, 0, 1, 0, /* -This function sets the clause separator. -If non-nil value is specified, the white space separator will be used. -No separator will be used otherwise. -*/ - (num)) -{ - int kugiri; /* 文節区切りをするか? (display clause separator?) */ - - kugiri = NILP (num) ? 0 : 1; - - jrKanjiControl (0, KC_SETBUNSETSUKUGIRI, (char *) kugiri); - - return Qnil; -} - -/* For whatever reason, calling Fding directly from libCanna loses */ -static int -call_Fding (void) -{ - Fding (Qnil, Qnil, Qnil); - return 0; -} - -DEFUN ("canna-initialize", Fcanna_initialize, 0, 3, 0, /* -Initialize ``canna'', which is a kana-to-kanji converter for XEmacs. -The first arg specifies if inserting space character between BUNSETSU when -candidates are displayed. -The second arg specifies server. -The third arg specifies a file which will be used as a customization -description. -If nil is specified for each arg, the default value will be used. -*/ - (num, server, rcfile)) -{ - Lisp_Object val; - int res; - unsigned char **p, **q; - - int kugiri; /* 文節区切りをするか? (display clause separator?) */ - - IRCP_context = -1; - - if (NILP (num)) - { - kugiri = 1; - } - else - { - CHECK_INT (num); - kugiri = XINT (num); - kugiri = (kugiri == 1) ? 1 : 0; - } - - if (NILP (server)) - { - jrKanjiControl (0, KC_SETSERVERNAME, (char *) 0); - } - else - { - char servername[256]; - - CHECK_STRING (server); - strncpy (servername, (const char *) XSTRING_DATA (server), - XSTRING_LENGTH (server)); - servername[XSTRING_LENGTH (server)] = '\0'; - jrKanjiControl (0, KC_SETSERVERNAME, servername); - } - - if (NILP (rcfile)) - { - jrKanjiControl (0, KC_SETINITFILENAME, (char *) 0); - } - else - { - char rcname[256]; - - CHECK_STRING (rcfile); - strncpy (rcname, (const char *) XSTRING_DATA (rcfile), - XSTRING_LENGTH (rcfile)); - rcname[XSTRING_LENGTH (rcfile)] = '\0'; - jrKanjiControl (0, KC_SETINITFILENAME, rcname); - } - - warning = (char **) 0; -#ifdef nec_ews_svr4 - stop_polling (); -#endif /* nec_ews_svr4 */ - res = jrKanjiControl (0, KC_INITIALIZE, (char *)&warning); -#ifdef nec_ews_svr4 - start_polling (); -#endif /* nec_ews_svr4 */ - val = Qnil; - if (warning) - { - for (p = q = (unsigned char **) warning ; *q ; q++) - ; - while (p < q) - { - q--; - val = Fcons (make_string (*q, strlen ((const char *) *q)), val); - } - } - val = Fcons (val, Qnil); - - if (res == -1) - { - val = Fcons (make_string ((unsigned char *) jrKanjiError, - strlen (jrKanjiError)), val); - /* イニシャライズで失敗した場合。 (on initialization failure) */ - return Fcons (Qnil, val); - } - else - { - jrBeepFunc = call_Fding; - -#ifdef KC_SETAPPNAME -#ifndef CANNA_MULE - jrKanjiControl (0, KC_SETAPPNAME, "nemacs"); -#else /* CANNA_MULE */ - jrKanjiControl (0, KC_SETAPPNAME, "mule"); -#endif /* CANNA_MULE */ -#endif /* KC_SETAPPNAME */ - - jrKanjiControl (0, KC_SETBUNSETSUKUGIRI, (char *) kugiri); - jrKanjiControl (0, KC_SETWIDTH, (char *) 78); -#ifndef CANNA_MULE - jrKanjiControl (0, KC_INHIBITHANKAKUKANA, (char *) 1); -#else - /* mule だったら半角カタカナも使える - (Mule can use half-width katakana) */ - if (canna_inhibit_hankakukana) - jrKanjiControl (0, KC_INHIBITHANKAKUKANA, (char *) 1); -#endif - jrKanjiControl (0, KC_YOMIINFO, (char *) 2); /* ※2: ローマ字まで返す - (*2: return to - romanized form) */ - val = Fcons (Qnil, val); - return Fcons (CANNA_mode_keys (), val); - } -} - -DEFUN ("canna-finalize", Fcanna_finalize, 0, 0, 0, /* -finalize ``canna'', which is a kana-to-kanji converter for XEmacs. -This cause to write miscellaneous informations to kana-to-kanji dictionary. -*/ - ()) -{ - Lisp_Object val; - unsigned char **p; - - jrKanjiControl (0, KC_FINALIZE, (char *)&warning); - - val = Qnil; - if (warning) - { - for (p = (unsigned char**) warning ; *p ; p++) - { - val = Fcons (make_string (*p, strlen ((const char *) *p)), val); - } - } - val = Fcons (val, Qnil); - IRCP_context = -1; - return val; -} - -DEFUN ("canna-touroku-string", Fcanna_touroku_string, 1, 1, 0, /* -Register Kanji words into kana-to-kanji conversion dictionary. -*/ - (str)) -{ - jrKanjiStatusWithValue ksv; - jrKanjiStatus ks; -#ifdef CANNA_MULE - unsigned char cbuf[4096]; -#endif - - CHECK_STRING (str); - ksv.buffer = (unsigned char *) key_buffer; - ksv.bytes_buffer = KEYTOSTRSIZE; -#ifndef CANNA_MULE - ks.echoStr = XSTRING_DATA (str); - ks.length = XSTRING_LENGTH (str); -#else /* CANNA_MULE */ - m2c (XSTRING_DATA (str), XSTRING_LENGTH (str), cbuf); - ks.echoStr = cbuf; - ks.length = strlen ((const char *) cbuf); -#endif /* CANNA_MULE */ - ksv.ks = &ks; - jrKanjiControl (0, KC_DEFINEKANJI, (char *)&ksv); - return storeResults (key_buffer, ksv.val, ksv.ks); -} - -DEFUN ("canna-set-width", Fcanna_set_width, 1, 1, 0, /* -Set status-line width information, which is used to display -kanji candidates. -*/ - (num)) -{ - CHECK_INT (num); - - jrKanjiControl (0, KC_SETWIDTH, (char *) XINT (num)); - return Qnil; -} - -DEFUN ("canna-change-mode", Fcanna_change_mode, 1, 1, 0, /* -Change Japanese pre-edit mode. -*/ - (num)) -{ - jrKanjiStatusWithValue ksv; - jrKanjiStatus ks; - - CHECK_INT (num); - - ksv.buffer = (unsigned char *) key_buffer; - ksv.bytes_buffer = KEYTOSTRSIZE; - ksv.ks = &ks; - ksv.val = XINT (num); - jrKanjiControl (0, KC_CHANGEMODE, (char *)&ksv); - return storeResults (key_buffer, ksv.val, ksv.ks); -} - -static Lisp_Object -CANNA_mode_keys (void) -{ -#define CANNAWORKBUFSIZE 32 - char xxx[CANNAWORKBUFSIZE]; - Lisp_Object val; - int i, n; - - n = jrKanjiControl (0, KC_MODEKEYS, xxx); - val = Qnil; - for (i = n ; i > 0 ;) - { - --i; - /* !!#### something fucked here */ - val = Fcons (make_char ((int)(0xFF & (unsigned char) xxx[i])), val); - } - return val; -} - -DEFUN ("canna-store-yomi", Fcanna_store_yomi, 1, 2, 0, /* -Store yomi characters as a YOMI of kana-to-kanji conversion. -*/ - (yomi, roma)) -{ - jrKanjiStatusWithValue ksv; - jrKanjiStatus ks; - - CHECK_STRING (yomi); -#ifndef CANNA_MULE - strncpy (key_buffer, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi)); - ks.length = XSTRING_LENGTH (yomi); - key_buffer[ks.length] = '\0'; -#else /* CANNA_MULE */ - m2c (XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), - (unsigned char *) key_buffer); - ks.length = strlen (key_buffer); -#endif /* CANNA_MULE */ - - if (NILP (roma)) - { - ks.mode = 0; - } - else - { - CHECK_STRING (roma); - -#ifndef CANNA_MULE - strncpy (key_buffer + XSTRING_LENGTH (yomi) + 1, XSTRING_DATA (roma), - XSTRING_LENGTH (roma)); - key_buffer[XSTRING_LENGTH (yomi) + 1 + XSTRING_LENGTH (roma)] = '\0'; - ks.mode = (unsigned char *)(key_buffer + XSTRING_LENGTH (yomi) + 1); -#else /* CANNA_MULE */ - ks.mode = (unsigned char *)(key_buffer + ks.length + 1); - m2c (XSTRING_DATA (roma), XSTRING_LENGTH (roma), - (unsigned char *) ks.mode); -#endif /* CANNA_MULE */ - } - - ks.echoStr = (unsigned char *) key_buffer; - ksv.buffer = (unsigned char *) key_buffer; /* 返値用 (return value) */ - ksv.bytes_buffer = KEYTOSTRSIZE; - ksv.ks = &ks; - - jrKanjiControl (0, KC_STOREYOMI, (char *)&ksv); - - return storeResults (key_buffer, ksv.val, ksv.ks); -} - -DEFUN ("canna-do-function", Fcanna_do_function, 1, 2, 0, /* -Do specified function at current mode. -*/ - (num, ch)) -{ - jrKanjiStatusWithValue ksv; - jrKanjiStatus ks; - - CHECK_INT (num); - - if (NILP (ch)) - { - *key_buffer = '@'; - } - else - { - CHECK_CHAR (ch); - *key_buffer = XCHAR (ch); - } - - ksv.buffer = (unsigned char *) key_buffer; - ksv.bytes_buffer = KEYTOSTRSIZE; - ksv.ks = &ks; - ksv.val = XINT (num); - jrKanjiControl (0, KC_DO, (char *) &ksv); - return storeResults (key_buffer, ksv.val, ksv.ks); -} - -DEFUN ("canna-parse", Fcanna_parse, 1, 1, 0, /* -Parse customize string. -*/ - (str)) -{ - Lisp_Object val; - unsigned char **p; - int n; - - CHECK_STRING (str); - -#ifndef CANNA_MULE - strncpy (key_buffer, XSTRING_DATA (str), XSTRING_LENGTH (str)); - key_buffer[XSTRING_LENGTH (str)] = '\0'; -#else /* CANNA_MULE */ - m2c (XSTRING_DATA (str), XSTRING_LENGTH (str), (unsigned char *) key_buffer); -#endif /* CANNA_MULE */ - p = (unsigned char**) key_buffer; - n = jrKanjiControl (0, KC_PARSE, (char *) &p); - val = Qnil; - while (n > 0) - { - n--; - val = Fcons (make_string (p[n], strlen ((const char *) p[n])), val); - } - return val; -} - -DEFUN ("canna-query-mode", Fcanna_query_mode, 0, 0, 0, /* -Get current mode string. -*/ - ()) -{ - char buf[256]; - - jrKanjiControl (0, KC_QUERYMODE, buf); - return make_string ((unsigned char *) buf, strlen (buf)); -} - -/* - * Functions following this line are for KKCP interface compatible - * library. These functions may be used by MILK system. - */ - -#define RKBUFSIZE 1024 - -static unsigned char yomibuf[RKBUFSIZE]; -static short kugiri[RKBUFSIZE / 2]; - -static int -confirmContext (void) -{ - if (IRCP_context < 0) - { - int context; - - if ((context = jrKanjiControl (0, KC_GETCONTEXT, (char *) 0)) == -1) - { - return 0; - } - IRCP_context = context; - } - return 1; -} - -static int -byteLen (int bun, int len) -{ - int i = 0, offset = 0, ch; - - if (0 <= bun && bun < RKBUFSIZE) - { - offset = kugiri[bun]; - } - - while (len-- > 0 && (ch = (int) yomibuf[offset + i])) - { - i++; - if (ch & 0x80) - { - i++; - } - } - return i; -} - -DEFUN ("canna-henkan-begin", Fcanna_henkan_begin, 1, 1, 0, /* -Return the result of kana-to-kanji conversion. -Clause separator is set. -*/ - (yomi)) -{ - int nbun; - - CHECK_STRING (yomi); - if (confirmContext () == 0) - { - return Qnil; - } -#ifndef CANNA_MULE - strncpy (yomibuf, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi)); - yomibuf[XSTRING_LENGTH (yomi)] = '\0'; - nbun = RkBgnBun (IRCP_context, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), - (RK_XFER << RK_XFERBITS) | RK_KFER); -#else /* CANNA_MULE */ - m2c (XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), yomibuf); - nbun = RkBgnBun (IRCP_context, (char *) yomibuf, - strlen ((const char *) yomibuf), - (RK_XFER << RK_XFERBITS) | RK_KFER); -#endif /* CANNA_MULE */ - - return kanjiYomiList (IRCP_context, nbun); -} - -static Lisp_Object -kanjiYomiList (int context, int nbun) -{ - Lisp_Object val, res = Qnil; - unsigned char RkBuf[RKBUFSIZE]; - int len, i, total; - - for (i = nbun ; i > 0 ; ) - { - i--; - RkGoTo (context, i); - len = RkGetKanji (context, RkBuf, RKBUFSIZE); - val = make_string (RkBuf, len); - len = RkGetYomi (context, RkBuf, RKBUFSIZE); - res = Fcons (Fcons (val, make_string (RkBuf, len)), res); - if (i < RKBUFSIZE / 2) - { - kugiri[i] = len; - } - } - for (i = 0, total = 0 ; i < nbun ; i++) - { - int temp = kugiri[i]; - kugiri[i] = total; - total += temp; - } - return res; -} - -DEFUN ("canna-henkan-next", Fcanna_henkan_next, 1, 1, 0, /* -Return the list of candidates. -*/ - (bunsetsu)) -{ - int i, slen, len; - unsigned char *p, RkBuf[RKBUFSIZE]; - Lisp_Object res = Qnil; - - CHECK_INT (bunsetsu); - if (confirmContext () == 0) - { - return Qnil; - } - RkGoTo (IRCP_context, XINT (bunsetsu)); - len = RkGetKanjiList (IRCP_context, RkBuf, RKBUFSIZE); - p = RkBuf; - for (i = 0 ; i < len ; i++) - { - slen = strlen ((const char *) p); - if (NILP(res)) - { - res = Fcons (make_string (p, slen), Qnil); - } - else - { - XCDR (res) = Fcons (make_string (p, slen), Qnil); - } - p += slen + 1; - } - return res; -} - -DEFUN ("canna-bunsetu-henkou", Fcanna_bunsetu_henkou, 2, 2, 0, /* -Specify the length of a clause. -*/ - (bunsetsu, bunlen)) -{ - int nbun, len; - - CHECK_INT (bunsetsu); - CHECK_INT (bunlen); - - nbun = XINT (bunsetsu); - if (confirmContext () == 0) - { - return Qnil; - } - RkGoTo (IRCP_context, nbun); - len = byteLen (nbun, XINT (bunlen)); - return kanjiYomiList (IRCP_context, RkResize (IRCP_context, len)); -} - -DEFUN ("canna-henkan-kakutei", Fcanna_henkan_kakutei, 2, 2, 0, /* -Select a candidate. -*/ - (bun, kouho)) -{ - int nbun, nkouho; - - if (confirmContext () == 0) - { - return Qnil; - } - nbun = XINT(bun); - RkGoTo (IRCP_context, nbun); - - nkouho = XINT(kouho); - RkXfer (IRCP_context, nkouho); - return Qt; -} - -DEFUN ("canna-henkan-end", Fcanna_henkan_end, 0, 0, 0, /* -End conversion. -*/ - ()) -{ - if (confirmContext () == 0) - { - return Qnil; - } - RkEndBun (IRCP_context, 1); /* 学習はいつでも行って良いものなのか? - (is it OK to invoke learning function - at arbitrary times?) */ - return Qt; -} - -DEFUN ("canna-henkan-quit", Fcanna_henkan_quit, 0, 0, 0, /* -Quit conversion. -*/ - ()) -{ - if (confirmContext () == 0) - { - return Qnil; - } - RkEndBun (IRCP_context, 0); - return Qt; -} - -/* variables below this line is constants of Canna */ - -static Fixnum canna_mode_AlphaMode; -static Fixnum canna_mode_EmptyMode; -static Fixnum canna_mode_KigoMode; -static Fixnum canna_mode_YomiMode; -static Fixnum canna_mode_JishuMode; -static Fixnum canna_mode_TankouhoMode; -static Fixnum canna_mode_IchiranMode; -static Fixnum canna_mode_YesNoMode; -static Fixnum canna_mode_OnOffMode; -#ifdef CANNA_MODE_AdjustBunsetsuMode -static Fixnum canna_mode_AdjustBunsetsuMode; -#endif -#ifdef CANNA_MODE_ChikujiYomiMode -static Fixnum canna_mode_ChikujiYomiMode; -static Fixnum canna_mode_ChikujiTanMode; -#endif - -static Fixnum canna_mode_HenkanMode; -#ifdef CANNA_MODE_HenkanNyuryokuMode -static Fixnum canna_mode_HenkanNyuryokuMode; -#endif -#ifdef CANNA_MODE_ZenHiraHenkanMode -static Fixnum canna_mode_ZenHiraHenkanMode; -#ifdef CANNA_MODE_HanHiraHenkanMode -static Fixnum canna_mode_HanHiraHenkanMode; -#endif -static Fixnum canna_mode_ZenKataHenkanMode; -static Fixnum canna_mode_HanKataHenkanMode; -static Fixnum canna_mode_ZenAlphaHenkanMode; -static Fixnum canna_mode_HanAlphaHenkanMode; -#endif -static Fixnum canna_mode_ZenHiraKakuteiMode; -#ifdef CANNA_MODE_HanHiraKakuteiMode -static Fixnum canna_mode_HanHiraKakuteiMode; -#endif -static Fixnum canna_mode_ZenKataKakuteiMode; -static Fixnum canna_mode_HanKataKakuteiMode; -static Fixnum canna_mode_ZenAlphaKakuteiMode; -static Fixnum canna_mode_HanAlphaKakuteiMode; -static Fixnum canna_mode_HexMode; -static Fixnum canna_mode_BushuMode; -static Fixnum canna_mode_ExtendMode; -static Fixnum canna_mode_RussianMode; -static Fixnum canna_mode_GreekMode; -static Fixnum canna_mode_LineMode; -static Fixnum canna_mode_ChangingServerMode; -static Fixnum canna_mode_HenkanMethodMode; -static Fixnum canna_mode_DeleteDicMode; -static Fixnum canna_mode_TourokuMode; -static Fixnum canna_mode_TourokuEmptyMode; -static Fixnum canna_mode_TourokuHinshiMode; -static Fixnum canna_mode_TourokuDicMode; -static Fixnum canna_mode_QuotedInsertMode; -static Fixnum canna_mode_BubunMuhenkanMode; -static Fixnum canna_mode_MountDicMode; - -static Fixnum canna_fn_SelfInsert; -static Fixnum canna_fn_FunctionalInsert; -static Fixnum canna_fn_QuotedInsert; -static Fixnum canna_fn_JapaneseMode; -static Fixnum canna_fn_AlphaMode; -static Fixnum canna_fn_HenkanNyuryokuMode; -static Fixnum canna_fn_Forward; -static Fixnum canna_fn_Backward; -static Fixnum canna_fn_Next; -static Fixnum canna_fn_Prev; -static Fixnum canna_fn_BeginningOfLine; -static Fixnum canna_fn_EndOfLine; -static Fixnum canna_fn_DeleteNext; -static Fixnum canna_fn_DeletePrevious; -static Fixnum canna_fn_KillToEndOfLine; -static Fixnum canna_fn_Henkan; -static Fixnum canna_fn_Kakutei; -static Fixnum canna_fn_Extend; -static Fixnum canna_fn_Shrink; -#ifdef CANNA_FN_AdjustBunsetsu -static Fixnum canna_fn_AdjustBunsetsu; -#endif -static Fixnum canna_fn_Quit; -static Fixnum canna_fn_ConvertAsHex; -static Fixnum canna_fn_ConvertAsBushu; -static Fixnum canna_fn_KouhoIchiran; -static Fixnum canna_fn_BubunMuhenkan; -static Fixnum canna_fn_Zenkaku; -static Fixnum canna_fn_Hankaku; -static Fixnum canna_fn_ToUpper; -static Fixnum canna_fn_Capitalize; -static Fixnum canna_fn_ToLower; -static Fixnum canna_fn_Hiragana; -static Fixnum canna_fn_Katakana; -static Fixnum canna_fn_Romaji; -#ifdef CANNA_FN_BaseHiragana -static Fixnum canna_fn_BaseHiragana; -static Fixnum canna_fn_BaseKatakana; -static Fixnum canna_fn_BaseEisu; -static Fixnum canna_fn_BaseZenkaku; -static Fixnum canna_fn_BaseHankaku; -static Fixnum canna_fn_BaseKana; -static Fixnum canna_fn_BaseKakutei; -static Fixnum canna_fn_BaseHenkan; -static Fixnum canna_fn_BaseHiraKataToggle; -static Fixnum canna_fn_BaseZenHanToggle; -static Fixnum canna_fn_BaseKanaEisuToggle; -static Fixnum canna_fn_BaseKakuteiHenkanToggle; -static Fixnum canna_fn_BaseRotateForward; -static Fixnum canna_fn_BaseRotateBackward; -#endif -static Fixnum canna_fn_ExtendMode; -static Fixnum canna_fn_Touroku; -static Fixnum canna_fn_HexMode; -static Fixnum canna_fn_BushuMode; -static Fixnum canna_fn_KigouMode; -#ifdef CANNA_FN_Mark -static Fixnum canna_fn_Mark; -#endif -#ifdef CANNA_FN_TemporalMode -static Fixnum canna_fn_TemporalMode; -#endif - -static Fixnum canna_key_Nfer; -static Fixnum canna_key_Xfer; -static Fixnum canna_key_Up; -static Fixnum canna_key_Left; -static Fixnum canna_key_Right; -static Fixnum canna_key_Down; -static Fixnum canna_key_Insert; -static Fixnum canna_key_Rollup; -static Fixnum canna_key_Rolldown; -static Fixnum canna_key_Home; -static Fixnum canna_key_Help; -static Fixnum canna_key_KP_Key; -static Fixnum canna_key_Shift_Nfer; -static Fixnum canna_key_Shift_Xfer; -static Fixnum canna_key_Shift_Up; -static Fixnum canna_key_Shift_Left; -static Fixnum canna_key_Shift_Right; -static Fixnum canna_key_Shift_Down; -static Fixnum canna_key_Cntrl_Nfer; -static Fixnum canna_key_Cntrl_Xfer; -static Fixnum canna_key_Cntrl_Up; -static Fixnum canna_key_Cntrl_Left; -static Fixnum canna_key_Cntrl_Right; -static Fixnum canna_key_Cntrl_Down; - -Lisp_Object VCANNA; /* by MORIOKA Tomohiko <morioka@jaist.ac.jp> - 1996/6/7 */ - -/* - * Each dynamically loaded Emacs module is given a name at compile - * time. This is a short name, and must be a valid part of a C - * identifier. This name is used to construct the name of several - * functions which must appear in the module source code. - * The first such function, modules_of_XXXX, should load in any dependent - * modules. This function is optional, and the module will still load if - * it is not present in the module. - * - * The second function, which is NOT optional, is syms_of_XXXX, in which - * all functions that the module will be provided are declared. This - * function will contain calls to DEFSUBR(). - * - * The third function, which is also NOT optional, is vars_of_XXXX, in - * which you declare all variables that the module provides. This - * function will contain calls to DEFVAR_LISP(), DEFVAR_BOOL() etc. - * - * When declaring functions and variables in the syms_of_XXXX and - * vars_of_XXXX functions, you use the exact same syntax that you - * would as if this module were being compiled into the pure Emacs. - * - * The fourth function, which is optional, is unload_XXXX, in which actions - * that must be taken to unload the module are listed. XEmacs will unbind - * functions and variables for you. Anything else that must be done should - * appear in this function. - * - * All four of these functions are declared as void functions, - * taking no parameters. Since this sample module is called 'sample', - * the functions will be named 'modules_of_sample', 'syms_of_sample', - * 'vars_of_sample', and 'unload_sample'. - */ - -#if 0 -void -modules_of_canna_api (void) -{ - /* - * This function isn't actually required as we will not be loading - * in any dependent modules, but if we were, we would do something like: - * emodules_load ("dependent.ell", "canna2", "1.0.0"); - */ -} -#endif - -void -syms_of_canna_api (void) -{ - DEFSUBR (Fcanna_key_proc); - DEFSUBR (Fcanna_initialize); - DEFSUBR (Fcanna_finalize); - DEFSUBR (Fcanna_touroku_string); - DEFSUBR (Fcanna_set_width); - DEFSUBR (Fcanna_change_mode); - DEFSUBR (Fcanna_store_yomi); - DEFSUBR (Fcanna_do_function); - DEFSUBR (Fcanna_parse); - DEFSUBR (Fcanna_query_mode); - DEFSUBR (Fcanna_set_bunsetsu); - - DEFSUBR (Fcanna_henkan_begin); - DEFSUBR (Fcanna_henkan_next); - DEFSUBR (Fcanna_bunsetu_henkou); - DEFSUBR (Fcanna_henkan_kakutei); - DEFSUBR (Fcanna_henkan_end); - DEFSUBR (Fcanna_henkan_quit); -} - -void -vars_of_canna_api (void) -{ - DEFVAR_LISP ("CANNA", &VCANNA); /* hir@nec, 1992.5.21 */ - VCANNA = Qt; /* hir@nec, 1992.5.21 */ - - DEFVAR_LISP ("canna-kakutei-string", &Vcanna_kakutei_string /* - -*/ ); - Vcanna_kakutei_string = Qnil; - - DEFVAR_LISP ("canna-kakutei-yomi", &Vcanna_kakutei_yomi /* - -*/ ); - Vcanna_kakutei_yomi = Qnil; - - DEFVAR_LISP ("canna-kakutei-romaji", &Vcanna_kakutei_romaji /* - -*/ ); - Vcanna_kakutei_romaji = Qnil; - - DEFVAR_LISP ("canna-henkan-string", &Vcanna_henkan_string /* - -*/ ); - Vcanna_henkan_string = Qnil; - - DEFVAR_INT ("canna-henkan-length", &canna_henkan_length /* - -*/ ); - canna_henkan_length = 0; - - DEFVAR_INT ("canna-henkan-revpos", &canna_henkan_revPos /* - -*/ ); - canna_henkan_revPos = 0; - - DEFVAR_INT ("canna-henkan-revlen", &canna_henkan_revLen /* - -*/ ); - canna_henkan_revLen = 0; - - DEFVAR_LISP ("canna-ichiran-string", &Vcanna_ichiran_string /* - -*/ ); - Vcanna_ichiran_string = Qnil; - - DEFVAR_INT ("canna-ichiran-length", &canna_ichiran_length /* - -*/ ); - canna_ichiran_length = 0; - - DEFVAR_INT ("canna-ichiran-revpos", &canna_ichiran_revPos /* - -*/ ); - canna_ichiran_revPos = 0; - - DEFVAR_INT ("canna-ichiran-revlen", &canna_ichiran_revLen /* - -*/ ); - canna_ichiran_revLen = 0; - - DEFVAR_LISP ("canna-mode-string", &Vcanna_mode_string /* - -*/ ); - Vcanna_mode_string = Qnil; - - DEFVAR_BOOL ("canna-empty-info", &canna_empty_info /* -For canna -*/ ); - canna_empty_info = 0; - - DEFVAR_BOOL ("canna-through-info", &canna_through_info /* -For canna -*/ ); - canna_through_info = 0; - - DEFVAR_BOOL ("canna-underline", &canna_underline /* -For canna -*/ ); - canna_underline = 0; - - DEFVAR_BOOL ("canna-inhibit-hankakukana", &canna_inhibit_hankakukana /* -For canna -*/ ); - canna_inhibit_hankakukana = 0; - - DEFVAR_INT ("canna-mode-alpha-mode", &canna_mode_AlphaMode /* - -*/ ); - canna_mode_AlphaMode = IROHA_MODE_AlphaMode; - - DEFVAR_INT ("canna-mode-empty-mode", &canna_mode_EmptyMode /* - -*/ ); - canna_mode_EmptyMode = IROHA_MODE_EmptyMode; - - DEFVAR_INT ("canna-mode-kigo-mode", &canna_mode_KigoMode /* - -*/ ); - canna_mode_KigoMode = IROHA_MODE_KigoMode; - - DEFVAR_INT ("canna-mode-yomi-mode", &canna_mode_YomiMode /* - -*/ ); - canna_mode_YomiMode = IROHA_MODE_YomiMode; - - DEFVAR_INT ("canna-mode-jishu-mode", &canna_mode_JishuMode /* - -*/ ); - canna_mode_JishuMode = IROHA_MODE_JishuMode; - - DEFVAR_INT ("canna-mode-tankouho-mode", &canna_mode_TankouhoMode /* - -*/ ); - canna_mode_TankouhoMode = IROHA_MODE_TankouhoMode; - - DEFVAR_INT ("canna-mode-ichiran-mode", &canna_mode_IchiranMode /* - -*/ ); - canna_mode_IchiranMode = IROHA_MODE_IchiranMode; - - DEFVAR_INT ("canna-mode-yes-no-mode", &canna_mode_YesNoMode /* - -*/ ); - canna_mode_YesNoMode = IROHA_MODE_YesNoMode; - - DEFVAR_INT ("canna-mode-on-off-mode", &canna_mode_OnOffMode /* - -*/ ); - canna_mode_OnOffMode = IROHA_MODE_OnOffMode; - -#ifdef CANNA_MODE_AdjustBunsetsuMode - DEFVAR_INT ("canna-mode-adjust-bunsetsu-mode", - &canna_mode_AdjustBunsetsuMode /* - -*/ ); - canna_mode_AdjustBunsetsuMode = CANNA_MODE_AdjustBunsetsuMode; -#endif -#ifdef CANNA_MODE_ChikujiYomiMode - DEFVAR_INT ("canna-mode-chikuji-yomi-mode", &canna_mode_ChikujiYomiMode /* - -*/ ); - canna_mode_ChikujiYomiMode = CANNA_MODE_ChikujiYomiMode; - - DEFVAR_INT ("canna-mode-chikuji-bunsetsu-mode", - &canna_mode_ChikujiTanMode /* - -*/ ); - canna_mode_ChikujiTanMode = CANNA_MODE_ChikujiTanMode; -#endif - - DEFVAR_INT ("canna-mode-henkan-mode", &canna_mode_HenkanMode /* - -*/ ); - canna_mode_HenkanMode = IROHA_MODE_HenkanMode; - -#ifdef CANNA_MODE_HenkanNyuryokuMode - DEFVAR_INT ("canna-mode-henkan-nyuuryoku-mode", - &canna_mode_HenkanNyuryokuMode /* - -*/ ); - canna_mode_HenkanNyuryokuMode = CANNA_MODE_HenkanNyuryokuMode; -#endif -#ifdef CANNA_MODE_ZenHiraHenkanMode - DEFVAR_INT ("canna-mode-zen-hira-henkan-mode", - &canna_mode_ZenHiraHenkanMode /* - -*/ ); - canna_mode_ZenHiraHenkanMode = CANNA_MODE_ZenHiraHenkanMode; -#ifdef CANNA_MODE_HanHiraHenkanMode - DEFVAR_INT ("canna-mode-han-hira-henkan-mode", - &canna_mode_HanHiraHenkanMode /* - -*/ ); - canna_mode_HanHiraHenkanMode = CANNA_MODE_HanHiraHenkanMode; -#endif - DEFVAR_INT ("canna-mode-zen-kata-henkan-mode", - &canna_mode_ZenKataHenkanMode /* - -*/ ); - canna_mode_ZenKataHenkanMode = CANNA_MODE_ZenKataHenkanMode; - - DEFVAR_INT ("canna-mode-han-kata-henkan-mode", - &canna_mode_HanKataHenkanMode /* - -*/ ); - canna_mode_HanKataHenkanMode = CANNA_MODE_HanKataHenkanMode; - - DEFVAR_INT ("canna-mode-zen-alpha-henkan-mode", - &canna_mode_ZenAlphaHenkanMode /* - -*/ ); - canna_mode_ZenAlphaHenkanMode = CANNA_MODE_ZenAlphaHenkanMode; - - DEFVAR_INT ("canna-mode-han-alpha-henkan-mode", - &canna_mode_HanAlphaHenkanMode /* - -*/ ); - canna_mode_HanAlphaHenkanMode = CANNA_MODE_HanAlphaHenkanMode; -#endif - DEFVAR_INT ("canna-mode-zen-hira-kakutei-mode", - &canna_mode_ZenHiraKakuteiMode /* - -*/ ); - canna_mode_ZenHiraKakuteiMode = IROHA_MODE_ZenHiraKakuteiMode; -#ifdef CANNA_MODE_HanHiraKakuteiMode - DEFVAR_INT ("canna-mode-han-hira-kakutei-mode", - &canna_mode_HanHiraKakuteiMode /* - -*/ ); - canna_mode_HanHiraKakuteiMode = CANNA_MODE_HanHiraKakuteiMode; -#endif - DEFVAR_INT ("canna-mode-zen-kata-kakutei-mode", - &canna_mode_ZenKataKakuteiMode /* - -*/ ); - canna_mode_ZenKataKakuteiMode = IROHA_MODE_ZenKataKakuteiMode; - - DEFVAR_INT ("canna-mode-han-kata-kakutei-mode", - &canna_mode_HanKataKakuteiMode /* - -*/ ); - canna_mode_HanKataKakuteiMode = IROHA_MODE_HanKataKakuteiMode; - - DEFVAR_INT ("canna-mode-zen-alpha-kakutei-mode", - &canna_mode_ZenAlphaKakuteiMode /* - -*/ ); - canna_mode_ZenAlphaKakuteiMode = IROHA_MODE_ZenAlphaKakuteiMode; - - DEFVAR_INT ("canna-mode-han-alpha-kakutei-mode", - &canna_mode_HanAlphaKakuteiMode /* - -*/ ); - canna_mode_HanAlphaKakuteiMode = IROHA_MODE_HanAlphaKakuteiMode; - - DEFVAR_INT ("canna-mode-hex-mode", &canna_mode_HexMode /* - -*/ ); - canna_mode_HexMode = IROHA_MODE_HexMode; - - DEFVAR_INT ("canna-mode-bushu-mode", &canna_mode_BushuMode /* - -*/ ); - canna_mode_BushuMode = IROHA_MODE_BushuMode; - - DEFVAR_INT ("canna-mode-extend-mode", &canna_mode_ExtendMode /* - -*/ ); - canna_mode_ExtendMode = IROHA_MODE_ExtendMode; - - DEFVAR_INT ("canna-mode-russian-mode", &canna_mode_RussianMode /* - -*/ ); - canna_mode_RussianMode = IROHA_MODE_RussianMode; - - DEFVAR_INT ("canna-mode-greek-mode", &canna_mode_GreekMode /* - -*/ ); - canna_mode_GreekMode = IROHA_MODE_GreekMode; - - DEFVAR_INT ("canna-mode-line-mode", &canna_mode_LineMode /* - -*/ ); - canna_mode_LineMode = IROHA_MODE_LineMode; - - DEFVAR_INT ("canna-mode-changing-server-mode", - &canna_mode_ChangingServerMode /* - -*/ ); - canna_mode_ChangingServerMode = IROHA_MODE_ChangingServerMode; - - DEFVAR_INT ("canna-mode-henkan-method-mode", - &canna_mode_HenkanMethodMode /* - -*/ ); - canna_mode_HenkanMethodMode = IROHA_MODE_HenkanMethodMode; - - DEFVAR_INT ("canna-mode-delete-dic-mode", &canna_mode_DeleteDicMode /* - -*/ ); - canna_mode_DeleteDicMode = IROHA_MODE_DeleteDicMode; - - DEFVAR_INT ("canna-mode-touroku-mode", &canna_mode_TourokuMode /* - -*/ ); - canna_mode_TourokuMode = IROHA_MODE_TourokuMode; - - DEFVAR_INT ("canna-mode-touroku-empty-mode", - &canna_mode_TourokuEmptyMode /* - -*/ ); - canna_mode_TourokuEmptyMode = IROHA_MODE_TourokuEmptyMode; - - DEFVAR_INT ("canna-mode-touroku-hinshi-mode", - &canna_mode_TourokuHinshiMode /* - -*/ ); - canna_mode_TourokuHinshiMode = IROHA_MODE_TourokuHinshiMode; - - DEFVAR_INT ("canna-mode-touroku-dic-mode", &canna_mode_TourokuDicMode /* - -*/ ); - canna_mode_TourokuDicMode = IROHA_MODE_TourokuDicMode; - - DEFVAR_INT ("canna-mode-quoted-insert-mode", - &canna_mode_QuotedInsertMode /* - -*/ ); - canna_mode_QuotedInsertMode = IROHA_MODE_QuotedInsertMode; - - DEFVAR_INT ("canna-mode-bubun-muhenkan-mode", - &canna_mode_BubunMuhenkanMode /* - -*/ ); - canna_mode_BubunMuhenkanMode = IROHA_MODE_BubunMuhenkanMode; - - DEFVAR_INT ("canna-mode-mount-dic-mode", &canna_mode_MountDicMode /* - -*/ ); - canna_mode_MountDicMode = IROHA_MODE_MountDicMode; - - DEFVAR_INT ("canna-func-self-insert", &canna_fn_SelfInsert /* - -*/ ); - canna_fn_SelfInsert = IROHA_FN_SelfInsert; - - DEFVAR_INT ("canna-func-functional-insert", &canna_fn_FunctionalInsert /* - -*/ ); - canna_fn_FunctionalInsert = IROHA_FN_FunctionalInsert; - - DEFVAR_INT ("canna-func-quoted-insert", &canna_fn_QuotedInsert /* - -*/ ); - canna_fn_QuotedInsert = IROHA_FN_QuotedInsert; - - DEFVAR_INT ("canna-func-japanese-mode", &canna_fn_JapaneseMode /* - -*/ ); - canna_fn_JapaneseMode = IROHA_FN_JapaneseMode; - - DEFVAR_INT ("canna-func-alpha-mode", &canna_fn_AlphaMode /* - -*/ ); - canna_fn_AlphaMode = IROHA_FN_AlphaMode; - - DEFVAR_INT ("canna-func-henkan-nyuryoku-mode", - &canna_fn_HenkanNyuryokuMode /* - -*/ ); - canna_fn_HenkanNyuryokuMode = IROHA_FN_HenkanNyuryokuMode; - - DEFVAR_INT ("canna-func-forward", &canna_fn_Forward /* - -*/ ); - canna_fn_Forward = IROHA_FN_Forward; - - DEFVAR_INT ("canna-func-backward", &canna_fn_Backward /* - -*/ ); - canna_fn_Backward = IROHA_FN_Backward; - - DEFVAR_INT ("canna-func-next", &canna_fn_Next /* - -*/ ); - canna_fn_Next = IROHA_FN_Next; - - DEFVAR_INT ("canna-func-previous", &canna_fn_Prev /* - -*/ ); - canna_fn_Prev = IROHA_FN_Prev; - - DEFVAR_INT ("canna-func-beginning-of-line", &canna_fn_BeginningOfLine /* - -*/ ); - canna_fn_BeginningOfLine = IROHA_FN_BeginningOfLine; - - DEFVAR_INT ("canna-func-end-of-line", &canna_fn_EndOfLine /* - -*/ ); - canna_fn_EndOfLine = IROHA_FN_EndOfLine; - - DEFVAR_INT ("canna-func-delete-next", &canna_fn_DeleteNext /* - -*/ ); - canna_fn_DeleteNext = IROHA_FN_DeleteNext; - - DEFVAR_INT ("canna-func-delete-previous", &canna_fn_DeletePrevious /* - -*/ ); - canna_fn_DeletePrevious = IROHA_FN_DeletePrevious; - - DEFVAR_INT ("canna-func-kill-to-end-of-line", &canna_fn_KillToEndOfLine /* - -*/ ); - canna_fn_KillToEndOfLine = IROHA_FN_KillToEndOfLine; - - DEFVAR_INT ("canna-func-henkan", &canna_fn_Henkan /* - -*/ ); - canna_fn_Henkan = IROHA_FN_Henkan; - - DEFVAR_INT ("canna-func-kakutei", &canna_fn_Kakutei /* - -*/ ); - canna_fn_Kakutei = IROHA_FN_Kakutei; - - DEFVAR_INT ("canna-func-extend", &canna_fn_Extend /* - -*/ ); - canna_fn_Extend = IROHA_FN_Extend; - - DEFVAR_INT ("canna-func-shrink", &canna_fn_Shrink /* - -*/ ); - canna_fn_Shrink = IROHA_FN_Shrink; - -#ifdef CANNA_FN_AdjustBunsetsu - DEFVAR_INT ("canna-func-adjust-bunsetsu", &canna_fn_AdjustBunsetsu /* - -*/ ); - canna_fn_AdjustBunsetsu = CANNA_FN_AdjustBunsetsu; -#endif - DEFVAR_INT ("canna-func-quit", &canna_fn_Quit /* - -*/ ); - canna_fn_Quit = IROHA_FN_Quit; - - DEFVAR_INT ("canna-func-convert-as-hex", &canna_fn_ConvertAsHex /* - -*/ ); - canna_fn_ConvertAsHex = IROHA_FN_ConvertAsHex; - - DEFVAR_INT ("canna-func-convert-as-bushu", &canna_fn_ConvertAsBushu /* - -*/ ); - canna_fn_ConvertAsBushu = IROHA_FN_ConvertAsBushu; - - DEFVAR_INT ("canna-func-kouho-ichiran", &canna_fn_KouhoIchiran /* - -*/ ); - canna_fn_KouhoIchiran = IROHA_FN_KouhoIchiran; - - DEFVAR_INT ("canna-func-bubun-muhenkan", &canna_fn_BubunMuhenkan /* - -*/ ); - canna_fn_BubunMuhenkan = IROHA_FN_BubunMuhenkan; - - DEFVAR_INT ("canna-func-zenkaku", &canna_fn_Zenkaku /* - -*/ ); - canna_fn_Zenkaku = IROHA_FN_Zenkaku; - - DEFVAR_INT ("canna-func-hankaku", &canna_fn_Hankaku /* - -*/ ); - canna_fn_Hankaku = IROHA_FN_Hankaku; - - DEFVAR_INT ("canna-func-to-upper", &canna_fn_ToUpper /* - -*/ ); - canna_fn_ToUpper = IROHA_FN_ToUpper; - - DEFVAR_INT ("canna-func-capitalize", &canna_fn_Capitalize /* - -*/ ); - canna_fn_Capitalize = IROHA_FN_Capitalize; - - DEFVAR_INT ("canna-func-to-lower", &canna_fn_ToLower /* - -*/ ); - canna_fn_ToLower = IROHA_FN_ToLower; - - DEFVAR_INT ("canna-func-hiragana", &canna_fn_Hiragana /* - -*/ ); - canna_fn_Hiragana = IROHA_FN_Hiragana; - - DEFVAR_INT ("canna-func-katakana", &canna_fn_Katakana /* - -*/ ); - canna_fn_Katakana = IROHA_FN_Katakana; - - DEFVAR_INT ("canna-func-romaji", &canna_fn_Romaji /* - -*/ ); - canna_fn_Romaji = IROHA_FN_Romaji; - -#ifdef CANNA_FN_BaseHiragana - DEFVAR_INT ("canna-func-base-hiragana", &canna_fn_BaseHiragana /* - -*/ ); - canna_fn_BaseHiragana = CANNA_FN_BaseHiragana; - - DEFVAR_INT ("canna-func-base-katakana", &canna_fn_BaseKatakana /* - -*/ ); - canna_fn_BaseKatakana = CANNA_FN_BaseKatakana; - - DEFVAR_INT ("canna-func-base-eisu", &canna_fn_BaseEisu /* - -*/ ); - canna_fn_BaseEisu = CANNA_FN_BaseEisu; - - DEFVAR_INT ("canna-func-base-zenkaku", &canna_fn_BaseZenkaku /* - -*/ ); - canna_fn_BaseZenkaku = CANNA_FN_BaseZenkaku; - - DEFVAR_INT ("canna-func-base-hankaku", &canna_fn_BaseHankaku /* - -*/ ); - canna_fn_BaseHankaku = CANNA_FN_BaseHankaku; - - DEFVAR_INT ("canna-func-base-kana", &canna_fn_BaseKana /* - -*/ ); - canna_fn_BaseKana = CANNA_FN_BaseKana; - - DEFVAR_INT ("canna-func-base-kakutei", &canna_fn_BaseKakutei /* - -*/ ); - canna_fn_BaseKakutei = CANNA_FN_BaseKakutei; - - DEFVAR_INT ("canna-func-base-henkan", &canna_fn_BaseHenkan /* - -*/ ); - canna_fn_BaseHenkan = CANNA_FN_BaseHenkan; - - DEFVAR_INT ("canna-func-base-hiragana-katakana-toggle", - &canna_fn_BaseHiraKataToggle /* - -*/ ); - canna_fn_BaseHiraKataToggle = CANNA_FN_BaseHiraKataToggle; - - DEFVAR_INT ("canna-func-base-zenkaku-hankaku-toggle", - &canna_fn_BaseZenHanToggle /* - -*/ ); - canna_fn_BaseZenHanToggle = CANNA_FN_BaseZenHanToggle; - - DEFVAR_INT ("canna-func-base-kana-eisu-toggle", - &canna_fn_BaseKanaEisuToggle /* - -*/ ); - canna_fn_BaseKanaEisuToggle = CANNA_FN_BaseKanaEisuToggle; - - DEFVAR_INT ("canna-func-base-kakutei-henkan-toggle", - &canna_fn_BaseKakuteiHenkanToggle /* - -*/ ); - canna_fn_BaseKakuteiHenkanToggle = CANNA_FN_BaseKakuteiHenkanToggle; - - DEFVAR_INT ("canna-func-base-rotate-forward", - &canna_fn_BaseRotateForward /* - -*/ ); - canna_fn_BaseRotateForward = CANNA_FN_BaseRotateForward; - - DEFVAR_INT ("canna-func-base-rotate-backward", - &canna_fn_BaseRotateBackward /* - -*/ ); - canna_fn_BaseRotateBackward = CANNA_FN_BaseRotateBackward; - -#endif - DEFVAR_INT ("canna-func-extend-mode", &canna_fn_ExtendMode /* - -*/ ); - canna_fn_ExtendMode = IROHA_FN_ExtendMode; - - DEFVAR_INT ("canna-func-touroku", &canna_fn_Touroku /* - -*/ ); - canna_fn_Touroku = IROHA_FN_Touroku; - - DEFVAR_INT ("canna-func-hex-mode", &canna_fn_HexMode /* - -*/ ); - canna_fn_HexMode = IROHA_FN_HexMode; - - DEFVAR_INT ("canna-func-bushu-mode", &canna_fn_BushuMode /* - -*/ ); - canna_fn_BushuMode = IROHA_FN_BushuMode; - - DEFVAR_INT ("canna-func-kigo-mode", &canna_fn_KigouMode /* - -*/ ); - canna_fn_KigouMode = IROHA_FN_KigouMode; - -#ifdef CANNA_FN_Mark - DEFVAR_INT ("canna-func-mark", &canna_fn_Mark /* - -*/ ); - canna_fn_Mark = CANNA_FN_Mark; -#endif -#ifdef CANNA_FN_TemporalMode - DEFVAR_INT ("canna-func-temporal-mode", &canna_fn_TemporalMode /* - -*/ ); - canna_fn_TemporalMode = CANNA_FN_TemporalMode; -#endif - - DEFVAR_INT ("canna-key-nfer", &canna_key_Nfer /* - -*/ ); - canna_key_Nfer = IROHA_KEY_Nfer; - - DEFVAR_INT ("canna-key-xfer", &canna_key_Xfer /* - -*/ ); - canna_key_Xfer = IROHA_KEY_Xfer; - - DEFVAR_INT ("canna-key-up", &canna_key_Up /* - -*/ ); - canna_key_Up = IROHA_KEY_Up; - - DEFVAR_INT ("canna-key-left", &canna_key_Left /* - -*/ ); - canna_key_Left = IROHA_KEY_Left; - - DEFVAR_INT ("canna-key-right", &canna_key_Right /* - -*/ ); - canna_key_Right = IROHA_KEY_Right; - - DEFVAR_INT ("canna-key-down", &canna_key_Down /* - -*/ ); - canna_key_Down = IROHA_KEY_Down; - - DEFVAR_INT ("canna-key-insert", &canna_key_Insert /* - -*/ ); - canna_key_Insert = IROHA_KEY_Insert; - - DEFVAR_INT ("canna-key-rollup", &canna_key_Rollup /* - -*/ ); - canna_key_Rollup = IROHA_KEY_Rollup; - - DEFVAR_INT ("canna-key-rolldown", &canna_key_Rolldown /* - -*/ ); - canna_key_Rolldown = IROHA_KEY_Rolldown; - - DEFVAR_INT ("canna-key-home", &canna_key_Home /* - -*/ ); - canna_key_Home = IROHA_KEY_Home; - - DEFVAR_INT ("canna-key-help", &canna_key_Help /* - -*/ ); - canna_key_Help = IROHA_KEY_Help; - - DEFVAR_INT ("canna-key-kp-key", &canna_key_KP_Key /* - -*/ ); - canna_key_KP_Key = IROHA_KEY_KP_Key; - - DEFVAR_INT ("canna-key-shift-nfer", &canna_key_Shift_Nfer /* - -*/ ); - canna_key_Shift_Nfer = IROHA_KEY_Shift_Nfer; - - DEFVAR_INT ("canna-key-shift-xfer", &canna_key_Shift_Xfer /* - -*/ ); - canna_key_Shift_Xfer = IROHA_KEY_Shift_Xfer; - - DEFVAR_INT ("canna-key-shift-up", &canna_key_Shift_Up /* - -*/ ); - canna_key_Shift_Up = IROHA_KEY_Shift_Up; - - DEFVAR_INT ("canna-key-shift-left", &canna_key_Shift_Left /* - -*/ ); - canna_key_Shift_Left = IROHA_KEY_Shift_Left; - - DEFVAR_INT ("canna-key-shift-right", &canna_key_Shift_Right /* - -*/ ); - canna_key_Shift_Right = IROHA_KEY_Shift_Right; - - DEFVAR_INT ("canna-key-shift-down", &canna_key_Shift_Down /* - -*/ ); - canna_key_Shift_Down = IROHA_KEY_Shift_Down; - - DEFVAR_INT ("canna-key-control-nfer", &canna_key_Cntrl_Nfer /* - -*/ ); - canna_key_Cntrl_Nfer = IROHA_KEY_Cntrl_Nfer; - - DEFVAR_INT ("canna-key-control-xfer", &canna_key_Cntrl_Xfer /* - -*/ ); - canna_key_Cntrl_Xfer = IROHA_KEY_Cntrl_Xfer; - - DEFVAR_INT ("canna-key-control-up", &canna_key_Cntrl_Up /* - -*/ ); - canna_key_Cntrl_Up = IROHA_KEY_Cntrl_Up; - - DEFVAR_INT ("canna-key-control-left", &canna_key_Cntrl_Left /* - -*/ ); - canna_key_Cntrl_Left = IROHA_KEY_Cntrl_Left; - - DEFVAR_INT ("canna-key-control-right", &canna_key_Cntrl_Right /* - -*/ ); - canna_key_Cntrl_Right = IROHA_KEY_Cntrl_Right; - - DEFVAR_INT ("canna-key-control-down", &canna_key_Cntrl_Down /* - -*/ ); - canna_key_Cntrl_Down = IROHA_KEY_Cntrl_Down; - - Fprovide (intern ("CANNA")); -} - -#if 0 -#ifdef HAVE_SHLIB -void unload_canna_api (void); -void -unload_canna_api (void) -{ - /* We don't need to do anything here in the sample case. However, if you - create any new types with INIT_LRECORD_IMPLEMENTATION (sample_type), then - UNDEF_LRECORD_IMPLEMENTATION (sample_type) must appear here. Also, any - symbols declared with DEFSYMBOL (Qsample_var), or one of its variants, - must have a corresponding unstaticpro_nodump (&Qsample_var) here. */ -} -#endif -#endif - -#ifdef CANNA_MULE -/* To handle MULE internal code and EUC. - I assume CANNA can handle only Japanese EUC. */ - -/* EUC multibyte string to MULE internal string */ - -static void -c2mu (unsigned char *cp, int l, unsigned char *mp) -{ - unsigned char ch, *ep = cp+l; - - while ((cp < ep) && (ch = *cp)) - { - if ((unsigned char) ch == ISO_CODE_SS2) - { - *mp++ = LEADING_BYTE_KATAKANA_JISX0201; - cp++; - } - else if ((unsigned char) ch == ISO_CODE_SS3) - { - *mp++ = LEADING_BYTE_JAPANESE_JISX0212; - cp++; - *mp++ = *cp++; - } - else if (ch & 0x80) - { - *mp++ = LEADING_BYTE_JAPANESE_JISX0208; - *mp++ = *cp++; - } - *mp++ = *cp++; - } - *mp = 0; -} - -/* MULE internal string to EUC multibyte string */ - -static void -m2c (unsigned char *mp, int l, unsigned char *cp) -{ - unsigned char ch, *ep = mp + l; - - while ((mp < ep) && (ch = *mp++)) - { - switch (ch) - { - case LEADING_BYTE_KATAKANA_JISX0201: - *cp++ = ISO_CODE_SS2; - *cp++ = *mp++; - break; - case LEADING_BYTE_JAPANESE_JISX0212: - *cp++ = ISO_CODE_SS3; - case LEADING_BYTE_JAPANESE_JISX0208: - *cp++ = *mp++; - *cp++ = *mp++; - break; - default: - *cp++ = ch; - break; - } - } - *cp = 0; -} - -#undef make_string - -/* make_string after converting EUC string to MULE internal string */ -static Lisp_Object -mule_make_string (unsigned char *p, int l) -{ - unsigned char cbuf[4096]; - - c2mu (p,l,cbuf); - return (make_string (cbuf, strlen ((const char *) cbuf))); -} - -/* return the MULE internal string length of EUC string */ -/* Modified by sb to return a character count not byte count. */ -static int -mule_strlen (unsigned char *p, int l) -{ - unsigned char ch, *cp = p; - int len = 0; - - while ((cp < p + l) && (ch = *cp)) - { - if ((unsigned char) ch == ISO_CODE_SS2) - { - len++; - cp += 2; - } - else if ((unsigned char) ch == ISO_CODE_SS3) - { - len++; - cp += 3; - } - else if (ch & 0x80) - { - len++; - cp += 2; - } - else - { - len++; - cp++; - } - } - return (len); -} - -/* count number of characters */ -static void -count_char (unsigned char *p, int len, int pos, int rev, - Fixnum *clen, Fixnum *cpos, Fixnum *crev) -{ - unsigned char *q = p; - - *clen = *cpos = *crev = 0; - if (len == 0) return; - while (q < p + pos) - { - (*clen)++; - (*cpos)++; - if (*q++ & 0x80) q++; - } - while (q < p + pos + rev) - { - (*clen)++; - (*crev)++; - if (*q++ & 0x80) q++; - } - while (q < p + len) - { - (*clen)++; - if (*q++ & 0x80) q++; - } -} -#endif /* CANNA_MULE */
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/modules/canna/canna_api.c Fri Oct 21 15:48:42 2005 +0000 @@ -0,0 +1,1988 @@ +/* CANNA interface -*- coding: euc-jp -*- + + Copyright (C) 1995 Free Software Foundation, Inc. + Copyright (C) 1995 Sun Microsystems, Inc. + +This file is part of XEmacs. + +XEmacs 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, or (at your option) any +later version. + +XEmacs 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 XEmacs; see the file COPYING. If not, write to +the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +Boston, MA 02111-1307, USA. */ + +/* Synched up with: Mule 2.3. Not in FSF. */ + +/* Japanese comments were translated 2000-12-06 by Stephen Turnbull + <stephen@xemacs.org>. I haven't verified that the Japanese comments + were correct. YMMV, NO WARRANTY, not even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. (^^;;; as the + Japanese say. */ + +/* + + Authors: Akira Kon (kon@uxd.fc.nec.co.jp) + Ichiro Hirakura (hirakura@uxd.fc.nec.co.jp) + + Functions defined in this file are + + (canna-key-proc key) + key: single STRING + RETURNS: + Length of converted string if no error occurs. + Error string if error occurs. + DESCRIPTION: + Convert a key input to a set of strings. The + strings contain both well-formed string and a + intermediate result to show the translation + information to a user. converted strings are + stored in specific variables. + + (canna-initialize) + RETURNS: + List of the following things: + - list of keys to toggle Japanese-mode + - error message + - list of warning messages + DESCRIPTION: + Initialize ``canna'', which is a kana-to-kanji + converter for XEmacs. The first arg + specifies if inserting space character between + BUNSETSU when candidates are displayed. The + second arg specifies server. The third arg + specifies a file which will be used as a + customization description. If nil is + specified for each arg, the default value will + be used. + + (canna-finalize) + RETURNS: + list of warning messages + DESCRIPTION: + finalize ``canna'', which is a kana-to-kanji + converter for XEmacs. This cause to write + miscellaneous informations to kana-to-kanji + dictionary. + + (canna-touroku-string string) + string: + String to register to a dictionary. + RETURNS: + The same thing returns as canna-key-proc does. + DESCRIPTION: + Register Kanji words into kana-to-kanji + conversion dictionary. + + (canna-set-width width) + width: + Column width of the place where the candidates + of kana-to-kanji conversion will be shown. + RETURNS: + nil + DESCRIPTION: + Set status-line width information, which is + used to display kanji candidates. + + (canna-change-mode num) + num: + The mode number of Canna. + RETURNS: + The same thing returns as canna-key-proc does. + DESCRIPTION: + Change Japanese pre-edit mode. + + (canna-store-yomi yomi roma) + yomi: + ``Yomi'' to be stored. + roma: + ``Romaji'' which corresponds to the ``Yomi''. + RETURNS: + The same thing returns as canna-key-proc does. + DESCRIPTION: + Store yomi characters as a YOMI of + kana-to-kanji conversion. + + (canna-do-function num ch) + num: + A function number to be called. + ch: + A character will be specified in order to feed + the character to the function if the function + needs a input character. + RETURNS: + The same thing returns as canna-key-proc does. + DESCRIPTION: + Do specified function at current mode. + + (canna-parse string) + string: + To be parsed. + RETURNS: + List of warning messages. + DESCRIPTION: + Parse customize string. + + (canna-query-mode) + RETURNS: + A string which indicate the current mode. + DESCRIPTION: + Get current mode string. + + Functions below are used for KKCP compatible library. These + functions provides a base kana-to-kanji conversion system for EGG. + These functions may be used when users want to change the engine + from Wnn to Canna without changing user interface of Japanese input. + + (canna-henkan-begin) + (canna-henkan-next) + (canna-bunsetu-henkou) + (canna-henkan-kakutei) + (canna-henkan-end) + (canna-henkan-quit) + + */ + +#include <config.h> +#include "lisp.h" +#ifdef HAVE_SHLIB +#include "emodules.h" +#endif + +#include "buffer.h" +#include "file-coding.h" + +#ifdef CANNA2 +#define IROHA_BC +#define CANNA_NEW_WCHAR_AWARE +#include "canna/jrkanji.h" +#include "canna/RK.h" +#else /* !CANNA2 */ +#include "iroha/jrkanji.h" +#include "iroha/RK.h" +#endif /* !CANNA2 */ +extern char *jrKanjiError; + +extern int (*jrBeepFunc) (void); + +/* #### is this global really necessary? */ +#define KEYTOSTRSIZE 2048 +static char key_buffer[KEYTOSTRSIZE]; +static char **warning; + +static int canna_empty_info, canna_through_info; +static int canna_underline; +static int canna_inhibit_hankakukana; + +static Lisp_Object Vcanna_kakutei_string; +static Lisp_Object Vcanna_kakutei_yomi; +static Lisp_Object Vcanna_kakutei_romaji; +static Lisp_Object Vcanna_henkan_string; +static Fixnum canna_henkan_length; +static Fixnum canna_henkan_revPos; +static Fixnum canna_henkan_revLen; +static Lisp_Object Vcanna_ichiran_string; +static Fixnum canna_ichiran_length; +static Fixnum canna_ichiran_revPos; +static Fixnum canna_ichiran_revLen; +static Lisp_Object Vcanna_mode_string; + +static int IRCP_context; + +static Lisp_Object storeResults (char *, int, jrKanjiStatus *); +static Lisp_Object kanjiYomiList (int, int); +static Lisp_Object CANNA_mode_keys (void); + +#ifdef CANNA_MULE +static void m2c (unsigned char *, int, unsigned char *); +static Lisp_Object mule_make_string (unsigned char *, int); +static int mule_strlen (unsigned char *, int); +static void count_char (unsigned char *,int, int, int, Fixnum *, Fixnum *, Fixnum *); +#define make_string mule_make_string +#endif + +/* Lisp functions definition */ + +DEFUN ("canna-key-proc", Fcanna_key_proc, 1, 1, 0, /* +Translate a key input to a set of strings. The strings contain both +well-formed string and intermediate result to show the translation +information to a user. Converted strings are stored in specific +variables. +*/ + (ch)) +{ + jrKanjiStatus ks; + int len; + + CHECK_CHAR_COERCE_INT (ch); + len = jrKanjiString (0, XCHAR (ch), key_buffer, KEYTOSTRSIZE, &ks); + return storeResults (key_buffer, len, &ks); +} + +static Lisp_Object +storeResults (char *buf, int len, jrKanjiStatus *ks) +{ + Lisp_Object val = Qnil; + + if (len < 0) + { /* Error detected */ + val = make_string ((unsigned char*) jrKanjiError, strlen (jrKanjiError)); + } + else + { + /* 確定した文字列 (the confirmed string) */ + Vcanna_kakutei_string = make_string ((unsigned char *) buf, len); + val = make_int (len); + /* 確定した文字列の読みの情報... + (info about the reading of the confirmed string) */ + Vcanna_kakutei_yomi = Vcanna_kakutei_romaji = Qnil; + if (ks->info & KanjiYomiInfo) + { + char *p = buf + len + 1; + int yomilen = strlen (p); + + if (len + yomilen + 1 < KEYTOSTRSIZE) + { + int yomilen2; + + Vcanna_kakutei_yomi = + make_string ((unsigned char *) p, yomilen); /* 読み (reading) */ + p += yomilen + 1; + yomilen2 = strlen (p); + if (len + yomilen + yomilen2 + 2 < KEYTOSTRSIZE) + { + Vcanna_kakutei_romaji = + make_string ((unsigned char *) p, yomilen2); + /* ローマ字 (romanization) */ + } + } + } + + + /* 候補表示の文字列です。 + (string for displaying candidate translations) */ + Vcanna_henkan_string = Qnil; + if (ks->length >= 0) + { + Vcanna_henkan_string = make_string (ks->echoStr, ks->length); +#ifndef CANNA_MULE + canna_henkan_length = ks->length; + canna_henkan_revPos = ks->revPos; + canna_henkan_revLen = ks->revLen; +#else /* CANNA_MULE */ + if (canna_underline) + { + canna_henkan_length = mule_strlen (ks->echoStr,ks->length); + canna_henkan_revPos = mule_strlen (ks->echoStr,ks->revPos); + canna_henkan_revLen = mule_strlen (ks->echoStr+ks->revPos, + ks->revLen); + } + else + { + count_char (ks->echoStr, ks->length, ks->revPos, ks->revLen, + &canna_henkan_length, &canna_henkan_revPos, + &canna_henkan_revLen); + } +#endif /* CANNA_MULE */ + } + + /* 一覧の情報 (information about the echo area menu) */ + Vcanna_ichiran_string = Qnil; + if (ks->info & KanjiGLineInfo && ks->gline.length >= 0) + { + Vcanna_ichiran_string = make_string (ks->gline.line, + ks->gline.length); +#ifndef CANNA_MULE + canna_ichiran_length = ks->gline.length; + canna_ichiran_revPos = ks->gline.revPos; + canna_ichiran_revLen = ks->gline.revLen; +#else /* CANNA_MULE */ + count_char (ks->gline.line, ks->gline.length, + ks->gline.revPos, ks->gline.revLen, + &canna_ichiran_length, + &canna_ichiran_revPos, &canna_ichiran_revLen); +#endif /* CANNA_MULE */ + } + + /* モードの情報 (mode information) */ + Vcanna_mode_string = Qnil; + if (ks->info & KanjiModeInfo) + { + Vcanna_mode_string = + make_string (ks->mode, strlen ((const char *) ks->mode)); + } + + /* その他の情報 (other information) */ + canna_empty_info = (ks->info & KanjiEmptyInfo) ? 1 : 0; + canna_through_info = (ks->info & KanjiThroughInfo) ? 1 : 0; + } + + return val; +} + +DEFUN ("canna-set-bunsetsu-kugiri", Fcanna_set_bunsetsu, 0, 1, 0, /* +This function sets the clause separator. +If non-nil value is specified, the white space separator will be used. +No separator will be used otherwise. +*/ + (num)) +{ + int kugiri; /* 文節区切りをするか? (display clause separator?) */ + + kugiri = NILP (num) ? 0 : 1; + + jrKanjiControl (0, KC_SETBUNSETSUKUGIRI, (char *) kugiri); + + return Qnil; +} + +/* For whatever reason, calling Fding directly from libCanna loses */ +static int +call_Fding (void) +{ + Fding (Qnil, Qnil, Qnil); + return 0; +} + +DEFUN ("canna-initialize", Fcanna_initialize, 0, 3, 0, /* +Initialize ``canna'', which is a kana-to-kanji converter for XEmacs. +The first arg specifies if inserting space character between BUNSETSU when +candidates are displayed. +The second arg specifies server. +The third arg specifies a file which will be used as a customization +description. +If nil is specified for each arg, the default value will be used. +*/ + (num, server, rcfile)) +{ + Lisp_Object val; + int res; + unsigned char **p, **q; + + int kugiri; /* 文節区切りをするか? (display clause separator?) */ + + IRCP_context = -1; + + if (NILP (num)) + { + kugiri = 1; + } + else + { + CHECK_INT (num); + kugiri = XINT (num); + kugiri = (kugiri == 1) ? 1 : 0; + } + + if (NILP (server)) + { + jrKanjiControl (0, KC_SETSERVERNAME, (char *) 0); + } + else + { + char servername[256]; + + CHECK_STRING (server); + strncpy (servername, (const char *) XSTRING_DATA (server), + XSTRING_LENGTH (server)); + servername[XSTRING_LENGTH (server)] = '\0'; + jrKanjiControl (0, KC_SETSERVERNAME, servername); + } + + if (NILP (rcfile)) + { + jrKanjiControl (0, KC_SETINITFILENAME, (char *) 0); + } + else + { + char rcname[256]; + + CHECK_STRING (rcfile); + strncpy (rcname, (const char *) XSTRING_DATA (rcfile), + XSTRING_LENGTH (rcfile)); + rcname[XSTRING_LENGTH (rcfile)] = '\0'; + jrKanjiControl (0, KC_SETINITFILENAME, rcname); + } + + warning = (char **) 0; +#ifdef nec_ews_svr4 + stop_polling (); +#endif /* nec_ews_svr4 */ + res = jrKanjiControl (0, KC_INITIALIZE, (char *)&warning); +#ifdef nec_ews_svr4 + start_polling (); +#endif /* nec_ews_svr4 */ + val = Qnil; + if (warning) + { + for (p = q = (unsigned char **) warning ; *q ; q++) + ; + while (p < q) + { + q--; + val = Fcons (make_string (*q, strlen ((const char *) *q)), val); + } + } + val = Fcons (val, Qnil); + + if (res == -1) + { + val = Fcons (make_string ((unsigned char *) jrKanjiError, + strlen (jrKanjiError)), val); + /* イニシャライズで失敗した場合。 (on initialization failure) */ + return Fcons (Qnil, val); + } + else + { + jrBeepFunc = call_Fding; + +#ifdef KC_SETAPPNAME +#ifndef CANNA_MULE + jrKanjiControl (0, KC_SETAPPNAME, "nemacs"); +#else /* CANNA_MULE */ + jrKanjiControl (0, KC_SETAPPNAME, "mule"); +#endif /* CANNA_MULE */ +#endif /* KC_SETAPPNAME */ + + jrKanjiControl (0, KC_SETBUNSETSUKUGIRI, (char *) kugiri); + jrKanjiControl (0, KC_SETWIDTH, (char *) 78); +#ifndef CANNA_MULE + jrKanjiControl (0, KC_INHIBITHANKAKUKANA, (char *) 1); +#else + /* mule だったら半角カタカナも使える + (Mule can use half-width katakana) */ + if (canna_inhibit_hankakukana) + jrKanjiControl (0, KC_INHIBITHANKAKUKANA, (char *) 1); +#endif + jrKanjiControl (0, KC_YOMIINFO, (char *) 2); /* ※2: ローマ字まで返す + (*2: return to + romanized form) */ + val = Fcons (Qnil, val); + return Fcons (CANNA_mode_keys (), val); + } +} + +DEFUN ("canna-finalize", Fcanna_finalize, 0, 0, 0, /* +finalize ``canna'', which is a kana-to-kanji converter for XEmacs. +This cause to write miscellaneous informations to kana-to-kanji dictionary. +*/ + ()) +{ + Lisp_Object val; + unsigned char **p; + + jrKanjiControl (0, KC_FINALIZE, (char *)&warning); + + val = Qnil; + if (warning) + { + for (p = (unsigned char**) warning ; *p ; p++) + { + val = Fcons (make_string (*p, strlen ((const char *) *p)), val); + } + } + val = Fcons (val, Qnil); + IRCP_context = -1; + return val; +} + +DEFUN ("canna-touroku-string", Fcanna_touroku_string, 1, 1, 0, /* +Register Kanji words into kana-to-kanji conversion dictionary. +*/ + (str)) +{ + jrKanjiStatusWithValue ksv; + jrKanjiStatus ks; +#ifdef CANNA_MULE + unsigned char cbuf[4096]; +#endif + + CHECK_STRING (str); + ksv.buffer = (unsigned char *) key_buffer; + ksv.bytes_buffer = KEYTOSTRSIZE; +#ifndef CANNA_MULE + ks.echoStr = XSTRING_DATA (str); + ks.length = XSTRING_LENGTH (str); +#else /* CANNA_MULE */ + m2c (XSTRING_DATA (str), XSTRING_LENGTH (str), cbuf); + ks.echoStr = cbuf; + ks.length = strlen ((const char *) cbuf); +#endif /* CANNA_MULE */ + ksv.ks = &ks; + jrKanjiControl (0, KC_DEFINEKANJI, (char *)&ksv); + return storeResults (key_buffer, ksv.val, ksv.ks); +} + +DEFUN ("canna-set-width", Fcanna_set_width, 1, 1, 0, /* +Set status-line width information, which is used to display +kanji candidates. +*/ + (num)) +{ + CHECK_INT (num); + + jrKanjiControl (0, KC_SETWIDTH, (char *) XINT (num)); + return Qnil; +} + +DEFUN ("canna-change-mode", Fcanna_change_mode, 1, 1, 0, /* +Change Japanese pre-edit mode. +*/ + (num)) +{ + jrKanjiStatusWithValue ksv; + jrKanjiStatus ks; + + CHECK_INT (num); + + ksv.buffer = (unsigned char *) key_buffer; + ksv.bytes_buffer = KEYTOSTRSIZE; + ksv.ks = &ks; + ksv.val = XINT (num); + jrKanjiControl (0, KC_CHANGEMODE, (char *)&ksv); + return storeResults (key_buffer, ksv.val, ksv.ks); +} + +static Lisp_Object +CANNA_mode_keys (void) +{ +#define CANNAWORKBUFSIZE 32 + char xxx[CANNAWORKBUFSIZE]; + Lisp_Object val; + int i, n; + + n = jrKanjiControl (0, KC_MODEKEYS, xxx); + val = Qnil; + for (i = n ; i > 0 ;) + { + --i; + /* !!#### something fucked here */ + val = Fcons (make_char ((int)(0xFF & (unsigned char) xxx[i])), val); + } + return val; +} + +DEFUN ("canna-store-yomi", Fcanna_store_yomi, 1, 2, 0, /* +Store yomi characters as a YOMI of kana-to-kanji conversion. +*/ + (yomi, roma)) +{ + jrKanjiStatusWithValue ksv; + jrKanjiStatus ks; + + CHECK_STRING (yomi); +#ifndef CANNA_MULE + strncpy (key_buffer, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi)); + ks.length = XSTRING_LENGTH (yomi); + key_buffer[ks.length] = '\0'; +#else /* CANNA_MULE */ + m2c (XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), + (unsigned char *) key_buffer); + ks.length = strlen (key_buffer); +#endif /* CANNA_MULE */ + + if (NILP (roma)) + { + ks.mode = 0; + } + else + { + CHECK_STRING (roma); + +#ifndef CANNA_MULE + strncpy (key_buffer + XSTRING_LENGTH (yomi) + 1, XSTRING_DATA (roma), + XSTRING_LENGTH (roma)); + key_buffer[XSTRING_LENGTH (yomi) + 1 + XSTRING_LENGTH (roma)] = '\0'; + ks.mode = (unsigned char *)(key_buffer + XSTRING_LENGTH (yomi) + 1); +#else /* CANNA_MULE */ + ks.mode = (unsigned char *)(key_buffer + ks.length + 1); + m2c (XSTRING_DATA (roma), XSTRING_LENGTH (roma), + (unsigned char *) ks.mode); +#endif /* CANNA_MULE */ + } + + ks.echoStr = (unsigned char *) key_buffer; + ksv.buffer = (unsigned char *) key_buffer; /* 返値用 (return value) */ + ksv.bytes_buffer = KEYTOSTRSIZE; + ksv.ks = &ks; + + jrKanjiControl (0, KC_STOREYOMI, (char *)&ksv); + + return storeResults (key_buffer, ksv.val, ksv.ks); +} + +DEFUN ("canna-do-function", Fcanna_do_function, 1, 2, 0, /* +Do specified function at current mode. +*/ + (num, ch)) +{ + jrKanjiStatusWithValue ksv; + jrKanjiStatus ks; + + CHECK_INT (num); + + if (NILP (ch)) + { + *key_buffer = '@'; + } + else + { + CHECK_CHAR (ch); + *key_buffer = XCHAR (ch); + } + + ksv.buffer = (unsigned char *) key_buffer; + ksv.bytes_buffer = KEYTOSTRSIZE; + ksv.ks = &ks; + ksv.val = XINT (num); + jrKanjiControl (0, KC_DO, (char *) &ksv); + return storeResults (key_buffer, ksv.val, ksv.ks); +} + +DEFUN ("canna-parse", Fcanna_parse, 1, 1, 0, /* +Parse customize string. +*/ + (str)) +{ + Lisp_Object val; + unsigned char **p; + int n; + + CHECK_STRING (str); + +#ifndef CANNA_MULE + strncpy (key_buffer, XSTRING_DATA (str), XSTRING_LENGTH (str)); + key_buffer[XSTRING_LENGTH (str)] = '\0'; +#else /* CANNA_MULE */ + m2c (XSTRING_DATA (str), XSTRING_LENGTH (str), (unsigned char *) key_buffer); +#endif /* CANNA_MULE */ + p = (unsigned char**) key_buffer; + n = jrKanjiControl (0, KC_PARSE, (char *) &p); + val = Qnil; + while (n > 0) + { + n--; + val = Fcons (make_string (p[n], strlen ((const char *) p[n])), val); + } + return val; +} + +DEFUN ("canna-query-mode", Fcanna_query_mode, 0, 0, 0, /* +Get current mode string. +*/ + ()) +{ + char buf[256]; + + jrKanjiControl (0, KC_QUERYMODE, buf); + return make_string ((unsigned char *) buf, strlen (buf)); +} + +/* + * Functions following this line are for KKCP interface compatible + * library. These functions may be used by MILK system. + */ + +#define RKBUFSIZE 1024 + +static unsigned char yomibuf[RKBUFSIZE]; +static short kugiri[RKBUFSIZE / 2]; + +static int +confirmContext (void) +{ + if (IRCP_context < 0) + { + int context; + + if ((context = jrKanjiControl (0, KC_GETCONTEXT, (char *) 0)) == -1) + { + return 0; + } + IRCP_context = context; + } + return 1; +} + +static int +byteLen (int bun, int len) +{ + int i = 0, offset = 0, ch; + + if (0 <= bun && bun < RKBUFSIZE) + { + offset = kugiri[bun]; + } + + while (len-- > 0 && (ch = (int) yomibuf[offset + i])) + { + i++; + if (ch & 0x80) + { + i++; + } + } + return i; +} + +DEFUN ("canna-henkan-begin", Fcanna_henkan_begin, 1, 1, 0, /* +Return the result of kana-to-kanji conversion. +Clause separator is set. +*/ + (yomi)) +{ + int nbun; + + CHECK_STRING (yomi); + if (confirmContext () == 0) + { + return Qnil; + } +#ifndef CANNA_MULE + strncpy (yomibuf, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi)); + yomibuf[XSTRING_LENGTH (yomi)] = '\0'; + nbun = RkBgnBun (IRCP_context, XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), + (RK_XFER << RK_XFERBITS) | RK_KFER); +#else /* CANNA_MULE */ + m2c (XSTRING_DATA (yomi), XSTRING_LENGTH (yomi), yomibuf); + nbun = RkBgnBun (IRCP_context, (char *) yomibuf, + strlen ((const char *) yomibuf), + (RK_XFER << RK_XFERBITS) | RK_KFER); +#endif /* CANNA_MULE */ + + return kanjiYomiList (IRCP_context, nbun); +} + +static Lisp_Object +kanjiYomiList (int context, int nbun) +{ + Lisp_Object val, res = Qnil; + unsigned char RkBuf[RKBUFSIZE]; + int len, i, total; + + for (i = nbun ; i > 0 ; ) + { + i--; + RkGoTo (context, i); + len = RkGetKanji (context, RkBuf, RKBUFSIZE); + val = make_string (RkBuf, len); + len = RkGetYomi (context, RkBuf, RKBUFSIZE); + res = Fcons (Fcons (val, make_string (RkBuf, len)), res); + if (i < RKBUFSIZE / 2) + { + kugiri[i] = len; + } + } + for (i = 0, total = 0 ; i < nbun ; i++) + { + int temp = kugiri[i]; + kugiri[i] = total; + total += temp; + } + return res; +} + +DEFUN ("canna-henkan-next", Fcanna_henkan_next, 1, 1, 0, /* +Return the list of candidates. +*/ + (bunsetsu)) +{ + int i, slen, len; + unsigned char *p, RkBuf[RKBUFSIZE]; + Lisp_Object res = Qnil; + + CHECK_INT (bunsetsu); + if (confirmContext () == 0) + { + return Qnil; + } + RkGoTo (IRCP_context, XINT (bunsetsu)); + len = RkGetKanjiList (IRCP_context, RkBuf, RKBUFSIZE); + p = RkBuf; + for (i = 0 ; i < len ; i++) + { + slen = strlen ((const char *) p); + if (NILP(res)) + { + res = Fcons (make_string (p, slen), Qnil); + } + else + { + XCDR (res) = Fcons (make_string (p, slen), Qnil); + } + p += slen + 1; + } + return res; +} + +DEFUN ("canna-bunsetu-henkou", Fcanna_bunsetu_henkou, 2, 2, 0, /* +Specify the length of a clause. +*/ + (bunsetsu, bunlen)) +{ + int nbun, len; + + CHECK_INT (bunsetsu); + CHECK_INT (bunlen); + + nbun = XINT (bunsetsu); + if (confirmContext () == 0) + { + return Qnil; + } + RkGoTo (IRCP_context, nbun); + len = byteLen (nbun, XINT (bunlen)); + return kanjiYomiList (IRCP_context, RkResize (IRCP_context, len)); +} + +DEFUN ("canna-henkan-kakutei", Fcanna_henkan_kakutei, 2, 2, 0, /* +Select a candidate. +*/ + (bun, kouho)) +{ + int nbun, nkouho; + + if (confirmContext () == 0) + { + return Qnil; + } + nbun = XINT(bun); + RkGoTo (IRCP_context, nbun); + + nkouho = XINT(kouho); + RkXfer (IRCP_context, nkouho); + return Qt; +} + +DEFUN ("canna-henkan-end", Fcanna_henkan_end, 0, 0, 0, /* +End conversion. +*/ + ()) +{ + if (confirmContext () == 0) + { + return Qnil; + } + RkEndBun (IRCP_context, 1); /* 学習はいつでも行って良いものなのか? + (is it OK to invoke learning function + at arbitrary times?) */ + return Qt; +} + +DEFUN ("canna-henkan-quit", Fcanna_henkan_quit, 0, 0, 0, /* +Quit conversion. +*/ + ()) +{ + if (confirmContext () == 0) + { + return Qnil; + } + RkEndBun (IRCP_context, 0); + return Qt; +} + +/* variables below this line is constants of Canna */ + +static Fixnum canna_mode_AlphaMode; +static Fixnum canna_mode_EmptyMode; +static Fixnum canna_mode_KigoMode; +static Fixnum canna_mode_YomiMode; +static Fixnum canna_mode_JishuMode; +static Fixnum canna_mode_TankouhoMode; +static Fixnum canna_mode_IchiranMode; +static Fixnum canna_mode_YesNoMode; +static Fixnum canna_mode_OnOffMode; +#ifdef CANNA_MODE_AdjustBunsetsuMode +static Fixnum canna_mode_AdjustBunsetsuMode; +#endif +#ifdef CANNA_MODE_ChikujiYomiMode +static Fixnum canna_mode_ChikujiYomiMode; +static Fixnum canna_mode_ChikujiTanMode; +#endif + +static Fixnum canna_mode_HenkanMode; +#ifdef CANNA_MODE_HenkanNyuryokuMode +static Fixnum canna_mode_HenkanNyuryokuMode; +#endif +#ifdef CANNA_MODE_ZenHiraHenkanMode +static Fixnum canna_mode_ZenHiraHenkanMode; +#ifdef CANNA_MODE_HanHiraHenkanMode +static Fixnum canna_mode_HanHiraHenkanMode; +#endif +static Fixnum canna_mode_ZenKataHenkanMode; +static Fixnum canna_mode_HanKataHenkanMode; +static Fixnum canna_mode_ZenAlphaHenkanMode; +static Fixnum canna_mode_HanAlphaHenkanMode; +#endif +static Fixnum canna_mode_ZenHiraKakuteiMode; +#ifdef CANNA_MODE_HanHiraKakuteiMode +static Fixnum canna_mode_HanHiraKakuteiMode; +#endif +static Fixnum canna_mode_ZenKataKakuteiMode; +static Fixnum canna_mode_HanKataKakuteiMode; +static Fixnum canna_mode_ZenAlphaKakuteiMode; +static Fixnum canna_mode_HanAlphaKakuteiMode; +static Fixnum canna_mode_HexMode; +static Fixnum canna_mode_BushuMode; +static Fixnum canna_mode_ExtendMode; +static Fixnum canna_mode_RussianMode; +static Fixnum canna_mode_GreekMode; +static Fixnum canna_mode_LineMode; +static Fixnum canna_mode_ChangingServerMode; +static Fixnum canna_mode_HenkanMethodMode; +static Fixnum canna_mode_DeleteDicMode; +static Fixnum canna_mode_TourokuMode; +static Fixnum canna_mode_TourokuEmptyMode; +static Fixnum canna_mode_TourokuHinshiMode; +static Fixnum canna_mode_TourokuDicMode; +static Fixnum canna_mode_QuotedInsertMode; +static Fixnum canna_mode_BubunMuhenkanMode; +static Fixnum canna_mode_MountDicMode; + +static Fixnum canna_fn_SelfInsert; +static Fixnum canna_fn_FunctionalInsert; +static Fixnum canna_fn_QuotedInsert; +static Fixnum canna_fn_JapaneseMode; +static Fixnum canna_fn_AlphaMode; +static Fixnum canna_fn_HenkanNyuryokuMode; +static Fixnum canna_fn_Forward; +static Fixnum canna_fn_Backward; +static Fixnum canna_fn_Next; +static Fixnum canna_fn_Prev; +static Fixnum canna_fn_BeginningOfLine; +static Fixnum canna_fn_EndOfLine; +static Fixnum canna_fn_DeleteNext; +static Fixnum canna_fn_DeletePrevious; +static Fixnum canna_fn_KillToEndOfLine; +static Fixnum canna_fn_Henkan; +static Fixnum canna_fn_Kakutei; +static Fixnum canna_fn_Extend; +static Fixnum canna_fn_Shrink; +#ifdef CANNA_FN_AdjustBunsetsu +static Fixnum canna_fn_AdjustBunsetsu; +#endif +static Fixnum canna_fn_Quit; +static Fixnum canna_fn_ConvertAsHex; +static Fixnum canna_fn_ConvertAsBushu; +static Fixnum canna_fn_KouhoIchiran; +static Fixnum canna_fn_BubunMuhenkan; +static Fixnum canna_fn_Zenkaku; +static Fixnum canna_fn_Hankaku; +static Fixnum canna_fn_ToUpper; +static Fixnum canna_fn_Capitalize; +static Fixnum canna_fn_ToLower; +static Fixnum canna_fn_Hiragana; +static Fixnum canna_fn_Katakana; +static Fixnum canna_fn_Romaji; +#ifdef CANNA_FN_BaseHiragana +static Fixnum canna_fn_BaseHiragana; +static Fixnum canna_fn_BaseKatakana; +static Fixnum canna_fn_BaseEisu; +static Fixnum canna_fn_BaseZenkaku; +static Fixnum canna_fn_BaseHankaku; +static Fixnum canna_fn_BaseKana; +static Fixnum canna_fn_BaseKakutei; +static Fixnum canna_fn_BaseHenkan; +static Fixnum canna_fn_BaseHiraKataToggle; +static Fixnum canna_fn_BaseZenHanToggle; +static Fixnum canna_fn_BaseKanaEisuToggle; +static Fixnum canna_fn_BaseKakuteiHenkanToggle; +static Fixnum canna_fn_BaseRotateForward; +static Fixnum canna_fn_BaseRotateBackward; +#endif +static Fixnum canna_fn_ExtendMode; +static Fixnum canna_fn_Touroku; +static Fixnum canna_fn_HexMode; +static Fixnum canna_fn_BushuMode; +static Fixnum canna_fn_KigouMode; +#ifdef CANNA_FN_Mark +static Fixnum canna_fn_Mark; +#endif +#ifdef CANNA_FN_TemporalMode +static Fixnum canna_fn_TemporalMode; +#endif + +static Fixnum canna_key_Nfer; +static Fixnum canna_key_Xfer; +static Fixnum canna_key_Up; +static Fixnum canna_key_Left; +static Fixnum canna_key_Right; +static Fixnum canna_key_Down; +static Fixnum canna_key_Insert; +static Fixnum canna_key_Rollup; +static Fixnum canna_key_Rolldown; +static Fixnum canna_key_Home; +static Fixnum canna_key_Help; +static Fixnum canna_key_KP_Key; +static Fixnum canna_key_Shift_Nfer; +static Fixnum canna_key_Shift_Xfer; +static Fixnum canna_key_Shift_Up; +static Fixnum canna_key_Shift_Left; +static Fixnum canna_key_Shift_Right; +static Fixnum canna_key_Shift_Down; +static Fixnum canna_key_Cntrl_Nfer; +static Fixnum canna_key_Cntrl_Xfer; +static Fixnum canna_key_Cntrl_Up; +static Fixnum canna_key_Cntrl_Left; +static Fixnum canna_key_Cntrl_Right; +static Fixnum canna_key_Cntrl_Down; + +Lisp_Object VCANNA; /* by MORIOKA Tomohiko <morioka@jaist.ac.jp> + 1996/6/7 */ + +/* + * Each dynamically loaded Emacs module is given a name at compile + * time. This is a short name, and must be a valid part of a C + * identifier. This name is used to construct the name of several + * functions which must appear in the module source code. + * The first such function, modules_of_XXXX, should load in any dependent + * modules. This function is optional, and the module will still load if + * it is not present in the module. + * + * The second function, which is NOT optional, is syms_of_XXXX, in which + * all functions that the module will be provided are declared. This + * function will contain calls to DEFSUBR(). + * + * The third function, which is also NOT optional, is vars_of_XXXX, in + * which you declare all variables that the module provides. This + * function will contain calls to DEFVAR_LISP(), DEFVAR_BOOL() etc. + * + * When declaring functions and variables in the syms_of_XXXX and + * vars_of_XXXX functions, you use the exact same syntax that you + * would as if this module were being compiled into the pure Emacs. + * + * The fourth function, which is optional, is unload_XXXX, in which actions + * that must be taken to unload the module are listed. XEmacs will unbind + * functions and variables for you. Anything else that must be done should + * appear in this function. + * + * All four of these functions are declared as void functions, + * taking no parameters. Since this sample module is called 'sample', + * the functions will be named 'modules_of_sample', 'syms_of_sample', + * 'vars_of_sample', and 'unload_sample'. + */ + +#if 0 +void +modules_of_canna_api (void) +{ + /* + * This function isn't actually required as we will not be loading + * in any dependent modules, but if we were, we would do something like: + * emodules_load ("dependent.ell", "canna2", "1.0.0"); + */ +} +#endif + +void +syms_of_canna_api (void) +{ + DEFSUBR (Fcanna_key_proc); + DEFSUBR (Fcanna_initialize); + DEFSUBR (Fcanna_finalize); + DEFSUBR (Fcanna_touroku_string); + DEFSUBR (Fcanna_set_width); + DEFSUBR (Fcanna_change_mode); + DEFSUBR (Fcanna_store_yomi); + DEFSUBR (Fcanna_do_function); + DEFSUBR (Fcanna_parse); + DEFSUBR (Fcanna_query_mode); + DEFSUBR (Fcanna_set_bunsetsu); + + DEFSUBR (Fcanna_henkan_begin); + DEFSUBR (Fcanna_henkan_next); + DEFSUBR (Fcanna_bunsetu_henkou); + DEFSUBR (Fcanna_henkan_kakutei); + DEFSUBR (Fcanna_henkan_end); + DEFSUBR (Fcanna_henkan_quit); +} + +void +vars_of_canna_api (void) +{ + DEFVAR_LISP ("CANNA", &VCANNA); /* hir@nec, 1992.5.21 */ + VCANNA = Qt; /* hir@nec, 1992.5.21 */ + + DEFVAR_LISP ("canna-kakutei-string", &Vcanna_kakutei_string /* + +*/ ); + Vcanna_kakutei_string = Qnil; + + DEFVAR_LISP ("canna-kakutei-yomi", &Vcanna_kakutei_yomi /* + +*/ ); + Vcanna_kakutei_yomi = Qnil; + + DEFVAR_LISP ("canna-kakutei-romaji", &Vcanna_kakutei_romaji /* + +*/ ); + Vcanna_kakutei_romaji = Qnil; + + DEFVAR_LISP ("canna-henkan-string", &Vcanna_henkan_string /* + +*/ ); + Vcanna_henkan_string = Qnil; + + DEFVAR_INT ("canna-henkan-length", &canna_henkan_length /* + +*/ ); + canna_henkan_length = 0; + + DEFVAR_INT ("canna-henkan-revpos", &canna_henkan_revPos /* + +*/ ); + canna_henkan_revPos = 0; + + DEFVAR_INT ("canna-henkan-revlen", &canna_henkan_revLen /* + +*/ ); + canna_henkan_revLen = 0; + + DEFVAR_LISP ("canna-ichiran-string", &Vcanna_ichiran_string /* + +*/ ); + Vcanna_ichiran_string = Qnil; + + DEFVAR_INT ("canna-ichiran-length", &canna_ichiran_length /* + +*/ ); + canna_ichiran_length = 0; + + DEFVAR_INT ("canna-ichiran-revpos", &canna_ichiran_revPos /* + +*/ ); + canna_ichiran_revPos = 0; + + DEFVAR_INT ("canna-ichiran-revlen", &canna_ichiran_revLen /* + +*/ ); + canna_ichiran_revLen = 0; + + DEFVAR_LISP ("canna-mode-string", &Vcanna_mode_string /* + +*/ ); + Vcanna_mode_string = Qnil; + + DEFVAR_BOOL ("canna-empty-info", &canna_empty_info /* +For canna +*/ ); + canna_empty_info = 0; + + DEFVAR_BOOL ("canna-through-info", &canna_through_info /* +For canna +*/ ); + canna_through_info = 0; + + DEFVAR_BOOL ("canna-underline", &canna_underline /* +For canna +*/ ); + canna_underline = 0; + + DEFVAR_BOOL ("canna-inhibit-hankakukana", &canna_inhibit_hankakukana /* +For canna +*/ ); + canna_inhibit_hankakukana = 0; + + DEFVAR_INT ("canna-mode-alpha-mode", &canna_mode_AlphaMode /* + +*/ ); + canna_mode_AlphaMode = IROHA_MODE_AlphaMode; + + DEFVAR_INT ("canna-mode-empty-mode", &canna_mode_EmptyMode /* + +*/ ); + canna_mode_EmptyMode = IROHA_MODE_EmptyMode; + + DEFVAR_INT ("canna-mode-kigo-mode", &canna_mode_KigoMode /* + +*/ ); + canna_mode_KigoMode = IROHA_MODE_KigoMode; + + DEFVAR_INT ("canna-mode-yomi-mode", &canna_mode_YomiMode /* + +*/ ); + canna_mode_YomiMode = IROHA_MODE_YomiMode; + + DEFVAR_INT ("canna-mode-jishu-mode", &canna_mode_JishuMode /* + +*/ ); + canna_mode_JishuMode = IROHA_MODE_JishuMode; + + DEFVAR_INT ("canna-mode-tankouho-mode", &canna_mode_TankouhoMode /* + +*/ ); + canna_mode_TankouhoMode = IROHA_MODE_TankouhoMode; + + DEFVAR_INT ("canna-mode-ichiran-mode", &canna_mode_IchiranMode /* + +*/ ); + canna_mode_IchiranMode = IROHA_MODE_IchiranMode; + + DEFVAR_INT ("canna-mode-yes-no-mode", &canna_mode_YesNoMode /* + +*/ ); + canna_mode_YesNoMode = IROHA_MODE_YesNoMode; + + DEFVAR_INT ("canna-mode-on-off-mode", &canna_mode_OnOffMode /* + +*/ ); + canna_mode_OnOffMode = IROHA_MODE_OnOffMode; + +#ifdef CANNA_MODE_AdjustBunsetsuMode + DEFVAR_INT ("canna-mode-adjust-bunsetsu-mode", + &canna_mode_AdjustBunsetsuMode /* + +*/ ); + canna_mode_AdjustBunsetsuMode = CANNA_MODE_AdjustBunsetsuMode; +#endif +#ifdef CANNA_MODE_ChikujiYomiMode + DEFVAR_INT ("canna-mode-chikuji-yomi-mode", &canna_mode_ChikujiYomiMode /* + +*/ ); + canna_mode_ChikujiYomiMode = CANNA_MODE_ChikujiYomiMode; + + DEFVAR_INT ("canna-mode-chikuji-bunsetsu-mode", + &canna_mode_ChikujiTanMode /* + +*/ ); + canna_mode_ChikujiTanMode = CANNA_MODE_ChikujiTanMode; +#endif + + DEFVAR_INT ("canna-mode-henkan-mode", &canna_mode_HenkanMode /* + +*/ ); + canna_mode_HenkanMode = IROHA_MODE_HenkanMode; + +#ifdef CANNA_MODE_HenkanNyuryokuMode + DEFVAR_INT ("canna-mode-henkan-nyuuryoku-mode", + &canna_mode_HenkanNyuryokuMode /* + +*/ ); + canna_mode_HenkanNyuryokuMode = CANNA_MODE_HenkanNyuryokuMode; +#endif +#ifdef CANNA_MODE_ZenHiraHenkanMode + DEFVAR_INT ("canna-mode-zen-hira-henkan-mode", + &canna_mode_ZenHiraHenkanMode /* + +*/ ); + canna_mode_ZenHiraHenkanMode = CANNA_MODE_ZenHiraHenkanMode; +#ifdef CANNA_MODE_HanHiraHenkanMode + DEFVAR_INT ("canna-mode-han-hira-henkan-mode", + &canna_mode_HanHiraHenkanMode /* + +*/ ); + canna_mode_HanHiraHenkanMode = CANNA_MODE_HanHiraHenkanMode; +#endif + DEFVAR_INT ("canna-mode-zen-kata-henkan-mode", + &canna_mode_ZenKataHenkanMode /* + +*/ ); + canna_mode_ZenKataHenkanMode = CANNA_MODE_ZenKataHenkanMode; + + DEFVAR_INT ("canna-mode-han-kata-henkan-mode", + &canna_mode_HanKataHenkanMode /* + +*/ ); + canna_mode_HanKataHenkanMode = CANNA_MODE_HanKataHenkanMode; + + DEFVAR_INT ("canna-mode-zen-alpha-henkan-mode", + &canna_mode_ZenAlphaHenkanMode /* + +*/ ); + canna_mode_ZenAlphaHenkanMode = CANNA_MODE_ZenAlphaHenkanMode; + + DEFVAR_INT ("canna-mode-han-alpha-henkan-mode", + &canna_mode_HanAlphaHenkanMode /* + +*/ ); + canna_mode_HanAlphaHenkanMode = CANNA_MODE_HanAlphaHenkanMode; +#endif + DEFVAR_INT ("canna-mode-zen-hira-kakutei-mode", + &canna_mode_ZenHiraKakuteiMode /* + +*/ ); + canna_mode_ZenHiraKakuteiMode = IROHA_MODE_ZenHiraKakuteiMode; +#ifdef CANNA_MODE_HanHiraKakuteiMode + DEFVAR_INT ("canna-mode-han-hira-kakutei-mode", + &canna_mode_HanHiraKakuteiMode /* + +*/ ); + canna_mode_HanHiraKakuteiMode = CANNA_MODE_HanHiraKakuteiMode; +#endif + DEFVAR_INT ("canna-mode-zen-kata-kakutei-mode", + &canna_mode_ZenKataKakuteiMode /* + +*/ ); + canna_mode_ZenKataKakuteiMode = IROHA_MODE_ZenKataKakuteiMode; + + DEFVAR_INT ("canna-mode-han-kata-kakutei-mode", + &canna_mode_HanKataKakuteiMode /* + +*/ ); + canna_mode_HanKataKakuteiMode = IROHA_MODE_HanKataKakuteiMode; + + DEFVAR_INT ("canna-mode-zen-alpha-kakutei-mode", + &canna_mode_ZenAlphaKakuteiMode /* + +*/ ); + canna_mode_ZenAlphaKakuteiMode = IROHA_MODE_ZenAlphaKakuteiMode; + + DEFVAR_INT ("canna-mode-han-alpha-kakutei-mode", + &canna_mode_HanAlphaKakuteiMode /* + +*/ ); + canna_mode_HanAlphaKakuteiMode = IROHA_MODE_HanAlphaKakuteiMode; + + DEFVAR_INT ("canna-mode-hex-mode", &canna_mode_HexMode /* + +*/ ); + canna_mode_HexMode = IROHA_MODE_HexMode; + + DEFVAR_INT ("canna-mode-bushu-mode", &canna_mode_BushuMode /* + +*/ ); + canna_mode_BushuMode = IROHA_MODE_BushuMode; + + DEFVAR_INT ("canna-mode-extend-mode", &canna_mode_ExtendMode /* + +*/ ); + canna_mode_ExtendMode = IROHA_MODE_ExtendMode; + + DEFVAR_INT ("canna-mode-russian-mode", &canna_mode_RussianMode /* + +*/ ); + canna_mode_RussianMode = IROHA_MODE_RussianMode; + + DEFVAR_INT ("canna-mode-greek-mode", &canna_mode_GreekMode /* + +*/ ); + canna_mode_GreekMode = IROHA_MODE_GreekMode; + + DEFVAR_INT ("canna-mode-line-mode", &canna_mode_LineMode /* + +*/ ); + canna_mode_LineMode = IROHA_MODE_LineMode; + + DEFVAR_INT ("canna-mode-changing-server-mode", + &canna_mode_ChangingServerMode /* + +*/ ); + canna_mode_ChangingServerMode = IROHA_MODE_ChangingServerMode; + + DEFVAR_INT ("canna-mode-henkan-method-mode", + &canna_mode_HenkanMethodMode /* + +*/ ); + canna_mode_HenkanMethodMode = IROHA_MODE_HenkanMethodMode; + + DEFVAR_INT ("canna-mode-delete-dic-mode", &canna_mode_DeleteDicMode /* + +*/ ); + canna_mode_DeleteDicMode = IROHA_MODE_DeleteDicMode; + + DEFVAR_INT ("canna-mode-touroku-mode", &canna_mode_TourokuMode /* + +*/ ); + canna_mode_TourokuMode = IROHA_MODE_TourokuMode; + + DEFVAR_INT ("canna-mode-touroku-empty-mode", + &canna_mode_TourokuEmptyMode /* + +*/ ); + canna_mode_TourokuEmptyMode = IROHA_MODE_TourokuEmptyMode; + + DEFVAR_INT ("canna-mode-touroku-hinshi-mode", + &canna_mode_TourokuHinshiMode /* + +*/ ); + canna_mode_TourokuHinshiMode = IROHA_MODE_TourokuHinshiMode; + + DEFVAR_INT ("canna-mode-touroku-dic-mode", &canna_mode_TourokuDicMode /* + +*/ ); + canna_mode_TourokuDicMode = IROHA_MODE_TourokuDicMode; + + DEFVAR_INT ("canna-mode-quoted-insert-mode", + &canna_mode_QuotedInsertMode /* + +*/ ); + canna_mode_QuotedInsertMode = IROHA_MODE_QuotedInsertMode; + + DEFVAR_INT ("canna-mode-bubun-muhenkan-mode", + &canna_mode_BubunMuhenkanMode /* + +*/ ); + canna_mode_BubunMuhenkanMode = IROHA_MODE_BubunMuhenkanMode; + + DEFVAR_INT ("canna-mode-mount-dic-mode", &canna_mode_MountDicMode /* + +*/ ); + canna_mode_MountDicMode = IROHA_MODE_MountDicMode; + + DEFVAR_INT ("canna-func-self-insert", &canna_fn_SelfInsert /* + +*/ ); + canna_fn_SelfInsert = IROHA_FN_SelfInsert; + + DEFVAR_INT ("canna-func-functional-insert", &canna_fn_FunctionalInsert /* + +*/ ); + canna_fn_FunctionalInsert = IROHA_FN_FunctionalInsert; + + DEFVAR_INT ("canna-func-quoted-insert", &canna_fn_QuotedInsert /* + +*/ ); + canna_fn_QuotedInsert = IROHA_FN_QuotedInsert; + + DEFVAR_INT ("canna-func-japanese-mode", &canna_fn_JapaneseMode /* + +*/ ); + canna_fn_JapaneseMode = IROHA_FN_JapaneseMode; + + DEFVAR_INT ("canna-func-alpha-mode", &canna_fn_AlphaMode /* + +*/ ); + canna_fn_AlphaMode = IROHA_FN_AlphaMode; + + DEFVAR_INT ("canna-func-henkan-nyuryoku-mode", + &canna_fn_HenkanNyuryokuMode /* + +*/ ); + canna_fn_HenkanNyuryokuMode = IROHA_FN_HenkanNyuryokuMode; + + DEFVAR_INT ("canna-func-forward", &canna_fn_Forward /* + +*/ ); + canna_fn_Forward = IROHA_FN_Forward; + + DEFVAR_INT ("canna-func-backward", &canna_fn_Backward /* + +*/ ); + canna_fn_Backward = IROHA_FN_Backward; + + DEFVAR_INT ("canna-func-next", &canna_fn_Next /* + +*/ ); + canna_fn_Next = IROHA_FN_Next; + + DEFVAR_INT ("canna-func-previous", &canna_fn_Prev /* + +*/ ); + canna_fn_Prev = IROHA_FN_Prev; + + DEFVAR_INT ("canna-func-beginning-of-line", &canna_fn_BeginningOfLine /* + +*/ ); + canna_fn_BeginningOfLine = IROHA_FN_BeginningOfLine; + + DEFVAR_INT ("canna-func-end-of-line", &canna_fn_EndOfLine /* + +*/ ); + canna_fn_EndOfLine = IROHA_FN_EndOfLine; + + DEFVAR_INT ("canna-func-delete-next", &canna_fn_DeleteNext /* + +*/ ); + canna_fn_DeleteNext = IROHA_FN_DeleteNext; + + DEFVAR_INT ("canna-func-delete-previous", &canna_fn_DeletePrevious /* + +*/ ); + canna_fn_DeletePrevious = IROHA_FN_DeletePrevious; + + DEFVAR_INT ("canna-func-kill-to-end-of-line", &canna_fn_KillToEndOfLine /* + +*/ ); + canna_fn_KillToEndOfLine = IROHA_FN_KillToEndOfLine; + + DEFVAR_INT ("canna-func-henkan", &canna_fn_Henkan /* + +*/ ); + canna_fn_Henkan = IROHA_FN_Henkan; + + DEFVAR_INT ("canna-func-kakutei", &canna_fn_Kakutei /* + +*/ ); + canna_fn_Kakutei = IROHA_FN_Kakutei; + + DEFVAR_INT ("canna-func-extend", &canna_fn_Extend /* + +*/ ); + canna_fn_Extend = IROHA_FN_Extend; + + DEFVAR_INT ("canna-func-shrink", &canna_fn_Shrink /* + +*/ ); + canna_fn_Shrink = IROHA_FN_Shrink; + +#ifdef CANNA_FN_AdjustBunsetsu + DEFVAR_INT ("canna-func-adjust-bunsetsu", &canna_fn_AdjustBunsetsu /* + +*/ ); + canna_fn_AdjustBunsetsu = CANNA_FN_AdjustBunsetsu; +#endif + DEFVAR_INT ("canna-func-quit", &canna_fn_Quit /* + +*/ ); + canna_fn_Quit = IROHA_FN_Quit; + + DEFVAR_INT ("canna-func-convert-as-hex", &canna_fn_ConvertAsHex /* + +*/ ); + canna_fn_ConvertAsHex = IROHA_FN_ConvertAsHex; + + DEFVAR_INT ("canna-func-convert-as-bushu", &canna_fn_ConvertAsBushu /* + +*/ ); + canna_fn_ConvertAsBushu = IROHA_FN_ConvertAsBushu; + + DEFVAR_INT ("canna-func-kouho-ichiran", &canna_fn_KouhoIchiran /* + +*/ ); + canna_fn_KouhoIchiran = IROHA_FN_KouhoIchiran; + + DEFVAR_INT ("canna-func-bubun-muhenkan", &canna_fn_BubunMuhenkan /* + +*/ ); + canna_fn_BubunMuhenkan = IROHA_FN_BubunMuhenkan; + + DEFVAR_INT ("canna-func-zenkaku", &canna_fn_Zenkaku /* + +*/ ); + canna_fn_Zenkaku = IROHA_FN_Zenkaku; + + DEFVAR_INT ("canna-func-hankaku", &canna_fn_Hankaku /* + +*/ ); + canna_fn_Hankaku = IROHA_FN_Hankaku; + + DEFVAR_INT ("canna-func-to-upper", &canna_fn_ToUpper /* + +*/ ); + canna_fn_ToUpper = IROHA_FN_ToUpper; + + DEFVAR_INT ("canna-func-capitalize", &canna_fn_Capitalize /* + +*/ ); + canna_fn_Capitalize = IROHA_FN_Capitalize; + + DEFVAR_INT ("canna-func-to-lower", &canna_fn_ToLower /* + +*/ ); + canna_fn_ToLower = IROHA_FN_ToLower; + + DEFVAR_INT ("canna-func-hiragana", &canna_fn_Hiragana /* + +*/ ); + canna_fn_Hiragana = IROHA_FN_Hiragana; + + DEFVAR_INT ("canna-func-katakana", &canna_fn_Katakana /* + +*/ ); + canna_fn_Katakana = IROHA_FN_Katakana; + + DEFVAR_INT ("canna-func-romaji", &canna_fn_Romaji /* + +*/ ); + canna_fn_Romaji = IROHA_FN_Romaji; + +#ifdef CANNA_FN_BaseHiragana + DEFVAR_INT ("canna-func-base-hiragana", &canna_fn_BaseHiragana /* + +*/ ); + canna_fn_BaseHiragana = CANNA_FN_BaseHiragana; + + DEFVAR_INT ("canna-func-base-katakana", &canna_fn_BaseKatakana /* + +*/ ); + canna_fn_BaseKatakana = CANNA_FN_BaseKatakana; + + DEFVAR_INT ("canna-func-base-eisu", &canna_fn_BaseEisu /* + +*/ ); + canna_fn_BaseEisu = CANNA_FN_BaseEisu; + + DEFVAR_INT ("canna-func-base-zenkaku", &canna_fn_BaseZenkaku /* + +*/ ); + canna_fn_BaseZenkaku = CANNA_FN_BaseZenkaku; + + DEFVAR_INT ("canna-func-base-hankaku", &canna_fn_BaseHankaku /* + +*/ ); + canna_fn_BaseHankaku = CANNA_FN_BaseHankaku; + + DEFVAR_INT ("canna-func-base-kana", &canna_fn_BaseKana /* + +*/ ); + canna_fn_BaseKana = CANNA_FN_BaseKana; + + DEFVAR_INT ("canna-func-base-kakutei", &canna_fn_BaseKakutei /* + +*/ ); + canna_fn_BaseKakutei = CANNA_FN_BaseKakutei; + + DEFVAR_INT ("canna-func-base-henkan", &canna_fn_BaseHenkan /* + +*/ ); + canna_fn_BaseHenkan = CANNA_FN_BaseHenkan; + + DEFVAR_INT ("canna-func-base-hiragana-katakana-toggle", + &canna_fn_BaseHiraKataToggle /* + +*/ ); + canna_fn_BaseHiraKataToggle = CANNA_FN_BaseHiraKataToggle; + + DEFVAR_INT ("canna-func-base-zenkaku-hankaku-toggle", + &canna_fn_BaseZenHanToggle /* + +*/ ); + canna_fn_BaseZenHanToggle = CANNA_FN_BaseZenHanToggle; + + DEFVAR_INT ("canna-func-base-kana-eisu-toggle", + &canna_fn_BaseKanaEisuToggle /* + +*/ ); + canna_fn_BaseKanaEisuToggle = CANNA_FN_BaseKanaEisuToggle; + + DEFVAR_INT ("canna-func-base-kakutei-henkan-toggle", + &canna_fn_BaseKakuteiHenkanToggle /* + +*/ ); + canna_fn_BaseKakuteiHenkanToggle = CANNA_FN_BaseKakuteiHenkanToggle; + + DEFVAR_INT ("canna-func-base-rotate-forward", + &canna_fn_BaseRotateForward /* + +*/ ); + canna_fn_BaseRotateForward = CANNA_FN_BaseRotateForward; + + DEFVAR_INT ("canna-func-base-rotate-backward", + &canna_fn_BaseRotateBackward /* + +*/ ); + canna_fn_BaseRotateBackward = CANNA_FN_BaseRotateBackward; + +#endif + DEFVAR_INT ("canna-func-extend-mode", &canna_fn_ExtendMode /* + +*/ ); + canna_fn_ExtendMode = IROHA_FN_ExtendMode; + + DEFVAR_INT ("canna-func-touroku", &canna_fn_Touroku /* + +*/ ); + canna_fn_Touroku = IROHA_FN_Touroku; + + DEFVAR_INT ("canna-func-hex-mode", &canna_fn_HexMode /* + +*/ ); + canna_fn_HexMode = IROHA_FN_HexMode; + + DEFVAR_INT ("canna-func-bushu-mode", &canna_fn_BushuMode /* + +*/ ); + canna_fn_BushuMode = IROHA_FN_BushuMode; + + DEFVAR_INT ("canna-func-kigo-mode", &canna_fn_KigouMode /* + +*/ ); + canna_fn_KigouMode = IROHA_FN_KigouMode; + +#ifdef CANNA_FN_Mark + DEFVAR_INT ("canna-func-mark", &canna_fn_Mark /* + +*/ ); + canna_fn_Mark = CANNA_FN_Mark; +#endif +#ifdef CANNA_FN_TemporalMode + DEFVAR_INT ("canna-func-temporal-mode", &canna_fn_TemporalMode /* + +*/ ); + canna_fn_TemporalMode = CANNA_FN_TemporalMode; +#endif + + DEFVAR_INT ("canna-key-nfer", &canna_key_Nfer /* + +*/ ); + canna_key_Nfer = IROHA_KEY_Nfer; + + DEFVAR_INT ("canna-key-xfer", &canna_key_Xfer /* + +*/ ); + canna_key_Xfer = IROHA_KEY_Xfer; + + DEFVAR_INT ("canna-key-up", &canna_key_Up /* + +*/ ); + canna_key_Up = IROHA_KEY_Up; + + DEFVAR_INT ("canna-key-left", &canna_key_Left /* + +*/ ); + canna_key_Left = IROHA_KEY_Left; + + DEFVAR_INT ("canna-key-right", &canna_key_Right /* + +*/ ); + canna_key_Right = IROHA_KEY_Right; + + DEFVAR_INT ("canna-key-down", &canna_key_Down /* + +*/ ); + canna_key_Down = IROHA_KEY_Down; + + DEFVAR_INT ("canna-key-insert", &canna_key_Insert /* + +*/ ); + canna_key_Insert = IROHA_KEY_Insert; + + DEFVAR_INT ("canna-key-rollup", &canna_key_Rollup /* + +*/ ); + canna_key_Rollup = IROHA_KEY_Rollup; + + DEFVAR_INT ("canna-key-rolldown", &canna_key_Rolldown /* + +*/ ); + canna_key_Rolldown = IROHA_KEY_Rolldown; + + DEFVAR_INT ("canna-key-home", &canna_key_Home /* + +*/ ); + canna_key_Home = IROHA_KEY_Home; + + DEFVAR_INT ("canna-key-help", &canna_key_Help /* + +*/ ); + canna_key_Help = IROHA_KEY_Help; + + DEFVAR_INT ("canna-key-kp-key", &canna_key_KP_Key /* + +*/ ); + canna_key_KP_Key = IROHA_KEY_KP_Key; + + DEFVAR_INT ("canna-key-shift-nfer", &canna_key_Shift_Nfer /* + +*/ ); + canna_key_Shift_Nfer = IROHA_KEY_Shift_Nfer; + + DEFVAR_INT ("canna-key-shift-xfer", &canna_key_Shift_Xfer /* + +*/ ); + canna_key_Shift_Xfer = IROHA_KEY_Shift_Xfer; + + DEFVAR_INT ("canna-key-shift-up", &canna_key_Shift_Up /* + +*/ ); + canna_key_Shift_Up = IROHA_KEY_Shift_Up; + + DEFVAR_INT ("canna-key-shift-left", &canna_key_Shift_Left /* + +*/ ); + canna_key_Shift_Left = IROHA_KEY_Shift_Left; + + DEFVAR_INT ("canna-key-shift-right", &canna_key_Shift_Right /* + +*/ ); + canna_key_Shift_Right = IROHA_KEY_Shift_Right; + + DEFVAR_INT ("canna-key-shift-down", &canna_key_Shift_Down /* + +*/ ); + canna_key_Shift_Down = IROHA_KEY_Shift_Down; + + DEFVAR_INT ("canna-key-control-nfer", &canna_key_Cntrl_Nfer /* + +*/ ); + canna_key_Cntrl_Nfer = IROHA_KEY_Cntrl_Nfer; + + DEFVAR_INT ("canna-key-control-xfer", &canna_key_Cntrl_Xfer /* + +*/ ); + canna_key_Cntrl_Xfer = IROHA_KEY_Cntrl_Xfer; + + DEFVAR_INT ("canna-key-control-up", &canna_key_Cntrl_Up /* + +*/ ); + canna_key_Cntrl_Up = IROHA_KEY_Cntrl_Up; + + DEFVAR_INT ("canna-key-control-left", &canna_key_Cntrl_Left /* + +*/ ); + canna_key_Cntrl_Left = IROHA_KEY_Cntrl_Left; + + DEFVAR_INT ("canna-key-control-right", &canna_key_Cntrl_Right /* + +*/ ); + canna_key_Cntrl_Right = IROHA_KEY_Cntrl_Right; + + DEFVAR_INT ("canna-key-control-down", &canna_key_Cntrl_Down /* + +*/ ); + canna_key_Cntrl_Down = IROHA_KEY_Cntrl_Down; + + Fprovide (intern ("CANNA")); +} + +#if 0 +#ifdef HAVE_SHLIB +void unload_canna_api (void); +void +unload_canna_api (void) +{ + /* We don't need to do anything here in the sample case. However, if you + create any new types with INIT_LRECORD_IMPLEMENTATION (sample_type), then + UNDEF_LRECORD_IMPLEMENTATION (sample_type) must appear here. Also, any + symbols declared with DEFSYMBOL (Qsample_var), or one of its variants, + must have a corresponding unstaticpro_nodump (&Qsample_var) here. */ +} +#endif +#endif + +#ifdef CANNA_MULE +/* To handle MULE internal code and EUC. + I assume CANNA can handle only Japanese EUC. */ + +/* EUC multibyte string to MULE internal string */ + +static void +c2mu (unsigned char *cp, int l, unsigned char *mp) +{ + unsigned char ch, *ep = cp+l; + + while ((cp < ep) && (ch = *cp)) + { + if ((unsigned char) ch == ISO_CODE_SS2) + { + *mp++ = LEADING_BYTE_KATAKANA_JISX0201; + cp++; + } + else if ((unsigned char) ch == ISO_CODE_SS3) + { + *mp++ = LEADING_BYTE_JAPANESE_JISX0212; + cp++; + *mp++ = *cp++; + } + else if (ch & 0x80) + { + *mp++ = LEADING_BYTE_JAPANESE_JISX0208; + *mp++ = *cp++; + } + *mp++ = *cp++; + } + *mp = 0; +} + +/* MULE internal string to EUC multibyte string */ + +static void +m2c (unsigned char *mp, int l, unsigned char *cp) +{ + unsigned char ch, *ep = mp + l; + + while ((mp < ep) && (ch = *mp++)) + { + switch (ch) + { + case LEADING_BYTE_KATAKANA_JISX0201: + *cp++ = ISO_CODE_SS2; + *cp++ = *mp++; + break; + case LEADING_BYTE_JAPANESE_JISX0212: + *cp++ = ISO_CODE_SS3; + case LEADING_BYTE_JAPANESE_JISX0208: + *cp++ = *mp++; + *cp++ = *mp++; + break; + default: + *cp++ = ch; + break; + } + } + *cp = 0; +} + +#undef make_string + +/* make_string after converting EUC string to MULE internal string */ +static Lisp_Object +mule_make_string (unsigned char *p, int l) +{ + unsigned char cbuf[4096]; + + c2mu (p,l,cbuf); + return (make_string (cbuf, strlen ((const char *) cbuf))); +} + +/* return the MULE internal string length of EUC string */ +/* Modified by sb to return a character count not byte count. */ +static int +mule_strlen (unsigned char *p, int l) +{ + unsigned char ch, *cp = p; + int len = 0; + + while ((cp < p + l) && (ch = *cp)) + { + if ((unsigned char) ch == ISO_CODE_SS2) + { + len++; + cp += 2; + } + else if ((unsigned char) ch == ISO_CODE_SS3) + { + len++; + cp += 3; + } + else if (ch & 0x80) + { + len++; + cp += 2; + } + else + { + len++; + cp++; + } + } + return (len); +} + +/* count number of characters */ +static void +count_char (unsigned char *p, int len, int pos, int rev, + Fixnum *clen, Fixnum *cpos, Fixnum *crev) +{ + unsigned char *q = p; + + *clen = *cpos = *crev = 0; + if (len == 0) return; + while (q < p + pos) + { + (*clen)++; + (*cpos)++; + if (*q++ & 0x80) q++; + } + while (q < p + pos + rev) + { + (*clen)++; + (*crev)++; + if (*q++ & 0x80) q++; + } + while (q < p + len) + { + (*clen)++; + if (*q++ & 0x80) q++; + } +} +#endif /* CANNA_MULE */
--- a/modules/canna/configure.ac Fri Oct 21 14:08:15 2005 +0000 +++ b/modules/canna/configure.ac Fri Oct 21 15:48:42 2005 +0000 @@ -2,7 +2,7 @@ # This is only used for independent module building. AC_INIT([Sample module], [1.0], [xemacs-beta@xemacs.org]) AC_PREREQ(2.53) -AC_REVISION($Revision: 1.2 $) +AC_REVISION($Revision: 1.3 $) AC_COPYRIGHT([Configuration script for the sample module. Copyright (C) 2002 Jerry James.
--- a/src/ChangeLog Fri Oct 21 14:08:15 2005 +0000 +++ b/src/ChangeLog Fri Oct 21 15:48:42 2005 +0000 @@ -1,3 +1,7 @@ +2005-10-21 Stephen J. Turnbull <stephen@xemacs.org> + + * Makefile.in.in (mule_canna_objs): Revert canna-api to canna_api. + 2005-10-13 Ben Wing <ben@xemacs.org> * config.h.in:
--- a/src/Makefile.in.in Fri Oct 21 14:08:15 2005 +0000 +++ b/src/Makefile.in.in Fri Oct 21 15:48:42 2005 +0000 @@ -197,7 +197,7 @@ #endif #if defined(HAVE_CANNA) && !defined(HAVE_SHLIB) -mule_canna_objs=$(BLDMODULES)/canna/canna-api.o +mule_canna_objs=$(BLDMODULES)/canna/canna_api.o #endif #ifdef HAVE_WNN