view Wnn/jserver/do_dic_no.c @ 18:e7e2aba67cb3

disabled build for cWnn and kWnn by default
author Yoshiki Yazawa <yaz@cc.rim.or.jp>
date Mon, 14 Apr 2008 17:33:53 +0900
parents bbc77ca4def5
children a7ccf412ba02
line wrap: on
line source

/*
 *  $Id: do_dic_no.c,v 1.5 2003/05/11 18:41:49 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, 2003
 *
 * 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
 */

/*
 *      Do Dic operation by DicNo
 */

#include <stdio.h>

#include "demcom.h"
#include "commonhd.h"
#include "de_header.h"
#include "kaiseki.h"
#include "jdata.h"
#include "hinsi_file.h"

static void return_jbiki (struct jdata *jd);
static void return_jbiki1 (struct jdata *jd);
static int count_jdata (struct jdata *p);
static int count_jdata_kanji (struct jdata *p);

void
dic_init ()
{
  int i;
  for (i = 0; i < MAX_DIC; i++)
    {
      dic_table[i].body = -1;
      dic_table[i].hindo = -1;
    }
}

/*
        Dic. OPE by DicNo.
 */

/*      js_dic_info     */
void
js_dic_info ()
{
  int dic_no, envi;
  envi = get4_cur ();           /* env_id */
  dic_no = get4_cur ();
  if (!dic_in_envp (dic_no, envi))
    {
      wnn_errorno = WNN_DICT_NOT_IN_ENV;
      error_ret ();
      putc_purge ();
      return;
    }
  put4_cur (0);
  put_dic_info (dic_no);
  putc_purge ();
}

void
put_dic_info (int dic_no)
{
  int fid, hfid;
  struct JT *jtl;

  put4_cur (dic_no);
  put4_cur (fid = dic_table[dic_no].body);
  put4_cur (hfid = dic_table[dic_no].hindo);
  put4_cur (dic_table[dic_no].rw);
  put4_cur (dic_table[dic_no].hindo_rw);
  put4_cur (dic_table[dic_no].enablef);
  put4_cur (dic_table[dic_no].nice);
  put4_cur (dic_table[dic_no].rev);
/* added H.T */
  jtl = (struct JT *) files[fid].area;
  putnws_cur (jtl->comment, jtl->maxcomment);
  puts_cur (files[fid].name);
  if (hfid >= 0)
    puts_cur (files[hfid].name);
  else
    puts_cur ("");
  puts_n_cur (files[fid].passwd, WNN_PASSWD_LEN);
  if (hfid >= 0)
    puts_n_cur (files[hfid].passwd, WNN_PASSWD_LEN);
  else
    puts_n_cur (jtl->hpasswd, WNN_PASSWD_LEN);
  put4_cur (jtl->syurui);
  put4_cur (jtl->gosuu);
  put4_cur (files[fid].localf);
  if (hfid >= 0)
    put4_cur (files[hfid].localf);
  else
    put4_cur (-1);
}




/*      js_word_add     */
void
js_word_add ()
{
  int dic_no, hinsi, envi, hindo, ret;
  w_char yomi[LENGTHYOMI], kanji[LENGTHKANJI], comment[LENGTHKANJI];
  envi = get4_cur ();           /* env_id */
  dic_no = get4_cur ();
  getws_cur (yomi, LENGTHYOMI);
  getws_cur (kanji, LENGTHKANJI);
  getws_cur (comment, LENGTHKANJI);
  hinsi = get4_cur ();
  hindo = get4_cur ();
  ret = word_add (envi, dic_no, yomi, kanji, hinsi, hindo, comment);
  if (ret == -1)
    {
      error_ret ();
    }
  else
    {
      put4_cur (ret);
    }
  putc_purge ();
}

/*      js_word_delete  */
void
js_word_delete ()
{
  int dic_no, dic_entry, envi, ret;
  envi = get4_cur ();           /* env_id */
  dic_no = get4_cur ();
  dic_entry = get4_cur ();
  ret = word_delete (envi, dic_no, dic_entry);
  if (ret == -1)
    {
      error_ret ();
    }
  else
    {
      put4_cur (ret);
    }
  putc_purge ();
}

void
js_word_search_by_env ()
{
  w_char yomi[LENGTHYOMI];
  w_char ryomi[LENGTHYOMI];
  int n;

  c_env = env[get4_cur ()];
  getws_cur (yomi, LENGTHYOMI);
#ifdef  CONVERT_from_TOP
  Strcpy (ryomi, yomi);
#else
  Sreverse (ryomi, yomi);
#endif /* CONVERT_from_TOP */
  init_jmt ();

  n = jishobiki (ryomi, jmt_ptr);
  if (n != Strlen (yomi))
    {                           /* Want to return Error if n < 0 */
      return_jbiki (NULL);
    }
  else
    {
      return_jbiki (jmt_ptr[n - 1]);
    }
  if (n > 0)
    jmt_ptr += n;
  putc_purge ();
}


