Mercurial > freewnn
view Xwnmo/test/chkic.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: chkic.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 * chkic.c v 1.0 Tue Mar 5 19:20:16 JST 1991 */ /* * Author: Takashi Inoue OMRON Corporation * takashi@ari.ncl.omron.co.jp * * Shoji kamada OMRON Corporation * kamada@ari.ncl.omron.co.jp * */ #include <stdio.h> #include "exvalue.h" #include "func.h" /* *INDENT-OFF* */ XIC createic (im, mode, lfdir, flag) /* check of XCreateIC */ XIM im; FLAG mode; char *lfdir; FLAG *flag; /* *INDENT-ON* */ { XIC ic; int cnt; XIC onmust (), onmay (), overmust (), overmay (), rootmust (), rootmay (); static CRICMF ftbl[MODENUM] = { {ONSP, onmust, onmay}, {OVERSP, overmust, overmay}, {OFFSP, offmust, offmay}, {ROOTW, rootmust, rootmay}, {NULL, NULL, NULL} }; for (cnt = 0; ftbl[cnt].mode != NULL; cnt++) { if (mode == ftbl[cnt].mode) { ic = (*ftbl[cnt].fmust) (im, lfdir, flag); if (ic == NULL) { return (ic); } ic = (*ftbl[cnt].fmay) (im, flag); return (ic); } } return (NULL); } /* *INDENT-OFF* */ XIC onmust (im, lfdir, flag) /* for ON-the-spot mode (MUST) */ XIM im; char *lfdir; FLAG *flag; /* *INDENT-ON* */ { XIC ic; static int cntlog = 1; char logfile[MAX_BUF]; int cnt; int sum; XIMStyle gistyle; CALLBACK gpec; CALLBACK gstc; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *von[ONMUST]; prmode ("X11R5 Input Method Test Program : <<on-the-spot mode>>"); prstatus ("Creating log file for ic..."); /* open log file for IC test */ sprintf (logfile, "%s/ticon.log%d", lfdir, cntlog); icfp = fopen (logfile, "w"); cntlog++; prstatus ("done."); prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (must) */ uistyle = (XIMPreeditCallbacks | XIMStatusCallbacks); /* initialize valuables */ upec.start.client_data = NULL; upec.start.callback = (XIMProc) pe_start; upec.done.client_data = NULL; upec.done.callback = (XIMProc) pe_done; upec.draw.client_data = NULL; upec.draw.callback = (XIMProc) pe_draw; upec.caret.client_data = NULL; upec.caret.callback = (XIMProc) pe_caret; ustc.start.client_data = NULL; ustc.start.callback = (XIMProc) st_start; ustc.done.client_data = NULL; ustc.done.callback = (XIMProc) st_done; ustc.draw.client_data = NULL; ustc.draw.callback = (XIMProc) st_draw; cpe_nelist = XVaCreateNestedList (DUMMY, XNPreeditStartCallback, &upec.start, XNPreeditDoneCallback, &upec.done, XNPreeditDrawCallback, &upec.draw, XNPreeditCaretCallback, &upec.caret, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNStatusStartCallback, &ustc.start, XNStatusDoneCallback, &ustc.done, XNStatusDrawCallback, &ustc.draw, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (must) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (must) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNPreeditStartCallback, &gpec.start, XNPreeditDoneCallback, &gpec.done, XNPreeditDrawCallback, &gpec.draw, XNPreeditCaretCallback, &gpec.caret, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNStatusStartCallback, &gstc.start, XNStatusDoneCallback, &gstc.done, XNStatusDrawCallback, &gstc.draw, NULL); prstatus ("done."); prstatus ("Test of GetICValues()..."); /* test of GetICValues() (must) */ XGetICValues (ic, XNInputStyle, &gistyle, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ von[0] = mkstruct (IS, HEX, uistyle, gistyle); von[1] = mkstruct (PSL, HEX, upec.start.client_data, gpec.start.client_data); von[2] = mkstruct (PSA, HEX, upec.start.callback, gpec.start.callback); von[3] = mkstruct (POL, HEX, upec.done.client_data, gpec.done.client_data); von[4] = mkstruct (POA, HEX, upec.done.callback, gpec.done.callback); von[5] = mkstruct (PRL, HEX, upec.draw.client_data, gpec.draw.client_data); von[6] = mkstruct (PRA, HEX, upec.draw.callback, gpec.draw.callback); von[7] = mkstruct (PCL, HEX, upec.caret.client_data, gpec.caret.client_data); von[8] = mkstruct (PCA, HEX, upec.caret.callback, gpec.caret.callback); von[9] = mkstruct (SSL, HEX, ustc.start.client_data, gstc.start.client_data); von[10] = mkstruct (SSA, HEX, ustc.start.callback, gstc.start.callback); von[11] = mkstruct (SOL, HEX, ustc.done.client_data, gstc.done.client_data); von[12] = mkstruct (SOA, HEX, ustc.done.callback, gstc.done.callback); von[13] = mkstruct (SRL, HEX, ustc.draw.client_data, gstc.draw.client_data); von[14] = mkstruct (SRA, HEX, ustc.draw.callback, gstc.draw.callback); for (cnt = 0; cnt < ONMUST; cnt++) { sum += verval (von[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <must> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); return (ic); } /* *INDENT-OFF* */ XIC onmay (im, flag) /* for ON-the-spot mode (MAY) */ XIM im; FLAG *flag; /* *INDENT-ON* */ { XIC ic; int cnt; int sum; XIMStyle gistyle; Window gclient; Window gfocus; CALLBACK gpec; CALLBACK gstc; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *von[ONMUST]; prmode ("X11R5 Input Method Test Program : <<on-the-spot mode>>"); prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (must) */ uistyle = (XIMPreeditCallbacks | XIMStatusCallbacks); /* initialize valuables */ uclient = window1.win; ufocus = window3.win; ufname = window3.name; upec.start.client_data = NULL; upec.start.callback = (XIMProc) pe_start; upec.done.client_data = NULL; upec.done.callback = (XIMProc) pe_done; upec.draw.client_data = NULL; upec.draw.callback = (XIMProc) pe_draw; upec.caret.client_data = NULL; upec.caret.callback = (XIMProc) pe_caret; ustc.start.client_data = NULL; ustc.start.callback = (XIMProc) st_start; ustc.done.client_data = NULL; ustc.done.callback = (XIMProc) st_done; ustc.draw.client_data = NULL; ustc.draw.callback = (XIMProc) st_draw; cpe_nelist = XVaCreateNestedList (DUMMY, XNPreeditStartCallback, &upec.start, XNPreeditDoneCallback, &upec.done, XNPreeditDrawCallback, &upec.draw, XNPreeditCaretCallback, &upec.caret, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNStatusStartCallback, &ustc.start, XNStatusDoneCallback, &ustc.done, XNStatusDrawCallback, &ustc.draw, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (must) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNClientWindow, uclient, XNFocusWindow, ufocus, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (must) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNPreeditStartCallback, &gpec.start, XNPreeditDoneCallback, &gpec.done, XNPreeditDrawCallback, &gpec.draw, XNPreeditCaretCallback, &gpec.caret, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNStatusStartCallback, &gstc.start, XNStatusDoneCallback, &gstc.done, XNStatusDrawCallback, &gstc.draw, NULL); prstatus ("done."); prstatus ("Test of GetICValues()..."); /* test of GetICValues() (must) */ XGetICValues (ic, XNInputStyle, &gistyle, XNClientWindow, &gclient, XNFocusWindow, &gfocus, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ von[0] = mkstruct (IS, HEX, uistyle, gistyle); von[1] = mkstruct (CW, HEX, uclient, gclient); von[2] = mkstruct (FW, HEX, ufocus, gfocus); von[3] = mkstruct (PSL, HEX, upec.start.client_data, gpec.start.client_data); von[4] = mkstruct (PSA, HEX, upec.start.callback, gpec.start.callback); von[5] = mkstruct (POL, HEX, upec.done.client_data, gpec.done.client_data); von[6] = mkstruct (POA, HEX, upec.done.callback, gpec.done.callback); von[7] = mkstruct (PRL, HEX, upec.draw.client_data, gpec.draw.client_data); von[8] = mkstruct (PRA, HEX, upec.draw.callback, gpec.draw.callback); von[9] = mkstruct (PCL, HEX, upec.caret.client_data, gpec.caret.client_data); von[10] = mkstruct (PCA, HEX, upec.caret.callback, gpec.caret.callback); von[11] = mkstruct (SSL, HEX, ustc.start.client_data, gstc.start.client_data); von[12] = mkstruct (SSA, HEX, ustc.start.callback, gstc.start.callback); von[13] = mkstruct (SOL, HEX, ustc.done.client_data, gstc.done.client_data); von[14] = mkstruct (SOA, HEX, ustc.done.callback, gstc.done.callback); von[15] = mkstruct (SRL, HEX, ustc.draw.client_data, ustc.draw.client_data); von[16] = mkstruct (SRA, HEX, ustc.draw.callback, gstc.draw.callback); for (cnt = 0; cnt < ONMAY; cnt++) { sum += verval (von[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <must> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); return (ic); } /* *INDENT-OFF* */ XIC overmust (im, lfdir, flag) /* for OVER-the-spot mode (MUST) */ XIM im; char *lfdir; FLAG *flag; /* *INDENT-ON* */ { XIC ic; static int cntlog = 1; char logfile[MAX_BUF]; int cnt; int sum; XIMStyle gistyle; XPoint *gspot; XFontSet gpfset, gsfset; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *vover[OVERMUST]; prmode ("X11R5 Input Method Test Program : <<over-the-spot mode>>"); prstatus ("Creating log file for ic..."); /* open log file for IC test */ sprintf (logfile, "%s/ticover.log%d", lfdir, cntlog); icfp = fopen (logfile, "w"); cntlog++; prstatus ("done."); prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (must) */ uistyle = (XIMPreeditPosition | XIMStatusArea); /* initialize valuables */ upea.spot.x = XPSL1; upea.spot.y = YPSL; upea.fset = fontset[0]; usta.fset = fontset[1]; cpe_nelist = XVaCreateNestedList (DUMMY, XNSpotLocation, &upea.spot, XNFontSet, upea.fset, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNFontSet, usta.fset, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (must) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (must) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNSpotLocation, &gspot, XNFontSet, &gpfset, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNFontSet, &gsfset, NULL); prstatus ("done."); prstatus ("Test of GetICValues()..."); /* test of GetICValues() (must) */ XGetICValues (ic, XNInputStyle, &gistyle, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ vover[0] = mkstruct (IS, HEX, uistyle, gistyle); vover[1] = mkstruct (PSLX, DEC, upea.spot.x, gspot->x); vover[2] = mkstruct (PSLY, DEC, upea.spot.y, gspot->y); vover[3] = mkstruct (PFS, HEX, upea.fset, gpfset); vover[4] = mkstruct (SFS, HEX, usta.fset, gsfset); for (cnt = 0; cnt < OVERMUST; cnt++) { sum += verval (vover[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <must> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); XFree ((XPoint *) gspot); return (ic); } /* *INDENT-OFF* */ XIC overmay (im, flag) /* for OVER-the-spot mode (MAY) */ XIM im; FLAG *flag; /* *INDENT-ON* */ { XIC ic; int cnt; int sum; XIMStyle gistyle; Window gclient; Window gfocus; RESOURCE gres; XRectangle *gparea, *gsarea; XPoint *gspot; Colormap gpcmap, gscmap; u_long gpfg, gpbg, gsfg, gsbg; Pixmap gppix, gspix; XFontSet gpfset, gsfset; int glspc; Cursor gpcursor, gscursor; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *vover[OVERMAY]; prmode ("X11R5 Input Method Test Program : <<over-the-spot mode>>"); prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (may) */ uistyle = (XIMPreeditPosition | XIMStatusArea); /* initialize valuables */ uclient = window1.win; ufocus = window3.win; ufname = window3.name; ures.name = "xim"; ures.class = "Xim"; usta.area.x = WIN_ITV; usta.area.y = CALCY ((CALCY (W1_HEIGHT, NW_HEIGHT)), PS_HEIGHT); usta.area.width = ST_WIDTH; usta.area.height = PS_HEIGHT; usta.cmap = cmap[0]; usta.fg = pixel[cmflag][0]; usta.bg = pixel[cmflag][3]; usta.bgpm = pix[1]; usta.fset = fontset[1]; usta.cursor = cursor[1]; upea.area.x = XPOVER; upea.area.y = YPOVER; upea.area.width = WPOVER1; upea.area.height = HPOVER; upea.spot.x = XPSL1; upea.spot.y = YPSL; upea.cmap = cmap[0]; upea.fg = pixel[cmflag][3]; upea.bg = pixel[cmflag][0]; upea.bgpm = pix[0]; upea.fset = fontset[0]; upea.lspc = LSPC1; upea.cursor = cursor[0]; cpe_nelist = XVaCreateNestedList (DUMMY, XNArea, &upea.area, XNSpotLocation, &upea.spot, XNColormap, upea.cmap, XNForeground, upea.fg, XNBackground, upea.bg, XNBackgroundPixmap, upea.bgpm, XNFontSet, upea.fset, XNLineSpace, upea.lspc, XNCursor, upea.cursor, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNArea, &usta.area, XNColormap, usta.cmap, XNForeground, usta.fg, XNBackground, usta.bg, XNBackgroundPixmap, usta.bgpm, XNFontSet, usta.fset, XNCursor, usta.cursor, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (may) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNClientWindow, uclient, XNFocusWindow, ufocus, XNResourceName, ures.name, XNResourceClass, ures.class, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (may) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNArea, &gparea, XNSpotLocation, &gspot, XNColormap, &gpcmap, XNForeground, &gpfg, XNBackground, &gpbg, XNBackgroundPixmap, &gppix, XNFontSet, &gpfset, XNLineSpace, &glspc, XNCursor, &gpcursor, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNArea, &gsarea, XNColormap, &gscmap, XNForeground, &gsfg, XNBackground, &gsbg, XNBackgroundPixmap, &gspix, XNFontSet, &gsfset, XNCursor, &gscursor, NULL); prstatus ("done."); prstatus ("Test of XGetICValues()..."); /* test of GetICValues() (may) */ XGetICValues (ic, XNInputStyle, &gistyle, XNClientWindow, &gclient, XNFocusWindow, &gfocus, XNResourceName, &gres.name, XNResourceClass, &gres.class, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ vover[0] = mkstruct (IS, HEX, uistyle, gistyle); vover[1] = mkstruct (CW, HEX, uclient, gclient); vover[2] = mkstruct (FW, HEX, ufocus, gfocus); vover[3] = mkstruct (RN, STR, ures.name, gres.name); vover[4] = mkstruct (RC, STR, ures.class, gres.class); vover[5] = mkstruct (PAX, DEC, upea.area.x, gparea->x); vover[6] = mkstruct (PAY, DEC, upea.area.y, gparea->y); vover[7] = mkstruct (PAW, DEC, upea.area.width, gparea->width); vover[8] = mkstruct (PAH, DEC, upea.area.height, gparea->height); vover[9] = mkstruct (PSLX, DEC, upea.spot.x, gspot->x); vover[10] = mkstruct (PSLY, DEC, upea.spot.y, gspot->y); vover[11] = mkstruct (PCM, HEX, upea.cmap, gpcmap); vover[12] = mkstruct (PFG, HEX, upea.fg, gpfg); vover[13] = mkstruct (PBG, HEX, upea.bg, gpbg); vover[14] = mkstruct (PBP, HEX, upea.bgpm, gppix); vover[15] = mkstruct (PFS, HEX, upea.fset, gpfset); vover[16] = mkstruct (PLS, DEC, upea.lspc, glspc); vover[17] = mkstruct (PCU, HEX, upea.cursor, gpcursor); vover[18] = mkstruct (SAX, DEC, usta.area.x, gsarea->x); vover[19] = mkstruct (SAY, DEC, usta.area.y, gsarea->y); vover[20] = mkstruct (SAW, DEC, usta.area.width, gsarea->width); vover[21] = mkstruct (SAH, DEC, usta.area.height, gsarea->height); vover[22] = mkstruct (SCM, HEX, usta.cmap, gscmap); vover[23] = mkstruct (SFG, HEX, usta.fg, gsfg); vover[24] = mkstruct (SBG, HEX, usta.bg, gsbg); vover[25] = mkstruct (SBP, HEX, usta.bgpm, gspix); vover[26] = mkstruct (SFS, HEX, usta.fset, gsfset); vover[27] = mkstruct (SCU, HEX, usta.cursor, gscursor); for (cnt = 0; cnt < OVERMAY; cnt++) { sum += verval (vover[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <may> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <may> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <may> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <may> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); XFree ((XRectangle *) gparea); XFree ((XRectangle *) gsarea); XFree ((XPoint *) gspot); return (ic); } /* *INDENT-OFF* */ XIC offmust (im, lfdir, flag) /* for OFF-the-spot mode (MUST) */ XIM im; char *lfdir; FLAG *flag; /* *INDENT-ON* */ { XIC ic; static int cntlog = 1; char logfile[MAX_BUF]; int cnt; int sum; XIMStyle gistyle; XFontSet gpfset, gsfset; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *voff[OFFMUST]; prmode ("X11R5 Input Method Test Program : <<off-the-spot mode>>"); prstatus ("Creating log file for ic..."); /* open log file for IC test */ sprintf (logfile, "%s/ticoff.log%d", lfdir, cntlog); icfp = fopen (logfile, "w"); prstatus ("done."); cntlog++; prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (must) */ uistyle = (XIMPreeditArea | XIMStatusArea); /* initialize valuables */ upea.fset = fontset[0]; usta.fset = fontset[1]; cpe_nelist = XVaCreateNestedList (DUMMY, XNFontSet, upea.fset, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNFontSet, usta.fset, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (must) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (must) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNFontSet, &gpfset, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNFontSet, &gsfset, NULL); prstatus ("done."); prstatus ("Test of GetICValues()..."); /* test of GetICValues() (must) */ XGetICValues (ic, XNInputStyle, &gistyle, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ voff[0] = mkstruct (IS, HEX, uistyle, gistyle); voff[1] = mkstruct (PFS, HEX, upea.fset, gpfset); voff[2] = mkstruct (SFS, HEX, usta.fset, gsfset); for (cnt = 0; cnt < OFFMUST; cnt++) { sum += verval (voff[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <must> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); return (ic); } /* *INDENT-OFF* */ XIC offmay (im, flag) /* for OFF-the-spot mode (MAY) */ XIM im; FLAG *flag; /* *INDENT-ON* */ { XIC ic; int cnt; int sum; XIMStyle gistyle; Window gclient; Window gfocus; RESOURCE gres; XRectangle *gparea, *gsarea; Colormap gpcmap, gscmap; u_long gpfg, gpbg, gsfg, gsbg; Pixmap gppix, gspix; XFontSet gpfset, gsfset; Cursor gpcursor, gscursor; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *voff[OFFMAY]; prmode ("X11R5 Input Method Test Program : <<off-the-spot mode>>"); prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (may) */ uistyle = (XIMPreeditArea | XIMStatusArea); /* initialize valuables */ uclient = window1.win; ufocus = window3.win; ufname = window3.name; ures.name = "xim"; ures.class = "Xim"; usta.area.x = WIN_ITV; usta.area.y = CALCY ((CALCY (W1_HEIGHT, NW_HEIGHT)), PS_HEIGHT); usta.area.width = ST_WIDTH; usta.area.height = PS_HEIGHT; usta.cmap = cmap[0]; usta.fg = pixel[cmflag][0]; usta.bg = pixel[cmflag][3]; usta.fset = fontset[1]; usta.bgpm = pix[1]; usta.cursor = cursor[1]; upea.area.x = ST_WIDTH + 2 * WIN_ITV; upea.area.y = usta.area.y; upea.area.width = WPOFF1; upea.area.height = PS_HEIGHT; upea.cmap = cmap[0]; upea.fg = pixel[cmflag][3]; upea.bg = pixel[cmflag][0]; upea.bgpm = pix[0]; upea.fset = fontset[0]; upea.cursor = cursor[0]; cpe_nelist = XVaCreateNestedList (DUMMY, XNArea, &upea.area, XNColormap, upea.cmap, XNForeground, upea.fg, XNBackground, upea.bg, XNBackgroundPixmap, upea.bgpm, XNFontSet, upea.fset, XNCursor, upea.cursor, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNArea, &usta.area, XNColormap, usta.cmap, XNForeground, usta.fg, XNBackground, usta.bg, XNBackgroundPixmap, usta.bgpm, XNFontSet, usta.fset, XNCursor, usta.cursor, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (may) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNClientWindow, uclient, XNFocusWindow, ufocus, XNResourceName, ures.name, XNResourceClass, ures.class, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (may) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNArea, &gparea, XNColormap, &gpcmap, XNForeground, &gpfg, XNBackground, &gpbg, XNBackgroundPixmap, &gppix, XNFontSet, &gpfset, XNCursor, &gpcursor, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNArea, &gsarea, XNColormap, &gscmap, XNForeground, &gsfg, XNBackground, &gsbg, XNBackgroundPixmap, &gspix, XNFontSet, &gsfset, XNCursor, &gscursor, NULL); prstatus ("done."); prstatus ("Test of XGetICValues()..."); /* test of GetICValues() (may) */ XGetICValues (ic, XNInputStyle, &gistyle, XNClientWindow, &gclient, XNFocusWindow, &gfocus, XNResourceName, &gres.name, XNResourceClass, &gres.class, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ voff[0] = mkstruct (IS, HEX, uistyle, gistyle); voff[1] = mkstruct (CW, HEX, uclient, gclient); voff[2] = mkstruct (FW, HEX, ufocus, gfocus); voff[3] = mkstruct (RN, STR, ures.name, gres.name); voff[4] = mkstruct (RC, STR, ures.name, gres.name); voff[5] = mkstruct (PAX, DEC, upea.area.x, gparea->x); voff[6] = mkstruct (PAY, DEC, upea.area.y, gparea->y); voff[7] = mkstruct (PAW, DEC, upea.area.width, gparea->width); voff[8] = mkstruct (PAH, DEC, upea.area.height, gparea->height); voff[9] = mkstruct (PCM, HEX, upea.cmap, gpcmap); voff[10] = mkstruct (PFG, HEX, upea.fg, gpfg); voff[11] = mkstruct (PBG, HEX, upea.bg, gpbg); voff[12] = mkstruct (PBP, HEX, upea.bgpm, gppix); voff[13] = mkstruct (PFS, HEX, upea.fset, gpfset); voff[14] = mkstruct (PCU, HEX, upea.cursor, gpcursor); voff[15] = mkstruct (SAX, DEC, usta.area.x, gsarea->x); voff[16] = mkstruct (SAY, DEC, usta.area.y, gsarea->y); voff[17] = mkstruct (SAW, DEC, usta.area.width, gsarea->width); voff[18] = mkstruct (SAH, DEC, usta.area.height, gsarea->height); voff[19] = mkstruct (SCM, HEX, usta.cmap, gscmap); voff[20] = mkstruct (SFG, HEX, usta.fg, gsfg); voff[21] = mkstruct (SBG, HEX, usta.bg, gsbg); voff[22] = mkstruct (SBP, HEX, usta.bgpm, gspix); voff[23] = mkstruct (SFS, HEX, usta.fset, gsfset); voff[24] = mkstruct (SCU, HEX, usta.cursor, gscursor); for (cnt = 0; cnt < OFFMAY; cnt++) { sum += verval (voff[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <may> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <may> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <may> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <may> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); XFree ((XRectangle *) gsarea); XFree ((XRectangle *) gsarea); return (ic); } /* *INDENT-OFF* */ XIC rootmust (im, lfdir, flag) /* for ROOT-window mode (MUST) */ XIM im; char *lfdir; FLAG *flag; /* *INDENT-ON* */ { XIC ic; static int cntlog = 1; char logfile[MAX_BUF]; int sum; XIMStyle gistyle; VALUABLE *vroot; prmode ("X11R5 Input Method Test Program : <<root-window mode>>"); prstatus ("Creating log file for ic..."); /* open log file for IC test */ sprintf (logfile, "%s/ticroot.log%d", lfdir, cntlog); icfp = fopen (logfile, "w"); cntlog++; prstatus ("done."); uistyle = (XIMPreeditNothing | XIMStatusNothing); /* initialize valuables */ prstatus ("Creating ic..."); /* test of XCreateIC() (must) */ ic = XCreateIC (im, XNInputStyle, uistyle, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Test of GetICValues()..."); /* test of GetICValues() (must) */ XGetICValues (ic, XNInputStyle, &gistyle, NULL); prstatus ("done."); sum = 0; /* verify valuables */ vroot = mkstruct (IS, HEX, uistyle, gistyle); sum += verval (vroot); cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <must> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <must> is succeeded.\n\n"); } return (ic); } /* *INDENT-OFF* */ XIC rootmay (im, flag) /* for ROOT-window mode (MAY) */ XIM im; FLAG *flag; /* *INDENT-ON* */ { XIC ic; int cnt; int sum; XIMStyle gistyle; Window gclient; Window gfocus; RESOURCE gres; Colormap gpcmap, gscmap; u_long gpfg, gpbg, gsfg, gsbg; Pixmap gppix, gspix; XFontSet gpfset, gsfset; Cursor gpcursor, gscursor; XVaNestedList cpe_nelist, cst_nelist; XVaNestedList gpe_nelist, gst_nelist; VALUABLE *vroot[ROOTMAY]; prmode ("X11R5 Input Method Test Program : <<root-window mode>>"); prstatus ("Creating NestedList for set..."); /* create NestedList for create IC (may) */ uistyle = (XIMPreeditNothing | XIMStatusNothing); /* initialize valuables */ uclient = window1.win; ufocus = window3.win; ufname = window3.name; ures.name = "xim"; ures.class = "Xim"; usta.cmap = cmap[0]; usta.fg = pixel[cmflag][0]; usta.bg = pixel[cmflag][3]; usta.bgpm = pix[1]; usta.fset = fontset[1]; usta.cursor = cursor[1]; upea.cmap = cmap[0]; upea.fg = pixel[cmflag][3]; upea.bg = pixel[cmflag][0]; upea.bgpm = pix[0]; upea.fset = fontset[0]; upea.cursor = cursor[0]; cpe_nelist = XVaCreateNestedList (DUMMY, XNColormap, upea.cmap, XNForeground, upea.fg, XNBackground, upea.bg, XNBackgroundPixmap, upea.bgpm, XNFontSet, upea.fset, XNCursor, upea.cursor, NULL); cst_nelist = XVaCreateNestedList (DUMMY, XNColormap, usta.cmap, XNForeground, usta.fg, XNBackground, usta.bg, XNBackgroundPixmap, usta.bgpm, XNFontSet, usta.fset, XNCursor, usta.cursor, NULL); prstatus ("done."); prstatus ("Creating ic..."); /* test of XCreateIC() (may) */ ic = XCreateIC (im, XNInputStyle, uistyle, XNClientWindow, uclient, XNFocusWindow, ufocus, XNResourceName, ures.name, XNResourceClass, ures.class, XNPreeditAttributes, cpe_nelist, XNStatusAttributes, cst_nelist, NULL); prstatus ("done."); if (ic == NULL) { /* transaction of error */ cls (prdisp); prprint ("Test of XCreateIC() <must> is failed.\n"); prprint ("Cannot create IC. NULL returned.\n"); prprint ("This program will shutdown soon.\n\n"); fprintf (icfp, "Test of XCreateIC <must> is failed.\n"); fprintf (icfp, "Cannot create IC. NULL returned.\n\n"); *flag = CRICERR; return (NULL); } prstatus ("Creating NestedList for get..."); /* Create NestedList for GetICValues() (may) */ gpe_nelist = XVaCreateNestedList (DUMMY, XNColormap, &gpcmap, XNForeground, &gpfg, XNBackground, &gpbg, XNBackgroundPixmap, &gppix, XNFontSet, &gpfset, XNCursor, &gpcursor, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNColormap, &gscmap, XNForeground, &gsfg, XNBackground, &gsbg, XNBackgroundPixmap, &gspix, XNFontSet, &gsfset, XNCursor, &gscursor, NULL); prstatus ("done."); prstatus ("Test of XGetICValues()..."); /* test of GetICValues() (may) */ XGetICValues (ic, XNInputStyle, &gistyle, XNClientWindow, &gclient, XNFocusWindow, &gfocus, XNResourceName, &gres.name, XNResourceClass, &gres.class, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); sum = 0; /* verify valuables */ vroot[0] = mkstruct (IS, HEX, uistyle, gistyle); vroot[1] = mkstruct (CW, HEX, uclient, gclient); vroot[2] = mkstruct (FW, HEX, ufocus, gfocus); vroot[3] = mkstruct (RN, STR, ures.name, gres.name); vroot[4] = mkstruct (RC, STR, ures.class, gres.class); vroot[5] = mkstruct (PCM, HEX, upea.cmap, gpcmap); vroot[6] = mkstruct (PFG, HEX, upea.fg, gpfg); vroot[7] = mkstruct (PBG, HEX, upea.bg, gpbg); vroot[8] = mkstruct (PBP, HEX, upea.bgpm, gppix); vroot[9] = mkstruct (PFS, HEX, upea.fset, gpfset); vroot[10] = mkstruct (PCU, HEX, upea.cursor, gpcursor); vroot[11] = mkstruct (SCM, HEX, usta.cmap, gscmap); vroot[12] = mkstruct (SFG, HEX, usta.fg, gsfg); vroot[13] = mkstruct (SBG, HEX, usta.bg, gsbg); vroot[14] = mkstruct (SBP, HEX, usta.bgpm, gspix); vroot[15] = mkstruct (SFS, HEX, usta.fset, gsfset); vroot[16] = mkstruct (SCU, HEX, usta.cursor, gscursor); for (cnt = 0; cnt < ROOTMAY; cnt++) { sum += verval (vroot[cnt]); } cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XCreateIC() <may> is failed.\n"); prprint ("This program will shutdown soon.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <may> is failed.\n\n"); *flag = GICERR; return (NULL); } else { prprint ("Test of XCreateIC() <may> is succeeded.\n"); prprint ("move next test.\n\n"); prverlog (sum); fprintf (icfp, "...Test of XCreateIC <may> is succeeded.\n\n"); } XFree ((char *) cpe_nelist); XFree ((char *) cst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); return (ic); } void destic (ic) /* DESTroy IC */ XIC ic; { if (focuson == OK) { XUnsetICFocus (ic); focuson = NG; cwcolor (ufname, pixel[cmflag][1]); } XDestroyIC (ic); } void fclic () /* log File Close for IC */ { fclose (icfp); }