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, &para);
  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, &para));
}


/**     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, &para);
  *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 */