view Wnn/jserver/jishosub.c @ 22:c966456648ad

- fixed argument style in function definition - created header files for prototype check. (in progress) - suppress warnings
author Yoshiki Yazawa <yaz@cc.rim.or.jp>
date Thu, 17 Apr 2008 01:17:45 +0900
parents ed4bb01eb317
children 6bfa7ea3b75b
line wrap: on
line source

/*
 *  $Id: jishosub.c,v 1.3 2001/06/14 18:16:02 ura 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
 *
 * 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
 */

#include <stdio.h>
#include "commonhd.h"
#include "de_header.h"
#include "jdata.h"

static int inspect_sd (), get_fst_serial (), inspect_ud ();

int
inspect (dic_no, serial, yomi, jd)
     int dic_no;
     int serial;
     w_char *yomi;
     struct jdata *jd;
{
  struct JT *jtl;

  if (dic_no >= MAX_DIC || dic_no < 0 || dic_table[dic_no].body == -1)
    {
      wnn_errorno = WNN_DICT_NOT_IN_ENV;
      return (-1);
    }
  jtl = (struct JT *) (files[dic_table[dic_no].body].area);
  if (jtl->syurui == WNN_UD_DICT)
    {
      if (inspect_ud (dic_no, serial, yomi, jd) == -1)
        return (-1);
#if     defined(CONVERT_by_STROKE) || defined(CONVERT_with_SiSheng)
    }
  else if ((jtl->syurui & 0xff) == WNN_REV_DICT)
    {
#else
    }
  else if (jtl->syurui == WNN_REV_DICT)
    {
#endif /* CONVERT_by_STROKE || CONVERT_with_SiSheng */
      if (inspect_rd (dic_no, serial, yomi, jd) == -1)
        return (-1);
    }
  else
    {
      if (inspect_sd (dic_no, serial, yomi, jd) == -1)
        return (-1);
    }
  return (0);
}



int
get_yomi_from_serial (dic_no, serial, yomi)
     int dic_no;
     int serial;
     w_char *yomi;
{
  int k;
  struct jdata jdata;
  struct JT *jtl;

  jtl = (struct JT *) (files[dic_table[dic_no].body].area);
  for (k = 0; k < LENGTHYOMI; k++)
    {
      yomi[k] = 0;
    }

  if (jtl->syurui == WNN_UD_DICT)
    {
      if (inspect_ud (dic_no, serial, yomi, &jdata) == -1)
        return (-1);
#if     defined(CONVERT_by_STROKE) || defined(CONVERT_with_SiSheng)
    }
  else if ((jtl->syurui & 0xff) == WNN_REV_DICT)
    {
#else
    }
  else if (jtl->syurui == WNN_REV_DICT)
    {
#endif /* CONVERT_by_STROKE || CONVERT_with_SiSheng */
      if (inspect_rd (dic_no, serial, yomi, &jdata) == -1)
        return (-1);
    }
  else
    {
      if (inspect_sd (dic_no, serial, yomi, &jdata) == -1)
        return (-1);
    }
  return (0);
}


static int
inspect_sd (dic_no, serial, yomi, jd)
     int dic_no;
     int serial;
     w_char *yomi;
     struct jdata *jd;
{
  int len;
  struct JT *jtl;
  struct HJT *hjtl;
  UCHAR *hontaistart;
  UCHAR *hopter;
  int key;
  int tsize;
  w_char *charst;
  w_char *sumst;
  int *ptrst;
  int state;
  int sdiff;
  int last;
  int serialst;
  UCHAR *kanji1;


  yomi[0] = 0;
  jtl = (struct JT *) (files[dic_table[dic_no].body].area);
  if (dic_table[dic_no].hindo >= 0)
    hjtl = (struct HJT *) (files[dic_table[dic_no].hindo].area);
  else
    hjtl = NULL;
  hontaistart = jtl->hontai;
  hopter = hontaistart;
  if (serial >= jtl->maxserial)
    {
      wnn_errorno = WNN_WORD_NO_EXIST;
      return (-1);
    }
  if (jtl->hinsi[serial] == SAKUJO_HINSI)
    return (-1);

