Mercurial > freewnn
view Xwnmo/test/callback.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: callback.c,v 1.2 2001/06/14 18:16:10 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 * * 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: * */ /* * X11R5 Input Method Test Program * callback.c v 1.0 Tue Apr 23 13:33:07 JST 1991 */ /* * Author: Takashi Inoue OMRON Corporation * takashi@ari.ncl.omron.co.jp */ #include <stdio.h> #include "exvalue.h" #include "func.h" void geometry (ic, client_data, call_data) XIC ic; XPointer client_data; #ifdef SYSV caddr_t call_data; #else void *call_data; #endif { prstatus ("Calling function of \"GeometryCallback()\"..."); cls (prdisp); trnpebuf (call_data, "Geometry"); wlogcb (ic, client_data, call_data, "Geometry"); prstatus ("done."); } int pe_start (ic, client_data, call_data) XIC ic; XPointer client_data; #ifdef SYSV caddr_t call_data; #else void *call_data; #endif { int bufsize; prstatus ("Calling function of \"PreeditStartCallback()\"..."); cls (prdisp); bufsize = trnpebuf (call_data, "Start"); wlogcb (ic, client_data, call_data, "PreeditStart"); prstatus ("done."); return (bufsize); } void pe_done (ic, client_data, call_data) XIC ic; XPointer client_data; #ifdef SYSV caddr_t call_data; #else void *call_data; #endif { prstatus ("Calling function of \"PreeditDoneCallback()\"..."); cls (prdisp); trnpebuf (call_data, "Done"); wlogcb (ic, client_data, call_data, "PreeditDone"); prstatus ("done."); } void pe_draw (ic, client_data, call_data) XIC ic; XPointer client_data; XIMPreeditDrawCallbackStruct *call_data; { prstatus ("Calling function of \"PreeditDrawCallback()\"..."); cls (prdisp); trnpebuf (call_data, "Draw"); wlogcb (ic, client_data, call_data, "PreeditDraw"); prstatus ("done."); } void pe_caret (ic, client_data, call_data) XIC ic; XPointer client_data; XIMPreeditCaretCallbackStruct *call_data; { char *direction; char *style; prstatus ("Calling function of \"PreeditCaretCallback()\"..."); cls (prdisp); prprint ("Valuables of \"PreeditCaretCallback()\"\n\n"); chgcaretval (call_data, &direction, &style); prcaret (call_data->position, direction, style); wlogcb (ic, client_data, call_data, "PreeditCaret"); prstatus ("done."); } void st_start (ic, client_data, call_data) XIC ic; XPointer client_data; #ifdef SYSV caddr_t call_data; #else void *call_data; #endif { prstatus ("Calling function of \"StatusStartCallback()\"..."); cls (prdisp); wlogcb (ic, client_data, call_data, "StatusStart"); prstatus ("done."); } void st_done (ic, client_data, call_data) XIC ic; XPointer client_data; #ifdef SYSV caddr_t call_data; #else void *call_data; #endif { prstatus ("Calling function of \"StatusDoneCallback()\"..."); cls (prdisp); wlogcb (ic, client_data, call_data, "StatusDone"); prstatus ("done."); } void st_draw (ic, client_data, call_data) XIC ic; XPointer client_data; XIMStatusDrawCallbackStruct *call_data; { prstatus ("Calling function of \"StatusDrawCallback()\"..."); cls (prdisp); if (call_data->type == XIMTextType) { if (call_data->data.text->encoding_is_wchar == True) { (XwcDrawImageString (dpy, window1.win, fontset[0], gc, WIN_ITV * 2 + NW_WIDTH, CALCY (W1_HEIGHT, 0), call_data->data.text->string.wide_char, call_data->data.text->length)); } else { (XmbDrawImageString (dpy, window1.win, fontset[0], gc, WIN_ITV * 2 + NW_WIDTH, CALCY (W1_HEIGHT, 0), call_data->data.text->string.multi_byte, call_data->data.text->length)); } } wlogcb (ic, client_data, call_data, "StatusDraw"); prstatus ("done."); } void wlogcb (ic, client_data, call_data, cat) XIC ic; XPointer client_data; #ifdef SYSV caddr_t call_data; #else void *call_data; #endif char *cat; { XIMPreeditDrawCallbackStruct *pedcd; XIMPreeditCaretCallbackStruct *peccd; XIMStatusDrawCallbackStruct *stdcd; char *direction; char *style; fprintf (icfp, "\nFunction \"%sCallback\" has just called.\n", cat); fprintf (icfp, "1. ic : 0x%-18X\n", ic); fprintf (icfp, "2. client_data : 0x%-18X\n", client_data); if ((!strcmp (cat, "Geometry")) || (!strcmp (cat, "PreeditStart")) || (!strcmp (cat, "PreeditDone")) || (!strcmp (cat, "StatusStart")) || (!strcmp (cat, "StatusDone"))) { fprintf (icfp, "3. call_data : 0x%-18X\n", call_data); } else if (!strcmp (cat, "PreeditDraw")) { pedcd = (XIMPreeditDrawCallbackStruct *) call_data; fprintf (icfp, "3. call_data\n"); fprintf (icfp, " 1. caret : %-20d\n", pedcd->caret); fprintf (icfp, " 2. chg_first : %-20d\n", pedcd->chg_first); fprintf (icfp, " 3. chg_length : %-20d\n", pedcd->chg_length); fprintf (icfp, " 4. text\n"); wlogtext (pedcd->text); } else if (!strcmp (cat, "PreeditCaret")) { peccd = (XIMPreeditCaretCallbackStruct *) call_data; chgcaretval (peccd, &direction, &style); fprintf (icfp, "3. call_data\n"); fprintf (icfp, " 1. position : %-20d\n", peccd->position); fprintf (icfp, " 2. direction : %-20s\n", direction); fprintf (icfp, " 3. style : %-20s\n", style); } else if (!strcmp (cat, "StatusDraw")) { stdcd = (XIMStatusDrawCallbackStruct *) call_data; fprintf (icfp, "3. call_data\n"); fprintf (icfp, " 1. type : %-20s\n", ((stdcd->type == XIMTextType) ? "XIMTextType" : "XIMBitmapType")); if (stdcd->type == XIMTextType) { fprintf (icfp, " 2. text\n"); wlogtext (stdcd->data.text); } else { fprintf (icfp, " 2. bitmap : 0x%-18x\n", stdcd->data.bitmap); } } } void wlogtext (text) XIMText *text; { int cnt; /* CouNTer */ fprintf (icfp, " 1. length : %-20d\n", text->length); fprintf (icfp, " 2. feedback : 0x%-18x\n", *text->feedback); fprintf (icfp, " 3. encording_is_wchar : %d (%s)\n", text->encoding_is_wchar, ((text->encoding_is_wchar == True) ? "True" : "False")); if (text->length == 0) { fprintf (icfp, " 4. character code [%s] : None\n", ((text->encoding_is_wchar == True) ? "wc" : "mb")); } else { for (cnt = 0; cnt < text->length; cnt++) { fprintf (icfp, " 4. character code [%s] : 0x%-18X\n", ((text->encoding_is_wchar == True) ? "wc" : "mb"), ((text->encoding_is_wchar == True) ? text->string.wide_char[cnt] : text->string.multi_byte[cnt])); } } fprintf (icfp, "\n"); } void chgcaretval (call_data, direction, style) XIMPreeditCaretCallbackStruct *call_data; char **direction; char **style; { switch (call_data->direction) { case XIMForwardChar: *direction = "XIMForwardChar"; break; case XIMBackwardChar: *direction = "XIMBackwardChar"; break; case XIMForwardWord: *direction = "XIMForwardWord"; break; case XIMBackwardWord: *direction = "XIMBackwardWord"; break; case XIMCaretUp: *direction = "XIMCaretUp"; break; case XIMCaretDown: *direction = "XIMCaretDown"; break; case XIMNextLine: *direction = "XIMNextLine"; break; case XIMPreviousLine: *direction = "XIMPreviousLine"; break; case XIMLineStart: *direction = "XIMLineStart"; break; case XIMLineEnd: *direction = "XIMLineEend"; break; case XIMAbsolutePosition: *direction = "XIMAbsolutePosition"; break; case XIMDontChange: *direction = "XIMDontChange"; break; } switch (call_data->style) { case XIMIsInvisible: *style = "XIMIsInvisible"; break; case XIMIsPrimary: *style = "XIMIsPrimary"; break; case XIMIsSecondary: *style = "XIMIsSecondary"; break; } } int trnpebuf (call_data, cat) #ifdef SYSV caddr_t call_data; #else void *call_data; #endif char *cat; { static int cnt; /* CouNTer */ static int cntwk; /* CouNTer for WorK buffer */ static wchar_t buf_pe[MAX_BUF]; /* BUFfer for PreEdit */ static wchar_t tmp_tx[MAX_BUF]; /* TeMPorary TeXt */ static wchar_t buf_wk[MAX_BUF]; /* BUFfer for WorK */ XIMPreeditDrawCallbackStruct *pedcd; /* PreEditDrawCallbackData */ if ((!strcmp (cat, "Start")) || (!strcmp (cat, "Done"))) { bzero (buf_pe, (sizeof (wchar_t)) * MAX_BUF); bzero (tmp_tx, (sizeof (wchar_t)) * MAX_BUF); bzero (buf_wk, (sizeof (wchar_t)) * MAX_BUF); cnt = 0; if (!strcmp (cat, "Start")) { return (MAX_BUF); } } else if (!strcmp (cat, "Draw")) { pedcd = (XIMPreeditDrawCallbackStruct *) call_data; for (cnt = 0; buf_pe[cnt] != 0; cnt++) ; cntwk = cnt - ((pedcd->chg_first) + (pedcd->chg_length)); /* bzero(tmp_tx, (sizeof(wchar_t)) * MAX_BUF); bzero(buf_wk, (sizeof(wchar_t)) * MAX_BUF); */ bcopy (&buf_pe[(pedcd->chg_first) + (pedcd->chg_length)], buf_wk, sizeof (wchar_t) * cntwk); bzero (&buf_pe[pedcd->chg_first], sizeof (wchar_t) * (cnt - pedcd->chg_first)); cnt = pedcd->chg_first; if (pedcd->text->length > 0) { if (pedcd->text->encoding_is_wchar == False) { /* transaction of translation */ } else { bcopy (pedcd->text->string.wide_char, tmp_tx, sizeof (wchar_t) * (pedcd->text->length)); } bcopy (tmp_tx, &buf_pe[pedcd->chg_first], sizeof (wchar_t) * (pedcd->text->length)); cnt += pedcd->text->length; } bcopy (buf_wk, &buf_pe[cnt], sizeof (wchar_t) * cntwk); cnt += cntwk; } XClearArea (dpy, window1.win, 0, 0, 0, 80, True); XFlush (dpy); if (cnt > 0) { XwcDrawImageString (dpy, window1.win, fontset[0], gc, 0, 20, buf_pe, cnt); } XFlush (dpy); return (0); }