Mercurial > freewnn
view Xwnmo/test/chkpsset.c @ 20:c4b8c1d2b943
added supplement.u and ldic.u
author | Yoshiki Yazawa <yaz@cc.rim.or.jp> |
---|---|
date | Tue, 15 Apr 2008 17:26:32 +0900 |
parents | bbc77ca4def5 |
children |
line wrap: on
line source
/* * $Id: chkpsset.c,v 1.2 2001/06/14 18:16:11 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 * chkpsset.c v 1.0 Wed Mar 13 11:16:00 JST 1991 */ /* * Author: Takashi Inoue OMRON Corporation * takashi@ari.ncl.omron.co.jp */ #include <stdio.h> #include "exvalue.h" #include "func.h" /* *INDENT-OFF* */ FLAG sarea (ic, mode) /* Set AREA */ XIC ic; FLAG mode; /* *INDENT-ON* */ { XRectangle *gparea, *gsarea; VALUABLE *area[CHKAREA]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; if ((mode == ONSP) || (mode == ROOTW)) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for set values */ prstatus ("Creating NestedList for set values \"Area\"..."); if (usta.area.width == ST_WIDTH) { usta.area.width += WIN_ITV; } else { usta.area.width -= WIN_ITV; } if (mode == OVERSP) { upea.area.width = (upea.area.width == WPOVER1) ? WPOVER2 : WPOVER1; } else if (mode == OFFSP) { upea.area.x = usta.area.width + 2 * WIN_ITV; } spe_nelist = XVaCreateNestedList (DUMMY, XNArea, &upea.area, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNArea, &usta.area, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"Area\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"Area\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNArea, &gparea, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNArea, &gsarea, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"Area\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; area[0] = mkstruct (PAX, DEC, upea.area.x, gparea->x); area[1] = mkstruct (PAY, DEC, upea.area.y, gparea->y); area[2] = mkstruct (PAW, DEC, upea.area.width, gparea->width); area[3] = mkstruct (PAH, DEC, upea.area.height, gparea->height); area[4] = mkstruct (SAX, DEC, usta.area.x, gsarea->x); area[5] = mkstruct (SAY, DEC, usta.area.y, gsarea->y); area[6] = mkstruct (SAW, DEC, usta.area.width, gsarea->width); area[7] = mkstruct (SAH, DEC, usta.area.height, gsarea->height); for (cnt = 0; cnt < CHKAREA; cnt++) { sum += verval (area[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() \"Preedit/Status Area\" is failed.\n"); prprint ("Preedit/Status Area has not changed.\n\n"); prprint ("I will destroy IC and continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() \"Preedit/Status Area\" is failed.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); XFree ((XRectangle *) gparea); XFree ((XRectangle *) gsarea); prpng (); return (DIC); } prprint ("Test of XSetICValues() \"Preedit/Status Area\" is succeeded.\n"); prprint ("Preedit/Status Area has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); fprintf (icfp, "...Test of XSetICValues() \"Preedit/Status Area\" is succeeded.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); XFree ((XRectangle *) gparea); XFree ((XRectangle *) gsarea); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG sneeded (ic, mode) /* Set areaNEEDED */ XIC ic; FLAG mode; /* *INDENT-ON* */ { XRectangle *gpneeded, *gsneeded; XRectangle wparea, wsarea, *gparea, *gsarea; VALUABLE *needed[CHKNEEDED]; VALUABLE *area[CHKAREA]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; if (mode != OFFSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for set values */ prstatus ("Creating NestedList for set values \"AreaNeeded\"..."); upea.needed.width = 100; upea.needed.height = 100; usta.needed.width = 100; usta.needed.height = 100; spe_nelist = XVaCreateNestedList (DUMMY, XNAreaNeeded, &upea.needed, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNAreaNeeded, &upea.needed, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"AreaNeeded\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"AreaNeeded\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNAreaNeeded, &gpneeded, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNAreaNeeded, &gsneeded, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"AreaNeeded\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ needed[0] = mkstruct (PNW, DEC, upea.needed.width, gpneeded->width); needed[1] = mkstruct (PNH, DEC, upea.needed.height, gpneeded->height); needed[2] = mkstruct (SNW, DEC, usta.needed.width, gsneeded->width); needed[3] = mkstruct (SNH, DEC, usta.needed.height, gsneeded->height); for (cnt = 0; cnt < CHKNEEDED; cnt++) { verval (needed[cnt]); } wparea = upea.area; wsarea = usta.area; upea.area.width = gpneeded->width; upea.area.height = gpneeded->height; usta.area.width = gsneeded->width; usta.area.height = gsneeded->height; spe_nelist = XVaCreateNestedList (DUMMY, XNArea, &upea.area, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNArea, &usta.area, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"Area\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"Area\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNArea, &gparea, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNArea, &gsarea, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"Area\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; area[0] = mkstruct (PAX, DEC, upea.area.x, gparea->x); area[1] = mkstruct (PAY, DEC, upea.area.y, gparea->y); area[2] = mkstruct (PAW, DEC, upea.area.width, gparea->width); area[3] = mkstruct (PAH, DEC, upea.area.height, gparea->height); area[4] = mkstruct (SAX, DEC, usta.area.x, gsarea->x); area[5] = mkstruct (SAY, DEC, usta.area.y, gsarea->y); area[6] = mkstruct (SAW, DEC, usta.area.width, gsarea->width); area[7] = mkstruct (SAH, DEC, usta.area.height, gsarea->height); for (cnt = 0; cnt < CHKAREA; cnt++) { sum += verval (area[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() \"Preedit/Status AreaNeeded\" is failed.\n"); prprint ("Preedit/Status Area has not changed, "); prprint ("but I will continue test.\n\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() \"Preedit/Status AreaNeeded\" is failed.\n\n"); } else { prprint ("Test of XSetICValues() \"Preedit/Status AreaNeeded\" is succeeded.\n"); prprint ("Preedit/Status Area has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() \"Preedit/Status AreaNeeded\" is succeeded.\n\n"); } upea.area = wparea; usta.area = wsarea; spe_nelist = XVaCreateNestedList (DUMMY, XNArea, &upea.area, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNArea, &usta.area, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"Area\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); XFree ((XRectangle *) gparea); XFree ((XRectangle *) gsarea); XFree ((XRectangle *) gpneeded); XFree ((XRectangle *) gsneeded); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG sspot (ic, mode) /* Set SPOTlocation */ XIC ic; FLAG mode; /* *INDENT-ON* */ { XPoint *gspot; VALUABLE *spot[CHKSPOT]; XVaNestedList spe_nelist; XVaNestedList gpe_nelist; int cnt, sum; if (mode != OVERSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for set values */ prstatus ("Creating NestedList for set values \"SpotLocation\"..."); upea.spot.x = (upea.spot.x == XPSL1) ? XPSL2 : XPSL1; upea.spot.y = YPSL; spe_nelist = XVaCreateNestedList (DUMMY, XNSpotLocation, &upea.spot, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"SpotLocation\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"SpotLocation\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNSpotLocation, &gspot, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"SpotLocation\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; spot[0] = mkstruct (PSLX, DEC, upea.spot.x, gspot->x); spot[1] = mkstruct (PSLY, DEC, upea.spot.y, gspot->y); for (cnt = 0; cnt < CHKSPOT; cnt++) { sum += verval (spot[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() \"Preedit SpotLocation\" is failed.\n"); prprint ("Preedit SpotLocation has not changed.\n\n"); prprint ("I will destroy IC and continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() \"Preedit SpotLocation\" is failed.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) gpe_nelist); prpng (); return (DIC); } prprint ("Test of XSetICValues() \"Preedit SpotLocation\" is succeeded.\n"); prprint ("Preedit SpotLocation has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); fprintf (icfp, "...Test of XSetICValues() \"Preedit SpotLocation\" is succeeded.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) gpe_nelist); XFree ((XPoint *) gspot); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG scmap (ic, mode) /* Set ColorMAP */ XIC ic; FLAG mode; /* *INDENT-ON* */ { Colormap gpcmap, gscmap; VALUABLE *colormap[CHKCMAP]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; if (mode == ONSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for get values */ prstatus ("Creating NestedList for set values \"Colormap\"..."); cmflag = (cmflag == 1) ? 0 : 1; XSetWindowColormap (dpy, window1.win, cmap[cmflag]); XSetWindowColormap (dpy, window2.win, cmap[cmflag]); XSetWindowColormap (dpy, window3.win, cmap[cmflag]); XSetWindowColormap (dpy, mroot, cmap[cmflag]); upea.cmap = usta.cmap = cmap[cmflag]; spe_nelist = XVaCreateNestedList (DUMMY, XNColormap, upea.cmap, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNColormap, usta.cmap, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"Colormap\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"Colormap\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNColormap, &gpcmap, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNColormap, &gscmap, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"Colormap\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; colormap[0] = mkstruct (PCM, HEX, upea.cmap, gpcmap); colormap[1] = mkstruct (SCM, HEX, usta.cmap, gscmap); for (cnt = 0; cnt < CHKCMAP; cnt++) { sum += verval (colormap[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() for change \"Preedit/Status Colormap\" is failed.\n"); prprint ("Preedit/Status Colormap has not changed.\n\n"); prprint ("I will destroy IC and continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Cmap\" is failed.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpng (); return (DIC); } prprint ("Test of XSetICValues() for change \"Preedit/Status Colormap\" is succeeded.\n"); prprint ("Preedit/Status Colormap has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Colormap\" is succeeded.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG sground (ic, mode) /* Set fore/backGROUND */ XIC ic; FLAG mode; /* *INDENT-ON* */ { u_long gpfg, gpbg, gsfg, gsbg; VALUABLE *ground[CHKFBGND]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; static int i = 0, j = PIX_MAX - 1; if (mode == ONSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ i++, j--; if (i == PIX_MAX) { i = 0; } if (j == -1) { j = PIX_MAX - 1; } upea.fg = pixel[cmflag][j]; upea.bg = pixel[cmflag][i]; usta.fg = pixel[cmflag][i]; usta.bg = pixel[cmflag][j]; /* Create nestedlist for set values */ prstatus ("Creating NestedList for set values \"Fg/Bg\"..."); spe_nelist = XVaCreateNestedList (DUMMY, XNForeground, upea.fg, XNBackground, upea.bg, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNForeground, usta.fg, XNBackground, usta.bg, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Using XSetICValues() for change \"Fg/Bg\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"Fg/Bg\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNForeground, &gpfg, XNBackground, &gpbg, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNForeground, &gsfg, XNBackground, &gsbg, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"Fg/Bg\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; ground[0] = mkstruct (PFG, HEX, upea.fg, gpfg); ground[1] = mkstruct (PBG, HEX, upea.bg, gpbg); ground[2] = mkstruct (SFG, HEX, usta.fg, gsfg); ground[3] = mkstruct (SBG, HEX, usta.bg, gsbg); for (cnt = 0; cnt < CHKFBGND; cnt++) { sum += verval (ground[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() for change \"Preedit/Status Fg/Bg\" is failed.\n"); prprint ("Preedit/Status Fg/Bg has not changed.\n\n"); prprint ("I will destroy IC and continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Fg/Bg\" is failed.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpng (); return (DIC); } prprint ("Test of XSetICValues() for change \"Preedit/Status Fg/Bg\" is succeeded.\n"); prprint ("Preedit/Status Fg/Bg has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Fg/Bg\" is succeeded.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG spixmap (ic, mode) /* Set bg/ PIXMAP */ XIC ic; FLAG mode; /* *INDENT-ON* */ { Pixmap gppix, gspix; VALUABLE *pixmap[CHKPIX]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; if (mode == ONSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for get values */ prstatus ("Creating NestedList for set values \"Bg/ Pixmap\"..."); upea.bgpm = (upea.bgpm == pix[0]) ? pix[1] : pix[0]; usta.bgpm = (usta.bgpm == pix[0]) ? pix[1] : pix[0]; spe_nelist = XVaCreateNestedList (DUMMY, XNBackgroundPixmap, upea.bgpm, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNBackgroundPixmap, usta.bgpm, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() \"Bg/ Pixmap\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"Bg/ Pixmap\" again..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNBackgroundPixmap, &gppix, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNBackgroundPixmap, &gspix, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"Bg/ Pixmap\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; pixmap[0] = mkstruct (PBP, HEX, upea.bgpm, gppix); pixmap[1] = mkstruct (SBP, HEX, usta.bgpm, gspix); for (cnt = 0; cnt < CHKPIX; cnt++) { sum += verval (pixmap[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() for change \"Preedit/Status Bg/ Pixmap\" is failed.\n"); prprint ("Preedit/Status Bg/ Pixmap has not changed. "); prprint ("but I will continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Bg/ Pixmap\" is failed.\n\n"); } else { prprint ("Test of XSetICValues() for change \"Preedit/Status Bg/ Pixmap\" is succeeded.\n"); prprint ("Preedit/Status Bg/ Pixmap has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Bg/ Pixmap\" is succeeded.\n\n"); } XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG sfontset (ic, mode) /* Set FONTSET */ XIC ic; FLAG mode; /* *INDENT-ON* */ { XFontSet gpfont, gsfont; VALUABLE *font[CHKFONT]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; if (mode == ONSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for get values */ prstatus ("Creating NestedList for set values \"FontSet\"..."); upea.fset = (upea.fset == fontset[0]) ? fontset[1] : fontset[0]; usta.fset = (usta.fset == fontset[0]) ? fontset[1] : fontset[0]; spe_nelist = XVaCreateNestedList (DUMMY, XNFontSet, upea.fset, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNFontSet, usta.fset, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"FontSet\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"FontSet\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNFontSet, &gpfont, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNFontSet, &gsfont, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"FontSet\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; font[0] = mkstruct (PFS, HEX, upea.fset, gpfont); font[1] = mkstruct (SFS, HEX, usta.fset, gsfont); for (cnt = 0; cnt < CHKFONT; cnt++) { sum += verval (font[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() for change \"Preedit/Status FontSet\" is failed.\n"); prprint ("Preedit/Status FontSet has not changed.\n\n"); prprint ("I will destroy IC and continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status FontSet\" is failed.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpng (); return (DIC); } prprint ("Test of XSetICValues() for change \"Preedit/Status FontSet\" is succeeded.\n"); prprint ("Preedit/Status FontSet has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status FontSet\" is succeeded.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG slinespc (ic, mode) /* Set LINESPaCing */ XIC ic; FLAG mode; /* *INDENT-ON* */ { XRectangle *gplspc; VALUABLE *plspc; XVaNestedList spe_nelist; XVaNestedList gpe_nelist; int sum; if (mode != OVERSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for set values */ prstatus ("Creating NestedList for set values \"LineSpacing\"..."); upea.lspc = (upea.lspc == LSPC1) ? LSPC2 : LSPC1; spe_nelist = XVaCreateNestedList (DUMMY, XNLineSpace, upea.lspc, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"LineSpacing\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"LineSpacing\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNLineSpace, &gplspc, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"LineSpacing\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; plspc = mkstruct (PLS, DEC, upea.lspc, gplspc); sum += verval (plspc); /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() for change \"Preedit LineSpacing\" is failed.\n"); prprint ("Preedit LineSpacing has not changed.\n\n"); prprint ("I will destroy IC and continue test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit LineSpacing\" is faled.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) gpe_nelist); prpng (); return (DIC); } prprint ("Test of XSetICValues() for change \"Preedit LineSpacing\" is succeeded.\n"); prprint ("Status LineSpacing has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit LineSpacing\" is succeeded.\n\n"); XFree ((char *) spe_nelist); XFree ((char *) gpe_nelist); prpok (); return (COMP); } } /* *INDENT-OFF* */ FLAG scursor (ic, mode) /* Set CURSOR */ XIC ic; FLAG mode; /* *INDENT-ON* */ { Cursor gpcursor, gscursor; VALUABLE *cur[CHKCUR]; XVaNestedList spe_nelist, sst_nelist; XVaNestedList gpe_nelist, gst_nelist; int cnt, sum; if (mode == ONSP) { prerrfunc (); return (COMP); } else { cls (prdisp); /* clear screen */ /* create nestedlist for get values */ prstatus ("Creating NestedList for set values \"Cursor\"..."); upea.cursor = (upea.cursor == cursor[0]) ? cursor[1] : cursor[0]; usta.cursor = (usta.cursor == cursor[0]) ? cursor[1] : cursor[0]; spe_nelist = XVaCreateNestedList (DUMMY, XNCursor, upea.cursor, NULL); sst_nelist = XVaCreateNestedList (DUMMY, XNCursor, usta.cursor, NULL); prstatus ("done."); /* test of XSetICValues */ prstatus ("Test of XSetICValues() for change \"Cursor\"..."); XSetICValues (ic, XNPreeditAttributes, spe_nelist, XNStatusAttributes, sst_nelist, NULL); prstatus ("done."); /* create nestedlist for get values */ prstatus ("Creating NestedList for get values \"Cursor\" ..."); gpe_nelist = XVaCreateNestedList (DUMMY, XNCursor, &gpcursor, NULL); gst_nelist = XVaCreateNestedList (DUMMY, XNCursor, &gscursor, NULL); prstatus ("done."); /* test of XGetICValues */ prstatus ("Test of XGetICValues() \"Cursor\"..."); XGetICValues (ic, XNPreeditAttributes, gpe_nelist, XNStatusAttributes, gst_nelist, NULL); prstatus ("done."); /* verify values */ sum = 0; cur[0] = mkstruct (PCU, HEX, upea.cursor, gpcursor); cur[1] = mkstruct (SCU, HEX, usta.cursor, gscursor); for (cnt = 0; cnt < CHKCUR; cnt++) { sum += verval (cur[cnt]); } /* output of results */ cls (prdisp); prveres (sum); if (sum != NOERR) { prprint ("Test of XSetICValues() for change \"Preedit/Status Cursor\" is failed.\n"); prprint ("Preedit/Status Cursor has not changed, "); prprint ("but I will continue test.\n\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Cursor\" is failed.\n\n"); } else { prprint ("Test of XSetICValues() for change \"Preedit/Status Cursor\" is succeeded.\n"); prprint ("Preedit/Status Cursor has changed.\n\n"); prprint ("Check on your own eyes and move next test.\n"); prprint ("Check log file after this test.\n\n"); fprintf (icfp, "...Test of XSetICValues() for change \"Preedit/Status Cursor\" is succeeded.\n\n"); } XFree ((char *) spe_nelist); XFree ((char *) sst_nelist); XFree ((char *) gpe_nelist); XFree ((char *) gst_nelist); prpok (); return (COMP); } }