void
js_word_search ()
{
  w_char yomi[LENGTHYOMI];
  w_char ryomi[LENGTHYOMI];
  int dic_no;
  int n;

  get4_cur ();                  /* env_id */
  dic_no = get4_cur ();
  getws_cur (yomi, LENGTHYOMI);
#ifdef  CONVERT_from_TOP
  Strcpy (ryomi, yomi);
#else
  Sreverse (ryomi, yomi);
#endif /* CONVERT_from_TOP */
  init_jmt ();

  n = word_search (dic_no, ryomi, jmt_ptr);
  if (n != Strlen (yomi))
    {                           /* Want to return Error if n < 0 */
      return_jbiki (NULL);
    }
  else
    {
      return_jbiki (jmt_ptr[n - 1]);
    }
  if (n > 0)
    jmt_ptr += n;
  putc_purge ();
}


void
js_word_comment_set ()
{
  int dic_no, envi, entry;
  int ret;
  w_char comment[LENGTHKANJI];

  envi = get4_cur ();           /* env_id */
  dic_no = get4_cur ();
  entry = get4_cur ();
  getws_cur (comment, LENGTHKANJI);

  ret = word_comment_set (envi, dic_no, entry, comment);
  if (ret == -1)
    {
      error_ret ();
    }
  else
    {
      put4_cur (0);
    }
  putc_purge ();
}

void
js_word_info ()
{
  int dic_no, entry;
  struct jdata jdata;
  w_char yomi[LENGTHYOMI + 1];
  w_char ryomi[LENGTHYOMI + 1];

  get4_cur ();                  /* env_id */
  dic_no = get4_cur ();
  entry = get4_cur ();
  if (inspect (dic_no, entry, yomi, &jdata) == -1)
    {
      error_ret ();
      putc_purge ();
    }
  else
    {
      put4_cur (0);
#ifdef  CONVERT_from_TOP
      Strcpy (ryomi, yomi);
#else
      Sreverse (ryomi, yomi);
#endif /* CONVERT_from_TOP */
      putws_cur (ryomi);
      return_jbiki (&jdata);
      putc_purge ();
    }
}


static void
return_jbiki (struct jdata *jd)
{
  put4_cur (count_jdata (jd));
  put4_cur (count_jdata_kanji (jd));
  return_jbiki1 (jd);
}

static void
return_jbiki1 (struct jdata *jd)
{
  int t;
  w_char kouho[LENGTHKANJI];
  w_char comment[LENGTHKANJI];
  struct jdata *p;

  for (p = jd; p; p = p->jptr)
    {
      for (t = 0; t < p->kosuu; t++)
        {
          put4_cur (p->jishono);
          put4_cur (p->serial + t);

          put4_cur (*(p->hinsi + t));

          put4_cur (motoni2 (*(p->hindo + t) & 0x7f));
          put4_cur (*(p->hindo + t) >> 7);

/* internal hindo */
          if (p->hindo_in)
            {
              put4_cur (motoni2 (*(p->hindo_in + t) & 0x7f));
              put4_cur (*(p->hindo_in + t) >> 7);
            }
          else
            {
              put4_cur (-1);
              put4_cur (-1);
            }
        }
    }
  put4_cur (-1);
  for (p = jd; p; p = p->jptr)
    {
      for (t = 0; t < p->kosuu; t++)
        {
          get_knj_com (p, t, kouho, comment);
/*          get_knj(p, t, kouho);  H.T. Return Also Comment */
          putws_cur (kouho);    /* kanji */
          putws_cur (comment);  /* comment */
        }
    }
}

static int
count_jdata (struct jdata *p)
{
  int sum;

  for (sum = 0; p; p = p->jptr)
    {
      sum += p->kosuu;
    }
  return sum;
}

static int
count_jdata_kanji (struct jdata *p)
{
  int sum, t;
  w_char kouho[LENGTHKANJI];
  w_char comment[LENGTHKANJI];

  for (sum = 0; p; p = p->jptr)
    {
      for (t = 0; t < p->kosuu; t++)
        {
          get_knj_com (p, t, kouho, comment);
          sum += Strlen (kouho);        /* kanji */
          sum += Strlen (comment);      /* comment */
        }
    }
  return sum;
}

void
js_hinsi_name ()
{
  w_char *c;
  int no;

  no = get4_cur ();
  if ((c = wnn_hinsi_name (no)) == NULL)
    {
      error_ret ();
      putc_purge ();
      return;
    }
  put4_cur (Strlen (c));
  putws_cur (c);
  putc_purge ();
}

void
js_hinsi_number ()
{
  w_char name[WNN_HINSI_NAME_LEN];
  int no;

  getws_cur (name, WNN_HINSI_NAME_LEN);

  if ((no = wnn_hinsi_number (name)) == -1)
    {
      error_ret ();
      putc_purge ();
      return;
    }
  put4_cur (no);
  putc_purge ();
}


