view Xwnmo/xwnmo/inspect.c @ 29:35bc1f2e3f14 default tip

minor fix
author Yoshiki Yazawa <yaz@honeyplanet.jp>
date Sat, 06 Mar 2010 23:55:24 +0900
parents bbc77ca4def5
children
line wrap: on
line source

/*
 * $Id: inspect.c,v 1.2 2001/06/14 18:16:16 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 1991, 1992 by Massachusetts Institute of Technology
 *
 * Author: OMRON SOFTWARE Co., Ltd. <freewnn@rd.kyoto.omronsoft.co.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, 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 GNU Emacs; see the file COPYING.  If not, write to the
 * Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 * Commentary:
 *
 * Change log:
 *
 * Last modified date: 8,Feb.1999
 *
 * Code:
 *
 */
/*      Version 4.0
 */
#include <stdio.h>
#include "sdefine.h"
#include "xim.h"
#include "sheader.h"
#include "config.h"
#include "ext.h"
#include "rk_spclval.h"
#include "rk_fundecl.h"

#define LOCAL_TBL_CNT   2

int (*local_tbl[LOCAL_TBL_CNT]) () =
{
inspectdel, inspectuse};

static int
xw_inspect (c, in)
     char *c;
     int in;
{
  static int select_step = 0;
  int d;
  int ret;
  static int (*func) ();

  if (select_step == 0)
    {
      if (init_inspect ((unsigned char *) c))
        {
          ring_bell ();
          return (-1);
        }
      select_step++;
      return (BUFFER_IN_CONT);
    }
  if (select_step == 1)
    {
      if (in == -99)
        {
          end_inspect ();
          select_step = 0;
          return (-1);
        }
      if (!xim->cur_j_c_root->inspect->map)
        return (BUFFER_IN_CONT);
      if (xim->sel_ret == -2)
        {
          xim->sel_ret = -1;
          end_inspect ();
          select_step = 0;
          return (-1);
        }
      else if (xim->sel_ret != -1)
        {
          d = xim->sel_ret;
          xim->sel_ret = -1;
          if (d >= 0 && d < LOCAL_TBL_CNT && (func = local_tbl[d]))
            {
              lock_inspect ();
              select_step++;
            }
          else
            {
              return (BUFFER_IN_CONT);
            }
        }
      else if ((in < 256) && (func = main_table[9][in]))
        {
          for (d = 0; d < LOCAL_TBL_CNT; d++)
            {
              if (local_tbl[d] == func)
                {
                  lock_inspect ();
                  break;
                }
            }
          select_step++;
        }
      else
        {
          ring_bell ();
          return (BUFFER_IN_CONT);
        }
    }
  if (select_step == 2)
    {
      ret = (*func) (in);
      if (ret == 1 || ret == -1)
        {
          end_inspect ();
          select_step = 0;
          return (0);
        }
      else if (ret == BUFFER_IN_CONT)
        {
          return (BUFFER_IN_CONT);
        }
      else
        {
          select_step--;
          unlock_inspect ();
          return (BUFFER_IN_CONT);
        }
    }
  return (BUFFER_IN_CONT);
}

int
inspect (bun_no, c, in)
     int bun_no;
     char *c;
     int in;
{
  if (xw_inspect (c, in) == BUFFER_IN_CONT)
    {
      return (BUFFER_IN_CONT);
    }
  return (1);
}

static int next_flag;
#define I_NEXT 1
#define I_PREV 2
#define I_CUR 3

static int
update_dic_list (buf)
     struct wnn_buf *buf;
{
  if ((dic_list_size = jl_dic_list (bun_data_, &dicinfo)) == -1)
    {
      errorkeyin ();
      return (-1);
    }
  return (0);
}

static int
find_dic_by_no (dic_no)
     int dic_no;
{
  int j;

  for (j = 0; j < dic_list_size; j++)
    {
      if (dicinfo[j].dic_no == dic_no)
        return (j);
    }
  return (-1);
}

static int
dic_nickname (dic_no, buf)
     int dic_no;
     char *buf;
{
  int j;

  if ((j = find_dic_by_no (dic_no)) == -1)
    return (-1);
  if (*dicinfo[j].comment)
    sStrcpy (buf, dicinfo[j].comment);
  else
    strcpy (buf, dicinfo[j].fname);
  return (0);
}

