view Xwnmo/xwnmo/prologue.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: prologue.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, 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
 */
/* Standard Interface
 *    Initialize Routine
 */

#include <stdio.h>
#include "commonhd.h"
#include "config.h"
#include "sdefine.h"
#include <X11/Xos.h>
#include "xim.h"
#include "sheader.h"
#include "ext.h"
#include "rk_spclval.h"
#include "rk_fundecl.h"

extern char *getenv ();
extern FILE *fopen ();

/** Initialize of romkan */
int
open_romkan (ld)
     XIMLangDataBase *ld;
{
  int rk_option_flg;

  rk_option_flg = RK_REDRAW | RK_CHMOUT | (excellent_delete ? 0 : RK_SIMPLD);

  if (ld->rk_table == NULL)
    {
      if ((ld->rk_table = romkan_table_init (NULL, ld->rkfile_name, NULL, bytcntfn, NULL, 0))
/*
                                              bytcntfn, letterpickfn, NULL, 0))
*/
          == NULL)
        {
          return (-1);
        }
    }
  cur_rk_table = ld->rk_table;
  c_c->rk = (Romkan *) romkan_init5 (rubout_code, rk_option_flg);
  if (c_c->rk == NULL)
    return (-1);
  else
    {
      c_c->rk->rk_table = cur_rk_table;
      return (0);
    }
}



/** Open the wnnenvrc_R file */
static int
get_envrc_name_reverse (str, lang)
     char *str, *lang;
{
  extern int access ();

  if (c_c->cur_reverse_env == NULL || reverse_envrcname == NULL || reverse_envrcname[0] == '\0')
    return (0);
  strcpy (str, reverse_envrcname);
  if (access (str, R_OK) == -1)
    {
      return (-1);
    }
  return (1);
}

/** Open the wnnenvrc file */
static int
get_envrc_name (str, lang)
     char *str, *lang;
{
  if (c_c->cur_normal_env == NULL || envrcname == NULL || envrcname[0] == '\0')
    {
      strcpy (str, LIBDIR);
      strcat (str, "/");
      strcat (str, lang);
      strcat (str, ENVRCFILE);
    }
  else
    {
      strcpy (str, envrcname);
    }
  return (1);
}

/* Allocate of Wnn Area */
int
allocate_areas ()
{
  char *area_start;
  char *area_pter;

  int k;
  int total_size;
  int len1 = maxchg * sizeof (w_char);
  int return_buf_len = len1 * 7;

  total_size = return_buf_len + len1 * 3 + maxbunsetsu * sizeof (int) * 3 + maxbunsetsu * sizeof (struct wnn_env *);

  if ((area_start = Malloc (total_size)) == NULL)
    {
      malloc_error ("allocation of Wnn's area");
      return (-1);
    }

  area_pter = area_start;
  return_buf = (w_char *) area_pter;
  area_pter += return_buf_len;
  input_buffer = (w_char *) area_pter;
  area_pter += len1;
  kill_buffer = (w_char *) area_pter;
  area_pter += len1;
  remember_buf = (w_char *) area_pter;
  *remember_buf = 0;
  area_pter += len1;

  bunsetsu = (int *) area_pter;
  area_pter += maxbunsetsu * sizeof (int);
  bunsetsuend = (int *) area_pter;
  area_pter += maxbunsetsu * sizeof (int);
  bunsetsu_env = (struct wnn_env **) area_pter;
  area_pter += maxbunsetsu * sizeof (struct wnn_env *);
  touroku_bnst = (int *) area_pter;
  area_pter += maxbunsetsu * sizeof (int);
  for (k = 0; k < maxbunsetsu; k++)
    {
      bunsetsu[k] = 0;
      bunsetsuend[k] = 0;
      touroku_bnst[k] = 0;
    }
  return (0);
}

void
free_areas ()
{
  Free (return_buf);
}

static struct wnn_buf *
local_jl_open_lang ()
{
  struct wnn_buf *buf;
  register char **c, *p;

  if (!(p = Malloc (sizeof (struct wnn_buf) + sizeof (char *))))
    {
      malloc_error ("allocation of work area for Wnn");
      return (NULL);
    }
  buf = (struct wnn_buf *) p;
  p += sizeof (struct wnn_buf);
  buf->bun_suu = 0;
  buf->zenkouho_suu = 0;
  buf->zenkouho_daip = 0;
  buf->c_zenkouho = -1;
  buf->zenkouho_bun = -1;
  buf->zenkouho_end_bun = -1;
  buf->free_heap = NULL;
  c = (char **) p;
  *c = NULL;
  buf->heap = (char *) c;
  buf->zenkouho_dai_suu = 0;
  buf->msize_bun = 0;
  buf->msize_zenkouho = 0;
  buf->zenkouho_dai_suu = 0;
  buf->bun = NULL;
  buf->zenkouho_dai = NULL;
  buf->zenkouho = NULL;
  buf->down_bnst = NULL;
  buf->zenkouho_dai = NULL;
  buf->env = NULL;
  return (buf);
}