void
js_hinsi_list ()
{
  w_char name[WNN_HINSI_NAME_LEN];
  w_char *c, *c1;
  int envi, dic_no, no;
  int l, l1, k;
  int fid = 0, mmynode;
  struct wnn_hinsi_node *mynode;
  struct JT *jtl;

  envi = get4_cur ();
  dic_no = get4_cur ();
  getws_cur (name, WNN_HINSI_NAME_LEN);

  if (dic_no == -1)
    {
/*      fid = env[envi]->fzk_fid; */
      fid = 0;
      mynode = NULL;
      mmynode = 0;
    }
  else
    {
#ifdef nodef                    /* fid ha toumen tukawanai */
      if (!dic_in_envp (dic_no, envi))
        {
          wnn_errorno = WNN_DICT_NOT_IN_ENV;
          error_ret ();
          putc_purge ();
          return;
        }
#endif
      if (dic_no >= MAX_DIC || dic_no < 0)
        {
          wnn_errorno = WNN_DICT_NOT_IN_ENV;
          error_ret ();
          putc_purge ();
          return;
        }

      fid = dic_table[dic_no].body;
      if (fid == -1)
        {
          wnn_errorno = WNN_DICT_NOT_IN_ENV;
          error_ret ();
          putc_purge ();
          return;
        }
      jtl = (struct JT *) (files[fid].area);
      mynode = jtl->node;
      mmynode = jtl->maxnode;
      if (mmynode == 0)
        mynode = NULL;
    }

  if ((no = wnn_hinsi_list (name, &c, mynode, mmynode)) == -1)
    {
      error_ret ();
      putc_purge ();
      return;
    }
  put4_cur (no);
  for (l = 0, c1 = c, k = 0; k < no; k++)
    {
/*      l += (l1 =  Strlen(c1));
        c1 += l1 + 1; H.T.*/
      l += (l1 = Strlen (c1) + 1);
      c1 += l1;
    }
  put4_cur (l);
  for (k = 0, c1 = c; k < no; k++)
    {
      putws_cur (c1);
      c1 += Strlen (c1) + 1;
    }
  putc_purge ();
}

void
js_hinsi_dicts ()
{
  int envi;
  w_char *name;
  register int k;
  int cnt;
  struct JT *jtl;
  int ret[MAX_DIC];
  int no;
  int mmynode;
  struct wnn_hinsi_node *mynode;
  int max;
  register int dno;

  envi = get4_cur ();
  no = get4_cur ();
  if (no != -1)
    {                           /* H.T. n == -1 to return all dicts */
      if ((name = wnn_hinsi_name (no)) == NULL)
        {
          error_ret ();
          putc_purge ();
          return;
        }
    }
  cnt = 0;
  max = env[envi]->jishomax;
  for (k = 0; k < max; k++)
    {
      if ((dno = (env[envi]->jisho)[k]) == -1)
        continue;
      if (dic_table[dno].body == -1)
        continue;
      if (dic_table[dno].rw == WNN_DIC_RDONLY)
        continue;               /* H.T. */
      if (no == -1)
        {
          ret[cnt++] = dno;
        }
      else
        {
          jtl = (struct JT *) (files[dic_table[dno].body].area);
          mynode = jtl->node;
          mmynode = jtl->maxnode;
          if (mmynode == 0)
            mynode = NULL;
          if (wnn_has_hinsi (mynode, mmynode, name))
            ret[cnt++] = dno;
        }
    }
  put4_cur (cnt);
  for (k = 0; k < cnt; k++)
    {
      put4_cur (ret[k]);
    }
  putc_purge ();
}

void
js_hinsi_table_set ()
{
  w_char table[HEAP_LEN];
  int envi, dic_no, fid;
  /*
     struct wnn_hinsi_node *mynode;
   */
  struct JT *jtl;

  envi = get4_cur ();
  dic_no = get4_cur ();
  getws_cur (table, HEAP_LEN);


  if (!dic_in_envp (dic_no, envi))
    {
      wnn_errorno = WNN_DICT_NOT_IN_ENV;
      error_ret ();
      putc_purge ();
      return;
    }

  if (dic_no >= MAX_DIC || dic_no < 0)
    {
      wnn_errorno = WNN_DICT_NOT_IN_ENV;
      error_ret ();
      putc_purge ();
      return;
    }

  fid = dic_table[dic_no].body;
  if (fid == -1)
    {
      wnn_errorno = WNN_DICT_NOT_IN_ENV;
      error_ret ();
      putc_purge ();
      return;
    }
  jtl = (struct JT *) (files[fid].area);
  if (hinsi_table_set (jtl, table) == -1)
    {
      error_ret ();
      putc_purge ();
      return;
    }
  put4_cur (0);
  putc_purge ();
}