Mercurial > freewnn
view Xwnmo/xjutil/xselectele.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: xselectele.c,v 1.2 2001/06/14 18:16:13 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 */ #define DD_MAX 512 #include <stdio.h> #include "jslib.h" #include "commonhd.h" #include "sdefine.h" #include "xjutil.h" #include "sxheader.h" #include "rk_spclval.h" #include "rk_fundecl.h" #include "xext.h" #define printh(mm)\ if(state == 0){\ printf("%c.",((mm - dd[cc]) > 9)? mm - dd[cc] - 10 + 'A':mm - dd[cc] + '0');\ printf(data[mm]);\ }else{\ printf("%c.",((mm > 9)? mm - 10 + 'A':mm + '0'));\ printf(data[mm]);} #define kouho_len(x) (strlen(x) + 4) static int cc; /* ima no gamen */ static int kosuu; /* kosuu of elements */ extern hilited_item; extern max_line; int xw_select_one_element_call (c, kosuu1, init, title) char **c; int kosuu1; int init; char *title; { int in, ret; for (;;) { if ((ret = xw_select_one_element (c, kosuu1, init, title, SENTAKU, main_table[4], in)) != BUFFER_IN_CONT) return (ret); in = keyin (); } } int xw_select_one_element_keytable (c, kosuu1, init, title, bcnt, btable_t, b_tbl, key_tbl, comment) char **c; int kosuu1; int init; char *title; int bcnt; char *btable_t[]; int (**b_tbl) (); int (**key_tbl) (); char *comment; { register int i; int d; unsigned int c1; int ret; kosuu = kosuu1; init_ichiran (c, kosuu1, init, title, (unsigned char *) "", (unsigned char *) "", comment, 0, SENTAKU); for (;;) { TOP: xjutil->sel_ret = -1; c1 = keyin (); if (xjutil->sel_ret == -2) { end_ichiran (); romkan_clear (); return (-1); } else if (xjutil->sel_ret != -1) { d = find_hilite (); xjutil->sel_ret = -1; if (d < 0 || d > kosuu) { ring_bell (); continue; } } else { if ((c1 < 256) && (key_tbl[c1] != NULL)) { cc = d = find_hilite (); if (d < 0 || d > kosuu) { ring_bell (); continue; } for (i = 0; i < bcnt; i++) { if (key_tbl[c1] == b_tbl[i]) { lock_ichiran (); break; } } ret = (*key_tbl[c1]) (); unlock_ichiran (); if (ret == -1) { end_ichiran (); romkan_clear (); return (-1); } else if (ret == 1) { end_ichiran (); romkan_clear (); return (0); } else { continue; } } else { ring_bell (); continue; } } romkan_clear (); if (!bcnt) { end_ichiran (); return (d); } else { cc = d; lock_ichiran (); } init_keytable (bcnt, btable_t); for (;;) { c1 = keyin (); if (xjutil->sel_ret == -2) { end_ichiran (); end_keytable (); romkan_clear (); return (-1); } else if (xjutil->sel_ret != -1) { d = xjutil->sel_ret; xjutil->sel_ret = -1; if ((d < bcnt) && (b_tbl[d] != NULL)) { end_keytable (); if ((ret = (*b_tbl[d]) ()) == 1) { end_ichiran (); romkan_clear (); return (0); } unlock_ichiran (); goto TOP; } else { ring_bell (); } } else { if ((c1 < 256) && (key_tbl[c1] != NULL)) { end_keytable (); if ((ret = (*key_tbl[c1]) ()) == 1) { end_ichiran (); romkan_clear (); return (0); } unlock_ichiran (); goto TOP; } else { ring_bell (); xjutil->sel_ret = -1; continue; } } } romkan_clear (); } } /* * * Functions Called during select element (dictionaries). * */ /* jishodel for kensaku */ int kdicdel () { char buf[512]; sprintf (buf, "%s %s %s", msg_get (cd, 77, default_message[77], xjutil->lang), dicinfo[cc].fname, msg_get (cd, 78, default_message[78], xjutil->lang)); if (yes_or_no (buf) == 1) { if (dic_delete_e (cur_env, dicinfo[cc].dic_no) == -1) { errorkeyin (); return (0); } return (1); } return (0); } int kdicuse () { char buf[512]; if (dicinfo[cc].enablef) { sprintf (buf, "%s %s %s", msg_get (cd, 77, default_message[77], xjutil->lang), dicinfo[cc].fname, msg_get (cd, 79, default_message[89], xjutil->lang)); } else { sprintf (buf, "%s %s %s", msg_get (cd, 77, default_message[77], xjutil->lang), dicinfo[cc].fname, msg_get (cd, 80, default_message[80], xjutil->lang)); } if (yes_or_no (buf) == 1) { if (js_dic_use (cur_env, dicinfo[cc].dic_no, !dicinfo[cc].enablef) == -1) { if_dead_disconnect (cur_env, -1); errorkeyin (); return (0); } return (1); } return (0); } int kdiccom () { w_char com[512]; WNN_DIC_INFO dic; WNN_FILE_INFO_STRUCT file; char *mes[1]; com[0] = 0; mes[0] = msg_get (cd, 81, default_message[81], xjutil->lang); init_jutil (msg_get (cd, 39, default_message[39], xjutil->lang), msg_get (cd, 8, default_message[8], xjutil->lang), 1, &mes, NULL); cur_text->max_pos = 127; clr_line_all (); throw_col (0); kk_cursor_normal (); if (kana_in (UNDER_LINE_MODE, com, 512) == -1) { kk_cursor_invisible (); end_jutil (); return (0); } kk_cursor_invisible (); end_jutil (); if (js_dic_info (cur_env, dicinfo[cc].dic_no, &dic) < 0) { if_dead_disconnect (cur_env, -1); return (0); } if (js_file_info (cur_env, dic.body, &file) < 0) { if_dead_disconnect (cur_env, -1); return (0); } if (js_file_comment_set (cur_env, file.fid, com) == -1) { if_dead_disconnect (cur_env, -1); errorkeyin (); return (0); } return (1); } /* * * Functions Called during select element (dic_entries). * */ /* Defined in kensaku.c */ extern struct wnn_jdata *word_searched; extern int del_point, ima_point, hindo_point, com_point, max_c_len; int kworddel () { int type; if (cur_root->ichi->buf[cc][del_point] == 'D') { change_ichi_buf (cc, del_point, " "); return (0); } type = dicinfo[find_dic_by_no (word_searched[cc].dic_no)].type; if (type != WNN_UD_DICT && type != WNN_REV_DICT && type != CWNN_REV_DICT) { print_msg_getc (msg_get (cd, 82, default_message[82], xjutil->lang), NULL, NULL, NULL); return (0); } if (dicinfo[find_dic_by_no (word_searched[cc].dic_no)].rw == WNN_DIC_RDONLY) { print_msg_getc (msg_get (cd, 83, default_message[83], xjutil->lang), NULL, NULL, NULL); return (0); } change_ichi_buf (cc, del_point, "D"); return (0); } int kworddel_op () { register int i; char buf[512]; Ichiran *ichi = cur_root->ichi; for (i = 0; i < ichi->kosuu_all; i++) { if (ichi->buf[i][del_point] != 'D') continue; strcpy (buf, msg_get (cd, 84, default_message[84], xjutil->lang)); sStrcpy (buf + strlen (buf), word_searched[i].kanji); sprintf (buf + strlen (buf), "%s", msg_get (cd, 85, default_message[85], xjutil->lang)); if (yes_or_no (buf) == 1) { if (js_word_delete (cur_env, word_searched[i].dic_no, word_searched[i].serial) == -1) { if_dead_disconnect (cur_env, -1); errorkeyin (); } } } return (1); } int kwordcom () { w_char com[512]; char buf[512]; int type, len; char *mes[1]; type = dicinfo[find_dic_by_no (word_searched[cc].dic_no)].type; if (type != WNN_UD_DICT && type != WNN_REV_DICT && type != CWNN_REV_DICT) { print_msg_getc (msg_get (cd, 89, default_message[89], xjutil->lang), NULL, NULL, NULL); return (0); } if (dicinfo[find_dic_by_no (word_searched[cc].dic_no)].rw == WNN_DIC_RDONLY) { print_msg_getc (msg_get (cd, 90, default_message[90], xjutil->lang), NULL, NULL, NULL); return (0); } com[0] = 0; mes[0] = msg_get (cd, 81, default_message[81], xjutil->lang); init_jutil (msg_get (cd, 39, default_message[39], xjutil->lang), msg_get (cd, 8, default_message[8], xjutil->lang), 1, &mes, NULL); cur_text->max_pos = 127; clr_line_all (); throw_col (0); kk_cursor_normal (); if (kana_in (UNDER_LINE_MODE, com, 512) == -1) { kk_cursor_invisible (); end_jutil (); return (0); } kk_cursor_invisible (); end_jutil (); if (js_word_comment_set (cur_env, word_searched[cc].dic_no, word_searched[cc].serial, com) == -1) { if_dead_disconnect (cur_env, -1); errorkeyin (); return (0); } bzero (buf, sizeof (buf)); if (Strlen (com)) { strcpy (buf, "{"); sStrcpy (buf + strlen (buf), com); strcat (buf, "} "); } if (strlen (buf) > max_c_len) { len = strlen (buf) - max_c_len; insert_space_in_ichi_buf (com_point + max_c_len, len); max_c_len = strlen (buf); ima_point += len; hindo_point += len; } else { fill_space (buf, max_c_len); } change_ichi_buf (cc, com_point, buf); return (0); } static int call_hindo_set (ima, hindo) int ima; int hindo; { if (js_hindo_set (cur_env, word_searched[cc].dic_no, word_searched[cc].serial, ima, hindo) == -1) { if_dead_disconnect (cur_env, -1); errorkeyin (); return (0); } return (1); } int kwordima () { if (word_searched[cc].ima) { if (call_hindo_set (WNN_IMA_OFF, WNN_HINDO_NOP)) { change_ichi_buf (cc, ima_point, " "); word_searched[cc].ima = 0; } } else { if (call_hindo_set (WNN_IMA_ON, WNN_HINDO_NOP)) { change_ichi_buf (cc, ima_point, "*"); word_searched[cc].ima = 1; } } return (0); } int kworduse () { int ima, hindo; char buf[32]; extern int wnn_word_use_initial_hindo; if (word_searched[cc].hindo != -1) { if (call_hindo_set (WNN_HINDO_NOP, WNN_ENTRY_NO_USE)) { change_ichi_buf (cc, ima_point, "---- "); word_searched[cc].hindo = -1; } } else { ima = wnn_word_use_initial_hindo & 0x80; hindo = wnn_word_use_initial_hindo & 0x7f; if (call_hindo_set ((ima ? WNN_IMA_ON : WNN_IMA_OFF), hindo)) { sprintf (buf, "%c%-3d ", (ima ? '*' : ' '), hindo); change_ichi_buf (cc, ima_point, buf); word_searched[cc].hindo = hindo; word_searched[cc].ima = ima; } } return (0); } int kwordhindo () { int cur_hindo; char *mes[1]; w_char kana_buf[512]; char st[32]; char buf[32]; int newhindo; char message[80]; if (dicinfo[find_dic_by_no (word_searched[cc].dic_no)].hindo_rw == WNN_DIC_RDONLY) { print_msg_getc (msg_get (cd, 118, default_message[118], xjutil->lang), NULL, NULL, NULL); return (0); } cur_hindo = word_searched[cc].hindo; sprintf (message, "%s %d %s", msg_get (cd, 119, default_message[119], xjutil->lang), cur_hindo, msg_get (cd, 32, default_message[32], xjutil->lang)); mes[0] = msg_get (cd, 33, default_message[33], xjutil->lang); init_jutil (message, msg_get (cd, 8, default_message[8], xjutil->lang), 1, &mes, NULL); Retry: cur_text->max_pos = 127; clr_line_all (); throw_col (0); kk_cursor_normal (); kana_buf[0] = 0; if (kana_in (UNDER_LINE_MODE, kana_buf, 512) == -1) { kk_cursor_invisible (); end_jutil (); return (0); } kk_cursor_invisible (); if (sStrcpy_and_ck (st, kana_buf) || sscanf (st, "%d", &newhindo) <= 0) { print_msg_getc ("%s", msg_get (cd, 34, default_message[34], xjutil->lang), NULL, NULL); goto Retry; } else if (newhindo < 0) { print_msg_getc ("%s", msg_get (cd, 35, default_message[35], xjutil->lang), NULL, NULL); goto Retry; } end_jutil (); if (call_hindo_set (WNN_HINDO_NOP, newhindo)) { sprintf (buf, "%-3d ", newhindo); change_ichi_buf (cc, hindo_point, buf); word_searched[cc].hindo = newhindo; } return (0); } /* Local Variables: eval: (setq kanji-flag t) eval: (setq kanji-fileio-code 0) eval: (mode-line-kanji-code-update) End: */