static int Bun_no;

static int
make_string_for_ke (bun_no, buf, buf_size)
     int bun_no;
     char *buf;
     int buf_size;
{
  struct wnn_jl_bun *bun;
  w_char buf1[1024];
  w_char save_c;
  char tmp[WNN_HINSI_NAME_LEN * 2];
  char *lang;

  lang = cur_lang->lang;

  Bun_no = bun_no;
  bun = bun_data_->bun[bun_no];
  jl_get_kanji (bun_data_, bun_no, bun_no + 1, buf1);
  if (print_out_func)
    (*print_out_func) (buf1, buf1, Strlen (buf1));
  delete_w_ss2 (buf1, Strlen (buf1));
  sStrcpy (buf, buf1);
  strcat (buf, " ");
  jl_get_yomi (bun_data_, bun_no, bun_no + 1, buf1);
  if (print_out_func)
    (*print_out_func) (buf1, buf1, Strlen (buf1));
  delete_w_ss2 (buf1, Strlen (buf1));
  save_c = *(buf1 + bun->jirilen);
  *(buf1 + bun->jirilen) = 0;
  sStrcpy (buf + strlen (buf), buf1);
  *(buf1 + bun->jirilen) = save_c;
  strcat (buf, "-");
  sStrcpy (buf + strlen (buf), buf1 + bun->jirilen);

  set_escape_code (buf);

  strcat (buf, "   (");
  if (bun->dic_no >= 0)
    {
      update_dic_list (bun_data_);
      dic_nickname (bun->dic_no, buf + strlen (buf));
      sStrcpy (tmp, jl_hinsi_name (bun_data_, bun->hinsi));
      sprintf (buf + strlen (buf), ":%d %s", bun->entry, tmp);
      if (bun->hindo != 0x7f)
        {
          sprintf (buf + strlen (buf), " %s:%c%d", msg_get (cd, 4, default_message[4], lang), bun->ima ? '*' : ' ', bun->hindo);
        }
      else
        {
          sprintf (buf + strlen (buf), " ---------");
        }                       /* Means This entry is not used.
                                   This must not appear in ordinary use! */

    }
  else
    {
      sStrcpy (tmp, jl_hinsi_name (bun_data_, bun->hinsi));
      sprintf (buf + strlen (buf), "GIJI BUNSETU:%s", tmp);
    }
  strcat (buf, ")   ");
  sprintf (buf + strlen (buf), "%s:%d %s:%d", msg_get (cd, 5, default_message[5], lang), bun->hyoka, msg_get (cd, 6, default_message[6], lang), bun->kangovect);


  if (bun->dai_top)
    {
      if (bun->daihyoka != -1)
        {
          sprintf (buf + strlen (buf), "(%s:%d) ", msg_get (cd, 7, default_message[7], lang), bun->daihyoka);
        }
      else
        {
          sprintf (buf + strlen (buf), "(%s:---) ", msg_get (cd, 7, default_message[7], lang));
        }
    }

  return (0);
}

int
inspect_kouho (in)
     int in;
{
  static char buf[1024];
  static WnnClientRec *c_c_sv = 0;

#ifdef  CALLBACKS
  if (IsPreeditCallbacks (cur_x) && cur_x->cb_redraw_needed)
    {
      t_print_l ();
      c_c_sv = 0;
      pop_func (c_c);
      cur_x->cb_redraw_needed = 0;
      return (0);
    }
#endif /* CALLBACKS */

  if (c_c_sv != 0 && c_c != c_c_sv)
    {
      ring_bell ();
      return (0);
    }
  if (c_c_sv == 0)
    {
      c_c_sv = c_c;
      push_func (c_c, inspect_kouho);
      next_flag = I_CUR;
      if (make_string_for_ke (cur_bnst_, buf, sizeof (buf)) == -1)
        {
          print_msg_getc ("Error in inspect", NULL, NULL, NULL);
          return (0);
        }
    }
  if (inspect (cur_bnst_, buf, in) == BUFFER_IN_CONT)
    {
      return (BUFFER_IN_CONT);
    }
#ifdef  CALLBACKS
  if (IsPreeditCallbacks (cur_x))
    {
      cur_x->cb_redraw_needed = 1;
      SendCBRedraw ();
      return (BUFFER_IN_CONT);
    }
#endif /* CALLBACKS */
  t_print_l ();
  c_c_sv = 0;
  pop_func (c_c);
  return (0);
}

