Mercurial > freewnn
view Xwnmo/xwnmo/readximrc.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: readximrc.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 OMRON Corporation. 1987, 1988, 1989, 1990, 1991, 1992, 1999 * 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 "commonhd.h" #include "sdefine.h" #include "xim.h" #include "sheader.h" #include "config.h" #include "ext.h" /** Set parameter by reading ximrc file */ static int read_xim_rcfile (filenm, expand_filenm) char *filenm; int (*expand_filenm) (); { char buf[BUFSIZ]; char entrynm[64]; char s[2][MAXPATHLEN + 1]; int n; int error; FILE *fp; XIMLangDataBase *ld; extern int fclose (); if ((fp = fopen (filenm, "r")) == NULL) { return (-1); } while (fgets (buf, BUFSIZ, fp)) { if (comment_char (*buf) || (n = sscanf (buf, "%s %s %s", entrynm, s[0], s[1])) < 1) { continue; } error = 0; switch (*(entrynm + 3)) { case 'l': if (!strcmp (entrynm, "preloadrkfile")) { if (n > 1) { register ReadRkfileRec *rr, *p, *prev; if (!(rr = (ReadRkfileList) Malloc (sizeof (ReadRkfileRec)))) goto CLOSE_RET; if (read_rkfile_list == NULL) { read_rkfile_list = rr; } else { for (p = read_rkfile_list, prev = NULL; p != NULL; prev = p, p = p->next); prev->next = rr; } if (!(rr->name = alloc_and_copy (s[0]))) goto CLOSE_RET; rr->next = NULL; } else error = 1; } else error = 2; break; case 'u': if (!strcmp (entrynm, "setuumrc")) { if (n > 2) { for (ld = language_db; ld; ld = ld->next) { if (!strcmp (ld->lang, s[0])) break; } if (!ld) { print_out2 ("In ximrc \"%s\", I don't support the lang \"%s\".", filenm, s[0]); } if ((*expand_filenm) (s[1]) != 0) { print_out1 ("In ximrc \"%s\", I could not expand %s.", s[1]); } if (!(ld->uumrc_name = alloc_and_copy (s[1]))) goto CLOSE_RET; if (rkfile_defined_by_option && cur_lang == ld) { if (!(ld->rkfile_name = alloc_and_copy (root_rkfilename))) goto CLOSE_RET; } } else error = 1; } else error = 2; break; case 'b': if (!strcmp (entrynm, "setbackspacechar")) { if (n > 1) { rubout_code = s[0][0]; } else error = 1; } else error = 2; break; default: error = 2; break; } if (error == 1) { print_out2 ("In ximrc file \"%s\", I found a unknown entry name \"%s\".", filenm, entrynm); } else if (error == 2) { print_out2 ("In ximrc file \"%s\", I found a Illegal line %d.", filenm, entrynm); } } fclose (fp); return (0); CLOSE_RET: fclose (fp); return (-2); } int read_ximrc () { register char *n; char tmp_xim_rc_file[MAXPATHLEN + 1]; register int ret; extern char *getenv (); if (ximrc_file) { n = ximrc_file; } else { n = getenv (XIM_RCENV); } if (n && *n) { strcpy (tmp_xim_rc_file, n); if ((*expand_expr) (tmp_xim_rc_file) != 0) { print_out1 ("I could not expand %s.", tmp_xim_rc_file); } if ((ret = read_xim_rcfile (tmp_xim_rc_file, expand_expr)) == 0) { goto OK_RET; } else if (ret == -2) return (-1); print_out1 ("Can't open a specified ximrc \"%s\".", tmp_xim_rc_file); ximrc_file = NULL; } if ((n = getenv ("HOME")) && *n) { strcat (strcpy (tmp_xim_rc_file, n), USR_XIMRC); if ((ret = read_xim_rcfile (tmp_xim_rc_file, expand_expr)) == 0) { goto OK_RET; } else if (ret == -2) return (-1); ximrc_file = NULL; } strcat (strcpy (tmp_xim_rc_file, LIBDIR), XIMRCFILE); if (read_xim_rcfile (tmp_xim_rc_file, expand_expr) >= 0) { goto OK_RET; } print_out1 ("Can't open a default ximrc file \"%s\".", tmp_xim_rc_file); ximrc_file = NULL; return (-1); OK_RET: if (!(ximrc_file = alloc_and_copy (tmp_xim_rc_file))) return (-1); return (0); } static void default_set_of_ld (ld) register XIMLangDataBase *ld; { ld->read = 0; ld->uumkey_name = NULL; ld->host_name = NULL; ld->rev_host_name = NULL; ld->rk_table = NULL; ld->jishopath = NULL; ld->hindopath = NULL; ld->fuzokugopath = NULL; ld->h_off_def = 0; ld->e_delete = 1; ld->s_ascii_char_def = 0; ld->m_chg = 0; ld->m_bunsetsu = 0; ld->m_history = 0; ld->t_comment = 0; ld->h_on_kuten = 0; #ifdef USING_XJUTIL ld->xjutil_act = 0; ld->xjutil_id = (Window) 0; ld->xjutil_pid = 0; ld->xjutil_use = NULL; #endif /* USING_XJUTIL */ } int read_ximconf () { char buf[BUFSIZ]; char filenm[MAXPATHLEN + 1]; char s[6][128]; register int n, i, lc_cnt = 0, all_size; FILE *fp; register char *p, *ptr, *ret; FunctionTable *f; XIMLangDataBase *ld; XIMLcNameRec *lnl, *lnl_p; strcpy (filenm, LIBDIR); strcat (filenm, XIM_CONFIG_FILE); if ((fp = fopen (filenm, "r")) == NULL) { print_out1 ("Can't open xim.conf \"%s\".", filenm); return (-1); } while (1) { ptr = buf; while (1) { if (!(ret = fgets (ptr, BUFSIZ, fp))) { break; } if (*ptr == '\n') continue; if ((i = strlen (ptr)) > 1 && ptr[i - 2] == '\\') { ptr += i - 2; continue; } break; } if (!ret) break; if (comment_char (*buf) || (n = sscanf (buf, "%s %s %s %s %s %s", s[0], s[1], s[2], s[3], s[4], s[5])) < 1) { continue; } if (!strcmp (s[0], "setdefaultlocale")) { if (n < 2) goto ARG_ERR; if (!(def_locale = alloc_and_copy (s[1]))) goto CLOSE_RET; } else if (!strcmp (s[0], "setworldlocale")) { if (n < 2) goto ARG_ERR; if (!(world_locale = alloc_and_copy (s[1]))) goto CLOSE_RET; } else { if (n < 6) goto ARG_ERR; all_size = sizeof (XIMLangDataBase) + strlen (s[0]) + strlen (s[1]) + strlen (s[2]) + 3; if (!(p = (char *) Malloc (all_size))) { malloc_error ("allocation of the initial area"); goto CLOSE_RET; } bzero (p, all_size); ld = (XIMLangDataBase *) p; p += sizeof (XIMLangDataBase); strcpy (p, s[0]); ptr = p; lc_cnt = 0; do { if (lc_cnt) { *ptr++ = '\0'; } lc_cnt++; } while (*ptr && (ptr = index (ptr, '|'))); if (!(lnl_p = (XIMLcNameRec *) Malloc (sizeof (XIMLcNameRec) * lc_cnt))) { malloc_error ("allocation of the initial area"); goto CLOSE_RET; } ptr = p; for (i = 0; i < lc_cnt; i++) { for (lnl = lc_name_list; lnl; lnl = lnl->next) { if (!strcmp (lnl->lc_name, ptr)) { print_out2 ("In xim.conf file \"%s\", locale \"%s\" is redeclared.", filenm, ptr); goto CLOSE_RET; } } lnl_p[i].lc_name = ptr; ptr += strlen (ptr) + 1; lnl_p[i].lang_db = ld; if (i != 0) { lnl_p[i].next = &lnl_p[i - 1]; } } lnl_p[0].next = lc_name_list; lc_name_list = &lnl_p[lc_cnt - 1]; p += strlen (s[0]) + 1; ld->lang = (char *) p; strcpy (ld->lang, s[1]); p += strlen (s[1]) + 1; ld->lc_name = (char *) p; strcpy (ld->lc_name, s[2]); if ((ld->cswidth_id = create_cswidth (s[3])) == 0) { print_out2 ("In xim.conf file \"%s\", \"%s\" is a bad string for CSWIDTH.", filenm, s[3]); goto CLOSE_RET; } if (!strcmp (s[4], "True") || !strcmp (s[4], "TRUE")) { ld->connect_serv = True; } else { ld->connect_serv = False; } ld->f_table = (FunctionTable *) NULL; for (f = function_db, i = 0; f[i].name; i++) { if (!strcmp (s[5], f[i].name)) { ld->f_table = &(f[i]); break; } } if (!ld->f_table) { print_out2 ("In xim.conf file \"%s\", \"%s\" is a bad string for functions.", filenm, s[5]); goto CLOSE_RET; } if (language_db) { ld->next = language_db; } else { ld->next = NULL; } language_db = ld; default_set_of_ld (ld); } } fclose (fp); if (!def_locale) if (!(def_locale = alloc_and_copy (DEFAULT_LANG))) return (-1); if (!world_locale) if (!(world_locale = alloc_and_copy (DEFAULT_WORLD_LOCALE))) return (-1); return (0); ARG_ERR: print_out2 ("In xim.conf file \"%s\", too few arguments at line \"%s\".", filenm, buf); CLOSE_RET: fclose (fp); return (-1); }