Mercurial > freewnn
view Xwnmo/xwnmo/keyin.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: keyin.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 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 "sdefine.h" #include "xim.h" #include "sheader.h" #include "proto.h" #include "ext.h" static int read_xevent (ev) XEvent *ev; { ximEventReq req; if (EACH_REQUEST (&req, sz_ximEventReq) == -1) return (-1); if (_ReadFromClient (ev, sizeof (XEvent)) == -1) return (-1); if (need_byteswap () == True) { byteswap_xevent (ev); } xim->sel_button = '\0'; return (0); } static int check_cur_input (w) Window w; { if (cur_input == NULL) { #ifdef XJPLIB if (XJp_check_cur_input (w) == 0) return (0); #endif /* XJPLIB */ } else { if (w == cur_input->w) return (0); } if (cur_p && w == cur_p->yes_no->w) return (0); return (1); } static int cur_cl_set (set_window) Window set_window; { register XIMClientRec *xc = NULL; register XIMInputRec *xi; for (xi = input_list; xi != NULL; xi = xi->next) { if (xi->w == set_window) { xc = xi->pclient; break; } } #ifdef XJPLIB if (xc) { XJp_cur_cl_set (0); } else { xc = XJp_cur_cl_set (set_window); } #endif /* XJPLIB */ if (xc) { cur_x = xc; if (IsPreeditNothing (cur_x)) { cur_p = cur_x->root_pointer->ximclient; cur_lang = cur_p->cur_xl->lang_db; c_c = cur_p->cur_xl->w_c; } else { cur_p = cur_x; cur_lang = cur_p->cur_xl->lang_db; c_c = cur_x->cur_xl->w_c; } cur_rk = c_c->rk; cur_rk_table = cur_rk->rk_table; cur_input = xi; set_cswidth (cur_lang->cswidth_id); return (0); } for (xc = ximclient_list; xc; xc = xc->next) { if (!IsPreeditNothing (xc) && set_window == xc->yes_no->w) { cur_p = xc; cur_lang = cur_p->cur_xl->lang_db; c_c = cur_p->cur_xl->w_c; cur_rk = c_c->rk; cur_rk_table = cur_rk->rk_table; set_cswidth (cur_lang->cswidth_id); return (0); } } if (xim->j_c && (set_window == xim->cur_j_c_root->ichi->w || set_window == xim->cur_j_c_root->inspect->w)) { cur_p = xim->j_c; cur_lang = cur_p->cur_xl->lang_db; c_c = cur_p->cur_xl->w_c; cur_rk = c_c->rk; cur_rk_table = cur_rk->rk_table; set_cswidth (cur_lang->cswidth_id); return (0); } return (-1); } static XComposeStatus compose_status = { NULL, 0 }; int key_input (buff, ev) register int *buff; register XEvent *ev; { unsigned char strbuf[512]; KeySym keysym; int nbytes; int ck; register int i; if (check_cur_input (ev->xkey.window)) { if (cur_cl_set (ev->xkey.window) != 0) { return (-1); } } if (dpy != ev->xkey.display) ev->xkey.display = dpy; #ifdef CALLBACKS if (IsPreeditCallbacks (cur_x) && cur_x->cb_redraw_needed) { *buff++ = 0; return (1); } #endif /* CALLBACKS */ #ifdef USING_XJUTIL if (cur_p->cur_xl->working_xjutil) { xjutil_send_key_event (ev); return (-1); } #endif /* USING_XJUTIL */ nbytes = XLookupString ((XKeyEvent *) ev, strbuf, 512, &keysym, &compose_status); #if defined(XJPLIB) && defined(XJPLIB_DIRECT) XJp_save_sockbuf (nbytes, strbuf, keysym); #endif /* defined(XJPLIB) && defined(XJPLIB_DIRECT) */ if ((ck = cvt_key_fun (keysym, ev->xkey.state)) >= 0) { #ifdef XJPLIB XJp_check_save_event (ev, 0); #endif /* XJPLIB */ *buff++ = ck; return (1); } if ((keysym & 0xff00) == 0xff00) { /* Function Key */ if (nbytes > 0) { #ifdef XJPLIB XJp_check_save_event (ev, 1); #endif /* XJPLIB */ for (i = 0; i < nbytes; i++) { *buff++ = (int) strbuf[i]; } return (nbytes); } else { #ifdef XJPLIB XJp_check_send_cl_key (ev); #endif /* XJPLIB */ return (0); } } if (ev->xkey.state & ControlMask) { /* Control Key */ if (*strbuf >= 0x20) { #ifdef XJPLIB XJp_check_send_cl_key (ev); #endif /* XJPLIB */ return (-1); } else if (*strbuf == 0x0) { #ifdef XJPLIB XJp_check_save_event (ev, 0); #endif /* XJPLIB */ *buff++ = (int) *strbuf; return (1); } else if (*strbuf <= 0x1f) { #ifdef XJPLIB XJp_check_save_event (ev, 0); #endif /* XJPLIB */ *buff++ = (int) *strbuf; return (1); } } if ((keysym >= 0x4a0) && (keysym <= 0x4df)) { /* Kana Key */ #ifdef XJPLIB XJp_check_save_event (ev, 0); #endif /* XJPLIB */ *buff++ = (int) ((SS2 << 8) | (keysym & 0xff)); return (1); } else if ((keysym < 0x100) && (keysym > 0)) { #ifdef XJPLIB XJp_check_save_event (ev, 1); #endif /* XJPLIB */ if (nbytes <= 0) { nbytes = -1; } for (i = 0; i < nbytes; i++) { *buff++ = (int) strbuf[i]; } return (nbytes); } return (-1); } int ifempty () { if (cur_p->cur_xl->max_pos == 0) { return (1); } else { return (0); } } int RequestDispatch () { int buff[32], in; XEvent event; int ret = 0; register int i, n_bytes; switch (read_requestheader ()) { case XIM_Event: if (read_xevent (&event) == -1) { break; } ret = key_input (buff, &event); if (ret == 0) { send_nofilter (); } else if (ret > 0) { for (i = 0; i < ret;) { n_bytes = get_cswidth_by_char (in = buff[i++]); for (; n_bytes > 1 && i < ret; n_bytes--, i++) { in = (in << 8) + buff[i]; } in_put (in); } } send_end (); break; case XIM_GetIM: GetIM (); break; case XIM_CreateIC: CreateIC (); break; case XIM_ChangeIC: ChangeIC (); break; case XIM_GetIC: GetIC (); break; case XIM_DestroyIC: DestroyIC (); break; case XIM_SetICFocus: SetICFocus (); break; case XIM_UnsetICFocus: UnsetICFocus (); break; case XIM_ResetIC: ResetIC (); break; #ifdef SPOT case XIM_ChangeSpot: ChangeSpot (); break; #endif /* SPOT */ } return (0); }