static int
sakujo_kouho1 (bun_no, in)
     int bun_no;
     int in;
{
  w_char w_buf[512];
  char buf[512];
  int kanji_len, ret;
  char *lang;
  static int step = 0;

  if (step == 0)
    {
      lang = cur_lang->lang;
      jl_get_kanji (bun_data_, bun_no, bun_no + 1, w_buf);
      kanji_len = jl_kanji_len (bun_data_, bun_no, bun_no + 1) - jl_fuzoku_len (bun_data_, bun_no);
      w_buf[kanji_len] = 0;
      sStrcpy (buf, w_buf);
      strcat (buf, " ");
      strcat (buf, msg_get (cd, 8, default_message[8], lang));
      strcat (buf, ":");
      jl_get_yomi (bun_data_, bun_no, bun_no + 1, w_buf);
      w_buf[jl_jiri_len (bun_data_, bun_no)] = 0;
      sStrcpy (buf + strlen (buf), w_buf);
      strcat (buf, " ");
      sprintf (buf + strlen (buf), "%s?", msg_get (cd, 9, default_message[9], lang));
      step++;
    }
  if ((ret = yes_or_no (buf, in)) != BUFFER_IN_CONT)
    {
      if (ret == 1)
        {
          if (jl_word_delete (bun_data_, bun_data_->bun[bun_no]->dic_no, bun_data_->bun[bun_no]->entry) == -1)
            {
              errorkeyin ();
            }
        }
      step = 0;
    }
  return (ret);
}

int
sakujo_kouho (in)
     int in;
{
  static WnnClientRec *c_c_sv = 0;

#ifdef  CALLBACKS
  if (IsPreeditCallbacks (cur_x) && cur_x->cb_redraw_needed)
    {
      t_print_l ();
      c_c_sv = 0;
      pop_func (c_c);
      cur_x->cb_redraw_needed = 0;
      return (0);
    }
#endif /* CALLBACKS */

  if (c_c_sv != 0 && c_c != c_c_sv)
    {
      ring_bell ();
      return (0);
    }
  if (c_c_sv == 0)
    {
      c_c_sv = c_c;
      push_func (c_c, sakujo_kouho);
    }
  if (sakujo_kouho1 (cur_bnst_, in) == BUFFER_IN_CONT)
    {
      return (BUFFER_IN_CONT);
    }
#ifdef  CALLBACKS
  if (IsPreeditCallbacks (cur_x))
    {
      cur_x->cb_redraw_needed = 1;
      SendCBRedraw ();
      return (BUFFER_IN_CONT);
    }
#endif /* CALLBACKS */
  t_print_l ();
  c_c_sv = 0;
  pop_func (c_c);
  return (0);
}

int
inspectdel (in)
     int in;
{
  struct wnn_jl_bun *bun = bun_data_->bun[Bun_no];
  w_char buf1[1024];
  char buf[512];
  int type, ret;
  int kanji_len;
  char *lang;
  static int step = 0;

  if (step == 0)
    {
      lang = cur_lang->lang;
      type = dicinfo[find_dic_by_no (bun->dic_no)].type;
      if (type != WNN_UD_DICT && type != WNN_REV_DICT && type != CWNN_REV_DICT)
        {
          print_msg_getc ("%s", msg_get (cd, 10, default_message[10], lang), NULL, NULL);
          return (0);
        }
      if (dicinfo[find_dic_by_no (bun->dic_no)].rw == WNN_DIC_RDONLY)
        {
          print_msg_getc ("%s", msg_get (cd, 11, default_message[11], lang), NULL, NULL);
          return (0);
        }

      jl_get_kanji (bun_data_, Bun_no, Bun_no + 1, buf1);
      kanji_len = jl_kanji_len (bun_data_, Bun_no, Bun_no + 1) - jl_fuzoku_len (bun_data_, Bun_no);
      buf1[kanji_len] = 0;

      strcpy (buf, msg_get (cd, 12, default_message[12], lang));
      sStrcpy (buf + strlen (buf), buf1);
      sprintf (buf + strlen (buf), "%s", msg_get (cd, 13, default_message[13], lang));
      set_escape_code (buf);    /* ADD KURI */
      step++;
    }
  if ((ret = yes_or_no (buf, in)) != BUFFER_IN_CONT)
    {
      if (ret == 1)
        {
          if (jl_word_delete (bun_data_, bun->dic_no, bun->entry) == -1)
            {
              errorkeyin ();
            }
        }
      step = 0;
    }
  return (ret);
}

