Mercurial > freewnn
view Wnn/jlib.V3/jlv3.c @ 20:c4b8c1d2b943
added supplement.u and ldic.u
author | Yoshiki Yazawa <yaz@cc.rim.or.jp> |
---|---|
date | Tue, 15 Apr 2008 17:26:32 +0900 |
parents | bbc77ca4def5 |
children | 466fe6732d8d |
line wrap: on
line source
/* * $Id: jlv3.c,v 1.9 2002/07/14 04:26:57 hiroo Exp $ */ /* * FreeWnn is a network-extensible Kana-to-Kanji conversion system. * This file is part of FreeWnn. * * Copyright Kyoto University Research Institute for Mathematical Sciences * 1987, 1988, 1989, 1990, 1991, 1992 * Copyright OMRON Corporation. 1987, 1988, 1989, 1990, 1991, 1992, 1999 * Copyright ASTEC, Inc. 1987, 1988, 1989, 1990, 1991, 1992 * Copyright FreeWnn Project 1999, 2000, 2002 * * Maintainer: FreeWnn Project <freewnn@tomo.gr.jp> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ /* Nihongo Henkan Library */ /* entry functions jd_open jd_open_in jd_close jd_begin jd_end jd_next jd_reconv jd_tanconv jd_udp jd_udchg jd_freqsv jd_dicadd jd_dicdel jd_dicinfo jd_wdel jd_wsch jd_wreg jd_setevf jd_getevf jd_dicstatus jd_whdel jd_mkdir jd_access jd_who jd_version extern Variables int wnn_errorno; */ #ifdef HAVE_CONFIG_H # include <config.h> #endif #include <stdio.h> #include <ctype.h> #if STDC_HEADERS # include <stdlib.h> # include <string.h> #else # if HAVE_MALLOC_H # include <malloc.h> # endif # if HAVE_STRINGS_H # include <strings.h> # endif #endif /* STDC_HEADERS */ #if HAVE_FCNTL_H # include <fcntl.h> #endif #include <pwd.h> #if HAVE_UNISTD_H # include <unistd.h> #endif #include <sys/types.h> #include "jllib.h" #include "jlib.h" #include "wnnerror.h" #include "wnn_string.h" #include "wnn_os.h" /* These are used to convert w_char and char strings */ static w_char wchartmp[256]; static char chartmp[256]; static struct wnn_buf *buf; /* "jd_server_dead_env" は、使う必要が、ありません。 互換性のためだけにあります。 V4 では、サーバーが死んでも、ちゃんとエラーリターンします。 */ jmp_buf jd_server_dead_env; int jd_server_dead_env_flg = 0; #define JD_WNN_DEAD \ { \ buf->env->js_id->js_dead_env_flg = 1; \ if (setjmp(buf->env->js_id->js_dead_env) == 666) { \ if (jlib_work_area) { \ free(jlib_work_area); \ jlib_work_area = NULL;} \ jl_close(buf); \ if (jd_server_dead_env_flg) \ longjmp(jd_server_dead_env,666); \ return -1; \ } \ } /* j Lib. */ static char *jlib_work_area = NULL; /* bun joho */ static struct bunjoho bun; /** 文情報 **/ static int current_bun_no = -1; /* 次候補を取っている文節 */ static int current_ud = -1; /* カレント・ユーザ辞書 */ static struct wnn_ret_buf ret_buf = { 0, NULL }; /* get login name form /etc/passwd file */ static char * getlogname () { extern struct passwd *getpwuid (); struct passwd *p; if ((p = getpwuid (getuid ())) == NULL) return (NULL); return (p->pw_name); } /* * Lib. Functions */ /** jd_close **/ int jd_close (void) { if (jlib_work_area) { free (jlib_work_area); jlib_work_area = NULL; } if (jl_dic_save_all (buf) < 0) return (-1); jl_close (buf); return (0); } int jd_begin (); static int henkan_rcv (); /** jd_reconv **/ int jd_reconv (bunsetsu_no, kbuf, kb_siz) int bunsetsu_no, kb_siz; w_char *kbuf; { JD_WNN_DEAD if (bunsetsu_no == 0) return jd_begin (kbuf, kb_siz); if (jl_ren_conv (buf, &(bun.kana_buf)[((bun.klist)[bunsetsu_no]).s_ichi], bunsetsu_no, -1, WNN_USE_MAE) < 0) return (-1); return henkan_rcv (bunsetsu_no, kbuf, kb_siz); } /** jd_begin **/ int jd_begin (kbuf, kb_siz) w_char *kbuf; int kb_siz; { JD_WNN_DEAD current_bun_no = -1; jl_kill (buf, 0, -1); if (jl_ren_conv (buf, bun.kana_buf, 0, -1, WNN_NO_USE) < 0) return (-1); return (henkan_rcv (0, kbuf, kb_siz)); } /** jd_tanconv **/ int jd_tanconv (bunsetsu_no, moji_no, kbuf, kb_siz) int bunsetsu_no, moji_no, kb_siz; w_char *kbuf; { JD_WNN_DEAD if (moji_no < 0) return (-1); if (jl_nobi_conv (buf, bunsetsu_no, moji_no, -1, WNN_USE_MAE, WNN_SHO) < 0) return (-1); return henkan_rcv (bunsetsu_no, kbuf, kb_siz); } /** 変換結果を受信する **/ static int henkan_rcv (bunsetsu_no, kbuf, kb_siz) int bunsetsu_no; /** 文節番号 **/ w_char *kbuf; /** 漢字バッファー **/ int kb_siz; /** 漢字バッファーサイズ **/ { register w_char *b, *p; register int i, bun_no; register KOUHO_ENT *klp; int kanji_len = 0; int tmp; bun_no = jl_bun_suu (buf); if (jl_kanji_len (buf, bunsetsu_no, -1) >= kb_siz) return -1; if (bun_no >= bun.klist_size) { wnn_errorno = WNN_LONG_MOJIRETSU; return -1; } for (i = bunsetsu_no, klp = &((bun.klist)[bunsetsu_no]), b = kbuf; i < bun_no; klp++, i++) { klp->s_ichi = jl_yomi_len (buf, 0, i); klp->jl = jl_jiri_len (buf, i); klp->fl = jl_fuzoku_len (buf, i); klp->jishono = buf->bun[i]->dic_no; klp->serial = buf->bun[i]->entry; if (jl_kanji_len (buf, i, i + 1) + kanji_len >= kb_siz) { wnn_errorno = WNN_LONG_MOJIRETSU; return (-1); } klp->k_data = b; jl_get_kanji (buf, i, i + 1, b); tmp = jl_jiri_kanji_len (buf, i); b += tmp; kanji_len += tmp + 1; *b = 0; b++; klp->pl = 0; for (p = klp->k_data; *p; p++) { klp->pl += (*p & 0x8000) ? 2 : 1; } klp->pl += (klp->fl * 2); } klp->s_ichi = -1; return (bun_no - bunsetsu_no); } static int up_date_jikouho (); /** jd_end **/ int jd_end () { int ret; JD_WNN_DEAD if (current_bun_no != -1) { up_date_jikouho (); current_bun_no = -1; } ret = jl_update_hindo (buf, 0, -1); jl_kill (buf, 0, -1); return (ret); } /** jd_next **/ int jd_next (bunsetsu_no, to_go) int bunsetsu_no; JIKOUHOJOHO *to_go; { register int no_of_kouho, i; register w_char *b; register JIKOUHO_ENT *jlp; JD_WNN_DEAD if (current_bun_no != -1 && current_bun_no != bunsetsu_no) up_date_jikouho (); current_bun_no = bunsetsu_no; if (jl_zenkouho (buf, bunsetsu_no, WNN_USE_MAE, WNN_UNIQ) < 0) return (-1); no_of_kouho = jl_zenkouho_suu (buf); if (no_of_kouho >= to_go->jlist_size - 1) { wnn_errorno = WNN_JKTAREA_FULL; return (-1); } for (i = 0, jlp = to_go->jlist, b = to_go->kanji_buf; i < no_of_kouho; jlp++, i++) { jlp->jl = jl_jiri_len (buf, bunsetsu_no); jlp->jishono = buf->bun[bunsetsu_no]->dic_no; jlp->serial = buf->bun[bunsetsu_no]->entry; jlp->k_data = b; if (jl_kanji_len (buf, bunsetsu_no, bunsetsu_no + 1) >= to_go->kanji_buf_size) { wnn_errorno = WNN_JKTAREA_FULL; return (-1); } jl_get_kanji (buf, bunsetsu_no, bunsetsu_no + 1, b); b += jl_jiri_kanji_len (buf, bunsetsu_no); *b = 0; b++; if (jl_next (buf) < 0) return (-1); } jlp->jl = -1; return no_of_kouho; } static int up_date_jikouho () { register int no_of_kouho, i; int jishono, serial; jishono = (bun.klist)[current_bun_no].jishono; serial = (bun.klist)[current_bun_no].serial; no_of_kouho = jl_zenkouho_suu (buf); for (i = 0; i < no_of_kouho; i++) { if (jishono == buf->bun[current_bun_no]->dic_no && serial == buf->bun[current_bun_no]->entry) return (0); if (jl_next (buf) < 0) return (-1); } wnn_errorno = WNN_WORD_NO_EXIST; return (-1); } /* JD dictionary */ /** jd_dicadd **/ int jd_dicadd (fn, fn1, prio, hrdonly) char *fn, *fn1; int prio, hrdonly; { int rdonly; WNN_DIC_INFO ret; int dic_no; JD_WNN_DEAD if (fn1 == 0 || *fn1 == 0) { /* UD */ rdonly = hrdonly; } else if ((hrdonly == WNN_DIC_RDONLY) && /* READ ONLY SD && hind file is none */ (js_access (jl_env (buf), fn, 4) != -1) && (js_access (jl_env (buf), fn1, 4) == -1)) { if ((dic_no = jl_dic_add (buf, fn, fn1, WNN_DIC_ADD_NOR, prio, WNN_DIC_RDONLY, WNN_DIC_RW, NULL, NULL, WNN_CREATE, NULL)) < 0) return (-1); if (jl_dic_delete (buf, dic_no) < 0) return (-1); rdonly = WNN_DIC_RDONLY; } else { rdonly = WNN_DIC_RDONLY; } if ((dic_no = jl_dic_add (buf, fn, fn1, WNN_DIC_ADD_NOR, prio, rdonly, hrdonly, NULL, NULL, WNN_CREATE, NULL)) < 0) /* pw_d pw_h err mes */ return (-1); if (js_dic_info (jl_env (buf), dic_no, &ret) < 0) return (-1); if ((ret.type == WNN_UD_DICT || ret.type == WNN_REV_DICT) && ret.rw == WNN_DIC_RW) current_ud = dic_no; return (dic_no); } /** jd_dicdel **/ int jd_dicdel (dict_no) int dict_no; { JD_WNN_DEAD return (jl_dic_delete (buf, dict_no)); } /** jd_udchg **/ int jd_udchg (dic_no) int dic_no; { WNN_DIC_INFO ret; JD_WNN_DEAD if (js_dic_info (jl_env (buf), dic_no, &ret) < 0) return (-1); if (ret.type != WNN_UD_DICT && ret.type != WNN_REV_DICT) { wnn_errorno = WNN_NOT_A_UD; return (-1); } else if (ret.rw != WNN_DIC_RW || ret.enablef != 1) { wnn_errorno = WNN_RDONLY; return (-1); } current_ud = dic_no; return (0); } /** jd_udp **/ int jd_udp (dic_no) int dic_no; { WNN_DIC_INFO ret; int rdonly = 0; JD_WNN_DEAD if (js_dic_info (jl_env (buf), dic_no, &ret) < 0) return (-1); if (ret.rw == WNN_DIC_RDONLY || ret.enablef == 0) rdonly |= 0x4; if (ret.type == WNN_UD_DICT || (ret.type == WNN_REV_DICT && ret.rw == WNN_DIC_RW)) { rdonly = 1; if (current_ud == dic_no) rdonly |= 0x2; } return (rdonly); } /** jd_freqsv **/ int jd_freqsv () { JD_WNN_DEAD return (jl_dic_save_all (buf)); } /* JD word */ /** jd_whdel **/ int jd_whdel (ser_no, yomi, bunpou) int ser_no, bunpou; w_char *yomi; { JD_WNN_DEAD return (jl_word_delete (buf, current_ud, ser_no)); } /** jd_wdel **/ int jd_wdel (ser_no, yomi) int ser_no; w_char *yomi; { JD_WNN_DEAD return (jl_word_delete (buf, current_ud, ser_no)); } static int oldh_to_newh (); /** jd_wreg **/ int jd_wreg (kanji, yomi, bunpo) w_char *kanji, *yomi; int bunpo; { #ifdef NEW_HINSI return (jl_word_add (buf, current_ud, yomi, kanji, NULL, bunpo, 0)); #else int i; int ret = 0; int hinsi_suu; unsigned short *hinsi; JD_WNN_DEAD /* hinsi No conversion */ hinsi_suu = oldh_to_newh (bunpo, &hinsi); for (i = 0; i < hinsi_suu; i++, hinsi++) { if (jl_word_add (buf, current_ud, yomi, kanji, NULL, *hinsi, 0)) { ret = -1; } } return (ret); #endif } static int newh_to_oldh (); /** jd_wsch **/ int jd_wsch (yomi, jbuf, jbuf_siz, kbuf, kbuf_siz) w_char *yomi, *kbuf; JISHOJOHO *jbuf; int jbuf_siz, kbuf_siz; { register int i, klen; register w_char *b; struct wnn_jdata *jdp; int len; int cnt; JD_WNN_DEAD if ((cnt = jl_word_search_by_env (buf, yomi, &jdp)) < 0) return (-1); if (cnt >= jbuf_siz - 1) { wnn_errorno = WNN_JISHOTABLE_FULL; return (-1); } for (klen = 0, i = cnt, b = kbuf; i > 0; jbuf++, jdp++, i--) { jbuf->hindo = jdp->hindo; #ifdef NEW_HINSI jbuf->bumpo = jdp->hinshi; #else /* hinsi No conversion */ jbuf->bumpo = newh_to_oldh (jdp->hinshi); #endif jbuf->jisho = jdp->dic_no; jbuf->serial = jdp->serial; jbuf->k_data = b; len = wnn_Strlen (jdp->kanji) + 1; klen += len; if (klen >= kbuf_siz) { wnn_errorno = WNN_JISHOTABLE_FULL; return (-1); } wnn_Strcpy (b, jdp->kanji); b += len; } jbuf->hindo = -1; return cnt; } /* Parameter set/get */ /** jd_setenvf **/ int jd_setevf (bunsetsu_su, par1, par2, par3, par4, par5) int bunsetsu_su, par1, par2, par3, par4, par5; { struct wnn_param para; int ret; JD_WNN_DEAD ret = jl_param_get (buf, ¶); if (ret < 0) return (ret); para.n = bunsetsu_su; para.p1 = par1; para.p2 = par2; para.p3 = par3; para.p4 = par4; para.p5 = par5; return (jl_param_set (buf, ¶)); } /** jd_getenvf **/ int jd_getevf (bunsetsu_su, par1, par2, par3, par4, par5) int *bunsetsu_su, *par1, *par2, *par3, *par4, *par5; { struct wnn_param para; int ret; JD_WNN_DEAD ret = jl_param_get (buf, ¶); *bunsetsu_su = para.n; *par1 = para.p1; /* 幹語の頻度 */ *par2 = para.p2; /* 小文節長 */ *par3 = para.p3; /* 自立語長 */ *par4 = para.p4; /* 今使ったよビット */ *par5 = para.p5; /* 辞書 */ if (ret < 0); return (ret); } /** jd_dicinfo **/ int jd_dicinfo (jbuf, jbuf_siz, fbuf, fbuf_siz) DICINFO *jbuf; int jbuf_siz; char *fbuf; int fbuf_siz; { register int i, klen; register char *b; WNN_DIC_INFO *dic; int cnt, len; JD_WNN_DEAD if ((cnt = js_dic_list (jl_env (buf), &ret_buf)) < 0) return (-1); if (cnt >= jbuf_siz - 1) { wnn_errorno = WNN_JISHOTABLE_FULL; return (-1); } dic = (WNN_DIC_INFO *) ret_buf.buf; for (klen = i = 0, b = fbuf; i < cnt; jbuf++, dic++, i++) { jbuf->dic_no = dic->dic_no; jbuf->ttl_hindo = 0; /* ??? */ /* jbuf->dic_type = dic->type; */ if (dic->type == WNN_STATIC_DICT || (dic->type == WNN_REV_DICT && dic->rw == WNN_DIC_RDONLY)) jbuf->dic_type = SYSTEM_DIC; else if (dic->type == WNN_UD_DICT || (dic->type == WNN_REV_DICT && dic->rw == WNN_DIC_RW)) jbuf->dic_type = USER_DIC; jbuf->udp = jbuf->dic_no == current_ud ? 1 : 0; jbuf->dic_size = dic->gosuu; jbuf->prio = dic->nice; jbuf->rdonly = dic->rw | !dic->enablef; jbuf->file_name = b; len = strlen (dic->fname) + 1; klen += len; if (klen >= fbuf_siz) { wnn_errorno = WNN_JISHOTABLE_FULL; return (-1); } strcpy (b, dic->fname); b += len; jbuf->h_file_name = b; len = strlen (dic->hfname) + 1; klen += len; if (klen >= fbuf_siz) { wnn_errorno = WNN_JISHOTABLE_FULL; return (-1); } strcpy (b, dic->hfname); b += len; } jbuf->dic_no = -1; return i; } /** jd_open_in **/ struct bunjoho * jd_open_in (kana_len, klist_len, kanji_len, server, user, host) int kana_len, klist_len, kanji_len; char *server, *user, *host; { register int kasz, klsz, kjsz; int cnt, i; WNN_FILE_INFO_STRUCT *files; if (jlib_work_area != NULL) free (jlib_work_area); jlib_work_area = NULL; if (user == NULL || *user == '\0') { /* ENV name */ user = getlogname (); } if ((buf = jl_open (user, server, NULL, WNN_NO_CREATE, NULL, 0)) == NULL) return (NULL); else if (buf->env == NULL) return (NULL); kasz = (sizeof (w_char) * (kana_len + 1) + 7) & 0xfffffff8; klsz = (sizeof (KOUHO_ENT) * (klist_len + 1) + 7) & 0xfffffff8; kjsz = (sizeof (w_char) * kanji_len + 7) & 0xfffffff8; if (!(jlib_work_area = malloc (kasz + klsz + kjsz))) { wnn_errorno = WNN_MALLOC_INITIALIZE; return 0; } bun.klist = (KOUHO_ENT *) jlib_work_area; bun.klist_size = klist_len; bun.kana_buf = (w_char *) (jlib_work_area + klsz); bun.kana_size = kana_len; bun.kanji_buf = (w_char *) (jlib_work_area + klsz + kasz); bun.kanji_buf_size = kanji_len; /* Don't override fuzokugo file if already exists */ if (js_fuzokugo_get (jl_env (buf)) >= 0) { return &bun; } if ((cnt = js_file_list_all (buf->env->js_id, &ret_buf)) <= 0) return (NULL); for (i = 0, files = (WNN_FILE_INFO_STRUCT *) ret_buf.buf; i < cnt; i++) { if (files->type == WNN_FT_FUZOKUGO_FILE) break; files++; } if (i == cnt) return (NULL); if (jl_fuzokugo_set (buf, files->name) == -1) { return (NULL); } return &bun; } /** jd_open **/ struct bunjoho * jd_open (kana_len, klist_len, kanji_len) int kana_len, klist_len, kanji_len; { return (struct bunjoho *) jd_open_in (kana_len, klist_len, kanji_len, NULL, getlogname (), NULL); } /** jd_dicstatus **/ int jd_dicstatus (fn) char *fn; { WNN_FILE_STAT s; JD_WNN_DEAD if (js_file_stat (jl_env (buf), fn, &s) < 0) return (-1); if (s.type == WNN_STATIC_DICT) return (SYSTEM_DIC); else if (s.type == WNN_UD_DICT || s.type == WNN_REV_DICT) return (USER_DIC); else if (s.type == WNN_FILE_NOT_EXIST) return (NO_EXIST); else return (NOT_A_JISHO); } /** jd_mkdir **/ int jd_mkdir (dn) char *dn; { JD_WNN_DEAD return (js_mkdir (jl_env (buf), dn)); } /** jd_access **/ int jd_access (dn, amode) char *dn; int amode; { JD_WNN_DEAD return (js_access (jl_env (buf), dn, amode)); } /** jd_who **/ int jd_who (u, str) JWHO u[]; char *str; { register int i; register int cnt; WNN_JWHO *jwho; JD_WNN_DEAD if ((cnt = js_who (jl_env (buf)->js_id, &ret_buf)) < 0) return (-1); jwho = (WNN_JWHO *) ret_buf.buf; for (i = 0; i < cnt; i++, jwho++) { u[i].sd = jwho[0].sd; u[i].user_name = str; strcpy (str, jwho->user_name); str += strlen (u[i].user_name) + 1; u[i].host_name = str; strcpy (str, jwho->host_name); str += strlen (u[i].host_name) + 1; } u[i].sd = -1; return (0); } /** jd_version **/ int jd_version (serv, libv) int *serv, *libv; { JD_WNN_DEAD return (js_version (jl_env (buf)->js_id, serv, libv)); } #ifndef NEW_HINSI #define KOMEI 0x20000000 #define MEISI 0x00040000 #define JOSUU 0x04000000 #define SETTO 0x01000000 #define SETUBI 0x02000000 #define KEIYOU 0x00010000 #define KEIDOU 0x00020000 #define OLD_HINSI_SZ 32 static char *new_name[] = { "カ行五段", "カ行(行く)", "ガ行五段", "サ行五段", "タ行五段", "ナ行五段", "バ行五段", "マ行五段", "ラ行五段", "ワ行五段", "一段&名詞", "一段", "サ行(する)&名詞", "サ行(する)", "ザ行(ずる)", "来(こ)", "形容詞", "形容動詞", "名詞", "連体詞", "副詞", "接続詞,感動詞", "来(き)", "来(く)", "接頭語", "接尾語", "助数詞", "数詞", "ラ行(下さい)", "固有名詞", "形容動詞(たる)", "単漢字" }; /* :為(し):為(す):為(せ) */ #define KOMEI_SZ 3 /* "固有名詞" */ static char *komei_name[] = { "人名", "地名", "人名&地名" }; #define MEISI_SZ 1 /* "名詞" */ static char *meisi_name[] = { "形容動詞&名詞" }; #define JOSUU_SZ 2 /* "助数詞" */ static char *josuu_name[] = { "接頭助数詞", "接尾助数詞" }; #define SETTO_SZ 7 /* "接頭語" */ static char *setto_name[] = { "接頭語お", "接頭数詞", "接頭地名", "形容詞化接尾動詞", "接尾動詞", "サ行(する)&名詞化接尾語", "形容動詞化接尾語" }; #define SETUBI_SZ 4 /* "接尾語" */ static char *setubi_name[] = { "接尾人名", "接尾地名", "接尾社名", "接尾サ行(する)サ変名名詞" }; #define DOUSI_SZ 15 static char *dousi_name[] = { "カ動幹", "", "ガ動幹", "サ動幹", "タ動幹", "ナ動幹", "バ動幹", "マ動幹", "ラ動幹", "ワ動幹", "", "一動幹", "", "サ変動幹", "ザ変動幹" }; static char *dou_renyou_name[] = { "カ動連用幹", "", "ガ動連用幹", "サ動連用幹", "タ動連用幹", "ナ動連用幹", "バ動連用幹", "マ動連用幹", "ラ動連用幹", "ワ動連用幹", "", "一動連用幹", "", "サ変動連用幹", "ザ変動連用幹" }; static int oldh_to_newh (hinsi, new) int hinsi; unsigned short **new; { register int i, j; static unsigned short tmp[OLD_HINSI_SZ + 1]; register int tmptmp; /* H.T. to compile PCC */ for (i = j = 0; hinsi != 0 && i < OLD_HINSI_SZ; i++) { if ((hinsi & 0x01) != 0) { /* if((tmptmp = wnn_find_hinsi_by_name(new_name[i])) != -1){ */ wnn_Sstrcpy (wchartmp, new_name[i]); if ((tmptmp = jl_hinsi_number (buf, wchartmp)) != -1) { tmp[j] = tmptmp; j++; } else { tmp[j] = tmptmp; } /* H.T. unsigned short comparison with -1 if ((tmp[j] = wnn_find_hinsi_by_name(new_name[i])) != -1) j++; */ } hinsi >>= 1; } tmp[j] = -1; *new = tmp; return (j); } static int newh_to_oldh (hinsi) unsigned short hinsi; { register char *new_n; register w_char *wnew_n; register int i; /* if ((new_n = wnn_get_hinsi_name(hinsi)) == 0) */ if ((wnew_n = jl_hinsi_name (buf, hinsi)) == 0) return (-1); wnn_sStrcpy (chartmp, wnew_n); new_n = chartmp; for (i = 0; i < OLD_HINSI_SZ; i++) { if (strcmp (new_n, new_name[i]) == 0) return (0x1 << i); } for (i = 0; i < DOUSI_SZ; i++) { if (strcmp (new_n, dousi_name[i]) == 0) return (0x1 << i); } for (i = 0; i < DOUSI_SZ; i++) { if (strcmp (new_n, dou_renyou_name[i]) == 0) { /* return(wnn_find_hinsi_by_name(new_name[i])); */ wnn_Sstrcpy (wchartmp, new_name[i]); return (jl_hinsi_number (buf, wchartmp)); } } for (i = 0; i < KOMEI_SZ; i++) { if (strcmp (new_n, komei_name[i]) == 0) return (KOMEI); } for (i = 0; i < MEISI_SZ; i++) { if (strcmp (new_n, meisi_name[i]) == 0) return (MEISI); } for (i = 0; i < JOSUU_SZ; i++) { if (strcmp (new_n, josuu_name[i]) == 0) return (JOSUU); } for (i = 0; i < SETTO_SZ; i++) { if (strcmp (new_n, setto_name[i]) == 0) return (SETTO); } for (i = 0; i < SETUBI_SZ; i++) { if (strcmp (new_n, setubi_name[i]) == 0) return (SETUBI); } return (0); } #endif /* ! NEWHINSI */