/** Connecting to jserver */
int
connect_server (db)
     XIMLangDataBase *db;
{
  char environment[PATHNAMELEN];
  char uumrc_name[PATHNAMELEN];
  register WnnEnv *p;
  WnnEnv *save_cur_normal_env = NULL, *save_cur_reverse_env = NULL;

  if ((db->lang == NULL) || (db->connect_serv == False))
    {
      if (c_c->normal_env == NULL)
        {
          if (get_new_env (c_c, NULL, 0) < 0)
            return (-1);
        }
      c_c->use_server = 0;
      c_c->cur_normal_env = c_c->normal_env;
      uumrc_name[0] = '\0';
      if (!(bun_data_ = local_jl_open_lang ()))
        return (-1);
      return (0);
    }
  else
    {
      c_c->use_server = 1;
    }

  if (c_c->cur_normal_env)
    save_cur_normal_env = c_c->cur_normal_env;
  for (p = c_c->normal_env; p; p = p->next)
    {
      c_c->cur_normal_env = p;
      get_envrc_name (uumrc_name, db->lang);    /* use username for env-name */
      environment[0] = '\0';
      strcpy (environment, username);
      strcat (environment, p->env_name_str);
      if (servername == NULL && def_servername && *def_servername)
        {
          servername = alloc_and_copy (def_servername);
        }
      if (bun_data_ == NULL)
        {
          bun_data_ = jl_open_lang (environment, servername, db->lang, uumrc_name, yes_or_no_lock, print_msg_wait, WNN_TIMEOUT);
          if (!bun_data_)
            {
              if (wnn_errorno == WNN_ALLOC_FAIL)
                {
                  malloc_error ("alloction of work area for Wnn");
                }
              return (-1);
            }
          if (bun_data_->env != NULL)
            {
              env_normal = bun_data_->env;
            }
        }
      else if (env_normal == 0 || jl_isconnect_e (env_normal) == 0)
        {
          env_normal = jl_connect_lang (environment, servername, db->lang, uumrc_name, yes_or_no_lock, print_msg_wait, WNN_TIMEOUT);
        }
      if (env_normal)
        {
          if (normal_sticky)
            jl_env_sticky_e (env_normal);
          else
            jl_env_un_sticky_e (env_normal);
        }
    }
  if (save_cur_normal_env)
    {
      c_c->cur_normal_env = save_cur_normal_env;
      if (env_normal)
        jl_env_set (bun_data_, env_normal);
    }
  if (c_c->normal_env == NULL)
    {
      if (get_new_env (c_c, NULL, 0) < 0)
        return (-1);
      c_c->use_server = 0;
      c_c->cur_normal_env = c_c->normal_env;
      uumrc_name[0] = '\0';
      if (!(bun_data_ = local_jl_open_lang ()))
        return (-1);
    }

  if (c_c->cur_reverse_env)
    save_cur_reverse_env = c_c->cur_reverse_env;
  for (p = c_c->reverse_env; p; p = p->next)
    {
      c_c->cur_reverse_env = p;
      if (get_envrc_name_reverse (uumrc_name, db->lang) > 0)
        {
          environment[0] = '\0';
          strcpy (environment, username);
          strcat (environment, p->env_name_str);
          strcat (environment, "R");
          if (reverse_servername == NULL && def_reverse_servername && *def_reverse_servername)
            {
              reverse_servername = alloc_and_copy (def_reverse_servername);
            }
          env_reverse = jl_connect_lang (environment, reverse_servername, db->lang, uumrc_name, yes_or_no_lock, print_msg_wait, WNN_TIMEOUT);
          if (env_reverse)
            {
              if (reverse_sticky)
                jl_env_sticky_e (env_reverse);
              else
                jl_env_un_sticky_e (env_reverse);
            }
        }
    }
  if (save_cur_reverse_env)
    c_c->cur_reverse_env = save_cur_reverse_env;
#ifdef  USING_XJUTIL
  if (!isstart_xjutil (db->lang))
    xjutil_start ();
#endif /* USING_XJUTIL */
  return (0);
}

int
init_xcvtkey ()
{
  char tmp_file[MAXPATHLEN];
  int ret;

  cvt_key_tbl_cnt = 0;
  /* Backward compatibility for cvt_meta and cvt_fun. */
  if (cvt_fun_file && *cvt_fun_file)
    {
      if ((ret = cvt_meta_and_fun_setup (cvt_fun_file, cvt_key_tbl, NULL)) == -1)
        {
          print_out1 ("I can't open cvt_fun file \"%s\".", cvt_fun_file);
          cvt_fun_file = NULL;
        }
      else
        {
          cvt_key_tbl_cnt = ret;
        }
    }
  if (cvt_meta_file && *cvt_meta_file)
    {
      if ((ret = cvt_meta_and_fun_setup (cvt_meta_file, cvt_key_tbl, "Meta")) == -1)
        {
          print_out1 ("I can't open cvt_meta file \"%s\".", cvt_meta_file);
          cvt_meta_file = NULL;
        }
      else
        {
          cvt_key_tbl_cnt = ret;
        }
    }

  if (cvt_key_file && *cvt_key_file)
    {
      if (cvt_key_setup (cvt_key_file) == -1)
        {
          print_out1 ("I can't open cvt_key file \"%s\", use default file.", cvt_key_file);
          cvt_key_file = NULL;
        }
    }
  if (cvt_key_file == NULL)
    {
      strcat (strcpy (tmp_file, LIBDIR), CVTKEYFILE);
      if (!(cvt_key_file = alloc_and_copy (tmp_file)))
        return (-1);
      if (cvt_key_setup (cvt_key_file) == -1)
        {
          print_out1 ("I can't open default cvt_key file \"%s\".\n I don't convert function keys.", cvt_key_file);
          Free (cvt_key_file);
          cvt_key_file = NULL;
        }
    }
  return (0);
}