int
inspectuse (in)
     int in;
{
  struct wnn_jl_bun *bun = bun_data_->bun[Bun_no];
  w_char buf1[1024];
  char buf[512];
  int kanji_len;
  char *lang;
  int ret;
  static int step = 0;

  if (step == 0)
    {
      lang = cur_lang->lang;
      if (dicinfo[find_dic_by_no (bun->dic_no)].hindo_rw == WNN_DIC_RDONLY)
        {
          print_msg_getc ("%s", msg_get (cd, 14, default_message[14], lang), NULL, NULL);
          return (0);
        }
      strcpy (buf, msg_get (cd, 12, default_message[12], lang));
      jl_get_kanji (bun_data_, Bun_no, Bun_no + 1, buf1);
      kanji_len = jl_kanji_len (bun_data_, Bun_no, Bun_no + 1) - jl_fuzoku_len (bun_data_, Bun_no);
      buf1[kanji_len] = 0;
      sStrcpy (buf + strlen (buf), buf1);
      set_escape_code (buf);    /* ADD KURI */
      sprintf (buf + strlen (buf), "%s", msg_get (cd, 15, default_message[15], lang));
      step++;
    }
  if ((ret = yes_or_no (buf, in)) != BUFFER_IN_CONT)
    {
      if (ret == 1)
        {
          if (jl_word_use (bun_data_, bun->dic_no, bun->entry) == -1)
            {
              errorkeyin ();
            }
        }
      step = 0;
    }
  return (ret);
}

unsigned char *
next_inspect ()
{
  char buf[1024];
  char *c = buf;

  if (jl_zenkouho_bun (bun_data_) != cur_bnst_ || jl_zenkouho_daip (bun_data_) != WNN_SHO)
    {
      jl_zenkouho (bun_data_, cur_bnst_, WNN_USE_ZENGO, WNN_UNIQ);
    }
  jl_next (bun_data_);
  make_kanji_buffer (cur_bnst_);
  c_b->t_m_start = bunsetsuend[cur_bnst_];
  c_b->t_b_st = dai_top (bun_data_, cur_bnst_); /* add by KUWA */
  c_b->t_b_end = dai_end (bun_data_, cur_bnst_);        /* add by KUWA */
  if (make_string_for_ke (cur_bnst_, buf, sizeof (buf)) == -1)
    {
      print_msg_getc ("Error in inspect", NULL, NULL, NULL);
      return (NULL);
    }
  return ((unsigned char *) c);
}

unsigned char *
previous_inspect ()
{
  char buf[1024];
  char *c = buf;

  if (jl_zenkouho_bun (bun_data_) != cur_bnst_ || jl_zenkouho_daip (bun_data_) != WNN_SHO)
    {
      jl_zenkouho (bun_data_, cur_bnst_, WNN_USE_ZENGO, WNN_UNIQ);
    }
  jl_previous (bun_data_);
  make_kanji_buffer (cur_bnst_);
  c_b->t_m_start = bunsetsuend[cur_bnst_];
  c_b->t_b_st = dai_top (bun_data_, cur_bnst_); /* add by KUWA */
  c_b->t_b_end = dai_end (bun_data_, cur_bnst_);        /* add by KUWA */
  if (make_string_for_ke (cur_bnst_, buf, sizeof (buf)) == -1)
    {
      print_msg_getc ("Error in inspect", NULL, NULL, NULL);
      return (NULL);
    }

  return ((unsigned char *) c);
}