view Xwnmo/xwnmo/uif1.c @ 7:6ab41ec6f895

fix dtoa crash when it encounters malformed entry.
author Yoshiki Yazawa <yaz@cc.rim.or.jp>
date Tue, 18 Dec 2007 23:25:17 +0900
parents bbc77ca4def5
children
line wrap: on
line source

/*
 * $Id: uif1.c,v 1.2 2001/06/14 18:16:17 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 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 "commonhd.h"
#include "sdefine.h"
#include "xim.h"
#include "sheader.h"
#include "ext.h"
#include "rk_spclval.h"
#include "rk_fundecl.h"

int
jutil_c (in)
     int in;
{
  static WnnClientRec *c_c_sv = NULL;
  static int jutil_c_step = 0;

  if (c_c_sv != NULL && c_c != c_c_sv)
    {
      ring_bell ();
      return (-1);
    }
  if (jutil_c_step == 0)
    {
      if (c_c_sv)
        {
          return (-1);
        }
      c_c_sv = c_c;
      push_func (c_c, jutil_c);
      if (!isconect_jserver ())
        {
          c_c_sv = NULL;
          pop_func (c_c);
          return (0);
        }
      jutil_c_step = 1;
    }
  if (jutil (in) == BUFFER_IN_CONT)
    {
      return (BUFFER_IN_CONT);
    }
  c_c_sv = NULL;
  pop_func (c_c);
  jutil_c_step = 0;
  return (0);
}

int
touroku_c ()
{
  if (!isconect_jserver ())
    {
      return (0);
    }
  touroku ();
  return (0);
}

int
reconnect_jserver_body (in)
     int in;
{
  int k;
  int c;
  static int c_p = 0;
  static WnnClientRec *c_c_sv = 0;
  static int j_con_step = 0;
  static char hostname[32];
  static char *lang;

  if (c_c->use_server == 0)
    return (0);
  if (in == -99)
    {
      end_ichiran ();
      c_c_sv = 0;
      j_con_step = 0;
      romkan_clear ();
      return (-1);
    }
  if (c_c_sv != 0 && c_c != c_c_sv)
    {
      ring_bell ();
      return (-1);
    }
  if (c_c_sv == 0)
    {
      for (k = 0; k < 32; hostname[k++] = '\0');
      c_c_sv = c_c;
      c_p = 0;
      lang = cur_lang->lang;
    }
  if (j_con_step == 0)
    {
      if (init_ichiran ((unsigned char **) NULL, 0, -1,
                        (unsigned char *) msg_get (cd, 29, default_message[29], lang),
                        (unsigned char *) msg_get (cd, 30, default_message[30], lang), (unsigned char *) msg_get (cd, 19, default_message[19], lang), NULL, 32, NYUURYOKU) == -1)
        {
          ring_bell ();
          c_c_sv = 0;
          return (-1);
        }
      sprintf (hostname, "%s", servername);
      c_p = strlen (hostname);
      draw_nyuu_w ((unsigned char *) hostname, 1);
      j_con_step++;
      return (BUFFER_IN_CONT);
    }
  if (j_con_step == 1)
    {
      c = in;
      if (!xim->cur_j_c_root->ichi->map)
        return (BUFFER_IN_CONT);
      if (xim->sel_ret == -2)
        {
          end_ichiran ();
          xim->sel_ret = -1;
          c_c_sv = 0;
          j_con_step = 0;
          romkan_clear ();
          return (-1);
        }
      if (c < 256)
        {
          if ((c == ESC) || (t_quit == main_table[5][c]))
            {
              end_ichiran ();
              c_c_sv = 0;
              romkan_clear ();
              return (-1);
            }
          else if (henkan_off == main_table[5][c])
            {
              ring_bell ();
            }
          else if (c == rubout_code && c_p)
            {
              hostname[--c_p] = '\0';
            }
          else if (c == NEWLINE || c == CR)
            {
              if (c_p == 0)
                {
                  goto RET;
                }
              else
                {
                  end_ichiran ();
                  goto NEXT;
                }
            }
          else if (c > 20 && c < 128)
            {
              hostname[c_p++] = (char) c;
              goto RET;
            }
          else
            {
              ring_bell ();
            }
        }
      else
        {
          ring_bell ();
        }
    RET:
      clear_nyuu_w ();
      draw_nyuu_w ((unsigned char *) hostname, 1);
      return (BUFFER_IN_CONT);
    }
NEXT:
  if (servername)
    Free (servername);
  servername = alloc_and_copy (hostname);

  if (connect_server (cur_lang) < 0)
    goto ERROR_RET;
  if (c_c->use_server && !jl_isconnect (bun_data_))
    {
      print_msg_getc (" %s", msg_get (cd, 32, default_message[32], lang), NULL, NULL);
    }
  else
    {
      print_msg_getc (" %s", msg_get (cd, 33, default_message[33], lang), NULL, NULL);
    }
ERROR_RET:
  c_c_sv = 0;
  j_con_step = 0;
  romkan_clear ();
  return (0);
}

int
lang_c (in)
     int in;
{
  static WnnClientRec *c_c_sv = 0;
  XIMLangRec *xl;
  XIMNestLangRec *p;
  int ret;

  if (in == -99)
    {
      c_c_sv = 0;
      pop_func (c_c);
      return (0);
    }
  if (c_c_sv != 0 && c_c != c_c_sv)
    {
      ring_bell ();
      return (-1);
    }
  if (c_c_sv == 0)
    {
      c_c_sv = c_c;
      push_func (c_c, lang_c);
    }
  if ((ret = lang_set (in, &xl, &p)) == BUFFER_IN_CONT)
    {
      return (BUFFER_IN_CONT);
    }
  c_c_sv = 0;
  pop_func (c_c);
  if (ret >= 0)
    {
      change_lang (xl, p);
    }
  return (0);
}

int
lang_ct (in)
     int in;
{
  static WnnClientRec *c_c_sv = 0;
  XIMLangRec *xl;
  XIMNestLangRec *p;
  int ret;

  if (c_c_sv != 0 && c_c != c_c_sv)
    {
      ring_bell ();
      return (-1);
    }
  if (c_c_sv == 0)
    {
      c_c_sv = c_c;
      push_func (c_c, lang_ct);
    }
  if ((ret = lang_set_ct (in, &xl, &p)) == BUFFER_IN_CONT)
    {
      return (BUFFER_IN_CONT);
    }
  c_c_sv = 0;
  pop_func (c_c);
  if (ret >= 0)
    {
      change_lang (xl, p);
    }
  return (0);
}

#define UNGETBUFSIZE    32
static unsigned int unget_buf[UNGETBUFSIZE];
static int count = 0;

int
push_unget_buf (c)
     int c;
{
  if ((count + 1) >= UNGETBUFSIZE)
    return (-1);
  unget_buf[count++] = c;
  unget_buf[count] = EOLTTR;
  return (0);
}

unsigned int *
get_unget_buf ()
{
  if (count <= 0)
    unget_buf[0] = EOLTTR;
  count = 0;
  return (unget_buf);
}

int
if_unget_buf ()
{
  if (count > 0)
    return (1);
  return (0);
}