  for (;;)
    {
      switch ((state = *(w_char *) hopter))
        {
        case ST_NORMAL:
        case ST_NOPTER:
          tsize = *(w_char *) (hopter + 2);
          serialst = *(int *) (hopter + 4);
          kanji1 = (UCHAR *) (hopter + 8);
          charst = (w_char *) (hopter + 12);
          sumst = ((w_char *) charst + tsize + 2);
          /* + 2 keeps two zero words */
          ptrst = (int *) ((w_char *) sumst + tsize);
          sdiff = serial - *(int *) (hopter + 4);

          /* May be a little late, but enough */
          if ((int) sdiff < (int) sumst[tsize - 1])
            {
              for (key = 0; key < tsize; key++)
                {
                  if ((int) sdiff < (int) sumst[key])
                    {
                      break;
                    }
                }
              len = Strlen (yomi);
              yomi[len] = charst[key];
              yomi[len + 1] = 0;

              jd->kanji1 = (int)kanji1; // xxx this may result in failure --yaz
              jd->kanji2 = serial - serialst;
              jd->serial = serial;
              jd->kosuu = 1;
              jd->jishono = dic_no;
              jd->jptr = NULL;
              jd->hinsi = jtl->hinsi + serial;
              if (hjtl)
                {
                  jd->hindo = hjtl->hindo + serial;
                  jd->hindo_in = jtl->hindo + serial;
                }
              else
                {
                  jd->hindo = jtl->hindo + serial;
                  jd->hindo_in = NULL;
                }
              return (0);
            }
          else
            {
              if (state == ST_NOPTER)
                {
                  wnn_errorno = WNN_WORD_NO_EXIST;
                  return (-1);
                }
              last = 0;
              for (key = 0; key < tsize; key++)
                {
                  if (ptrst[key])
                    {
                      if (serial < get_fst_serial (hontaistart + ptrst[key], hontaistart))
                        break;
                      last = key;
                    }
                }
              len = Strlen (yomi);
              yomi[len] = charst[last];
              yomi[len + 1] = 0;
              hopter = hontaistart + ptrst[last];
            }
          break;
        case ST_NOENT:
          tsize = *(w_char *) (hopter + 2);
          charst = (w_char *) (hopter + 4);
          ptrst = (int *) AL_INT ((w_char *) charst + tsize);
          last = 0;
          for (key = 0; key < tsize; key++)
            {
              if (ptrst[key])
                {
                  if (serial < get_fst_serial (hontaistart + ptrst[key], hontaistart))
                    break;
                  last = key;
                }
            }
          len = Strlen (yomi);
          yomi[len] = charst[last];
          yomi[len + 1] = 0;
          hopter = hontaistart + ptrst[last];
          break;
        case ST_SMALL:
          len = Strlen (yomi);
          yomi[len] = *(w_char *) (hopter + 2);
          yomi[len + 1] = 0;
          hopter = hopter + 4;
          break;
        default:
          error1 ("inspect_sd:Error 2\n");
        }
    }
}

static int
get_fst_serial (hopter, hontaistart)
     UCHAR *hontaistart;
     char *hopter;
{
  int tsize;
  int k;
  int *ptrst;
  w_char *charst;

  switch (*(w_char *) hopter)
    {
    case ST_NORMAL:
    case ST_NOPTER:
      return (*(int *) (hopter + 4));
    case ST_NOENT:
      tsize = *(w_char *) (hopter + 2);
      charst = (w_char *) (hopter + 4);
      ptrst = (int *) AL_INT ((w_char *) charst + tsize);
      for (k = 0; k < tsize; k++)
        {
          if (ptrst[k])
            {
              return (get_fst_serial (hontaistart + ptrst[k], hontaistart));
            }
        }
      break;
    case ST_SMALL:
      return (get_fst_serial (hopter + 4, hontaistart));
    default:
      error1 ("get_fst_serial:Error 1\n");
    }
  return (-1);
}


static int
inspect_ud (dic_no, serial, yomi, jd)
     int dic_no;
     int serial;
     w_char *yomi;
     struct jdata *jd;
{
  struct JT *jtl;
  struct HJT *hjtl;
  struct uind1 *tary;
  struct uind2 *p;
  int k;
  int len;

  jtl = (struct JT *) (files[dic_table[dic_no].body].area);
  tary = jtl->table;
  if (dic_table[dic_no].hindo >= 0)
    hjtl = (struct HJT *) (files[dic_table[dic_no].hindo].area);
  else
    hjtl = NULL;

  if (serial >= jtl->maxserial)
    {
      wnn_errorno = WNN_WORD_NO_EXIST;
      return (-1);
    }
  if (jtl->hinsi[serial] == SAKUJO_HINSI)
    return (-1);

  for (k = 0; k < jtl->maxtable; k++)
    {
      for (p = ((struct uind2 *) ((tary[k].pter) + jtl->hontai));; p = ((struct uind2 *) ((p->next) + jtl->hontai)))
        {
          if ((int) p->serial <= (int) serial && (int) (p->serial + p->kosuu) > (int) serial)
            goto found_it;
          if (p->next == ENDPTR)
            break;
        }
    }
  wnn_errorno = WNN_WORD_NO_EXIST;
  return (-1);

found_it:
  yomi[0] = tary[k].yomi1 >> 16;
  yomi[1] = tary[k].yomi1 & 0xffff;
  if (yomi[1])
    {
      yomi[2] = tary[k].yomi2 >> 16;
      if (yomi[2])
        {
          yomi[3] = tary[k].yomi2 & 0xffff;
        }
    }
  len = p->yomi[0];
  Strncpy (yomi + 4, (p->yomi) + 1, len - 4);
  yomi[len] = 0;

  jd->kanji1 = p->kanjipter; // xxx this may result in failure --yaz
  jd->kanji2 = serial - p->serial;
  jd->serial = serial;
  jd->kosuu = 1;
  jd->jishono = dic_no;
  jd->jptr = NULL;
  jd->hinsi = jtl->hinsi + serial;
  if (hjtl)
    {
      jd->hindo = hjtl->hindo + serial;
      jd->hindo_in = jtl->hindo + serial;
    }
  else
    {
      jd->hindo = jtl->hindo + serial;
      jd->hindo_in = NULL;
    }

  return (0);
}