diff options
author | Dan Nicholson <dbn.lists@gmail.com> | 2009-09-28 23:35:33 -0700 |
---|---|---|
committer | Dan Nicholson <dbn.lists@gmail.com> | 2009-09-28 23:35:33 -0700 |
commit | 8e10609fc883cb26ab2ca42936c66edfe88be67b (patch) | |
tree | 4b6c89a4f560937ae0e37b04a27aa78a24376064 /xts5/Xlib7/XcmsStoreColors.m | |
parent | a94c2af8f070cae9aaf24cf562dae34cea5cb3b1 (diff) |
xts5: Flatten Xlib7 directory more
Diffstat (limited to 'xts5/Xlib7/XcmsStoreColors.m')
-rw-r--r-- | xts5/Xlib7/XcmsStoreColors.m | 662 |
1 files changed, 662 insertions, 0 deletions
diff --git a/xts5/Xlib7/XcmsStoreColors.m b/xts5/Xlib7/XcmsStoreColors.m new file mode 100644 index 00000000..42a50ad3 --- /dev/null +++ b/xts5/Xlib7/XcmsStoreColors.m @@ -0,0 +1,662 @@ +Copyright (c) 2005 X.Org Foundation LLC + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +Copyright (c) Applied Testing and Technology, Inc. 1993, 1994, 1995 +Copyright (c) 88open Consortium, Ltd. 1990, 1991, 1992, 1993 +All Rights Reserved. + +>># +>># Project: VSW5 +>># +>># File: xts/Xlib7/XcmsStoreColors.m +>># +>># Description: +>># Tests for XcmsStoreColors() +>># +>># Modifications: +>># $Log: cmsstcls.m,v $ +>># Revision 1.1 2005-02-12 14:37:36 anderson +>># Initial revision +>># +>># Revision 8.0 1998/12/23 23:27:18 mar +>># Branch point for Release 5.0.2 +>># +>># Revision 7.0 1998/10/30 22:45:36 mar +>># Branch point for Release 5.0.2b1 +>># +>># Revision 6.0 1998/03/02 05:19:30 tbr +>># Branch point for Release 5.0.1 +>># +>># Revision 5.0 1998/01/26 03:16:00 tbr +>># Branch point for Release 5.0.1b1 +>># +>># Revision 4.0 1995/12/15 08:50:26 tbr +>># Branch point for Release 5.0.0 +>># +>># Revision 3.1 1995/12/15 00:50:38 andy +>># Prepare for GA Release +>># +>>AVSCODE +>>TITLE XcmsStoreColors Xlib7 +XcmsStoreColors() +>>EXTERN + +/****** + * User defined globals for test + ******/ + +Bool writeable_colormaps = 1; + + +/****** + * User defined globals for test case sets + ******/ +Display *display_good; +Visual *visual_good ; +Colormap colormap_good ; +Colormap colormap_dfl ; +XcmsColor color_good, color_return ; +XcmsColorFormat format_good ; +int screen_good ; +int depth_good ; +XcmsColor color_array[2] ; +XcmsColor write_many_color[2] ; +XcmsColor query_many_color[2] ; +XcmsColor scrnColor, exactColor ; +/****** + * generated globals + ******/ +char *exec_file_name; +int x_init, + y_init, + h_init, + w_init; + +/****** + * routines + ******/ + +/***** + * svccmsStoreColors routine + *****/ +svccmsStoreColors(display, colormap, colors, ncolors, flags_return) +Display *display ; +Colormap colormap ; +XcmsColor colors[2] ; +unsigned int ncolors ; +Bool flags_return[] ; +{ + +/***** + * external defs + *****/ + + extern int errcnt; + extern int errflg; + extern int chkflg; + extern int signal_status(); + extern int unexp_err(); + extern char *svc_user_arg; + extern char *strcpy(); + +/****** + * local storage + ******/ + char fmtstr[256], *call_string; + union msglst fmt_lst[1]; + int skip_pixcheck; + + int + ss_status, /* save stat return status */ + stat_status, /* check stat return status */ + setup_status, + cleanup_status, + i1; + + Status svc_ret_value; + + + +/****** + * Turn on buffering and buffer parameter information + * in case an error occurs + ******/ + + regr_args.l_flags.bufrout = 1; + + (void)strcpy(fmtstr, "*********************\n"); + message(fmtstr, fmt_lst, 0); + (void)strcpy(fmtstr, "An error occurred during a call to %s\n\n"); + fmt_lst[0].typ_str = TestName; + message(fmtstr, fmt_lst, 1); + + + call_string = "svc_ret_value = XcmsStoreColors("; + + (void)strcpy(fmtstr, "The routine call looked like this - \n %s\n"); + fmt_lst[0].typ_str = call_string; + message(fmtstr, fmt_lst, 1); + + call_string = " display, colormap, colors, ncolors, flags);\n\n"; + message(call_string, fmt_lst, 0); + (void)strcpy(fmtstr, "The parameter values were as follows... \n"); + message(fmtstr, fmt_lst, 0); + + bufrdisp(display); /* buffer display struct info for error checking */ + { + char *fmt_string; + union msglst f_lst[1]; + + f_lst[0].typ_dec = colormap ; + fmt_string = "\n colormap= %d\n" ; + message(fmt_string, f_lst, 1); + + } +/****** + * Setup code for this service - this should always be executed. + ******/ + + XSync(display_arg, 0); + +/****** + * save environment + ******/ + if (regr_args.l_flags.chksta == 1) + ss_status = save_stat(dpy_msk | win_msk , + gc_id, + display_arg, + drawable_id); + + + first_error = 0; /* no errors encountered yet */ +/****** + * service call + ******/ + + svc_ret_value = 0 ; + errflg = 0; + XSetErrorHandler(signal_status); + svc_ret_value = XcmsStoreColors( + display, + colormap, + &colors[0], + ncolors, + (Bool *)0 + ); + XSync(display_arg, 0); + XSetErrorHandler(unexp_err); + r_wait(display_arg, window_arg, time_delay, None); /* no colormap by default */ + +/****** + * check saved environment with current environment. + ******/ + if (regr_args.l_flags.chksta == 1) + stat_status = chek_stat (dpy_msk | win_msk , + gc_id, + display_arg, + drawable_id, + ss_status); + else + stat_status = REGR_NORMAL; + +/****** + * check Success returns with expected returns + ******/ + if ((!errflg) && (!chkflg)) + if ((badstat(display_arg, estatus, Success)) != REGR_NORMAL) + errflg = 1; + + +/****** + * verify the results of the service if successful completion. + ******/ + if ((regr_args.l_flags.check) && + (errflg == 0) && + (stat_status == REGR_NORMAL)) + { + check_dec(XcmsSuccess, svc_ret_value, "return value" ) ; + format_good = XcmsRGBFormat ; + query_many_color[0].pixel = 10 ; + query_many_color[0].format = XcmsRGBFormat ; + query_many_color[1].pixel = 11 ; + query_many_color[1].format = XcmsRGBFormat ; + XcmsQueryColors(display_good, colormap, + &query_many_color[0], (unsigned int)2, format_good) ; + check_dec(0xff00, colors[0].spec.RGB.red, "red") ; + check_dec(0x0000, colors[0].spec.RGB.green, "green") ; + check_dec(0x0000, colors[0].spec.RGB.blue, "blue") ; + check_dec(0x0000, colors[1].spec.RGB.red, "red") ; + check_dec(0xff00, colors[1].spec.RGB.green, "green") ; + check_dec(0x0000, colors[1].spec.RGB.blue, "blue") ; + } + XSync(display_arg, 0); + +/****** + * cleanup code for this service. + ******/ + if (regr_args.l_flags.cleanup) + { + cleanup_status = REGR_NORMAL; + } + XSync(display_arg, 0); + + if (errflg) { /* if there was an error ... */ + errcnt++; /* ...increment the error count */ + (void)strcpy(fmtstr, "\nEnd of error report\n"); + message(fmtstr, fmt_lst, 0); + (void)strcpy(fmtstr, "*********************\n"); + message(fmtstr, fmt_lst, 0); + } + +/***** + * clear all flags + *****/ + chkflg = 0; + regr_args.l_flags.bufrout = 0; + + dumpbuf(); +} + + +>>ASSERTION Good C +If the implementation is X11R5 or later: +A call to xname +shall convert the colors specified in the array of +.A XcmsColor +structure into RGB values for the pixels and return XcmsSuccess. +>>CODE + +#if XT_X_RELEASE > 4 + display_arg = Dsp; +/* + * Create a GC to save environmental data in + */ + gc_save = XCreateGC(display_arg,XRootWindow(display_arg,XDefaultScreen(display_arg)),(unsigned long)0,(XGCValues *)0); + + regr_args.l_flags.check = 0; + regr_args.l_flags.nostat = 0; + regr_args.l_flags.perf = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 0; + regr_args.l_flags.chkdpy = 0; + regr_args.l_flags.verbose = 0; + regr_args.iter = 1; /* execute service once */ + estatus[0] = 1; + + +/****** + * User defined initialization code for test case sets + ******/ + display_good = display_arg; + +/***** + * Test wide set up + *****/ + + screen_good = XDefaultScreen(display_good); + + depth_good = DisplayPlanes( display_good, screen_good ); + + visual_good = XDefaultVisual(display_good, screen_good ); + + if ((visual_good->class == StaticGray) || + (visual_good->class == StaticColor) || + (visual_good->class == TrueColor)) + writeable_colormaps = 0 ; + + if ( writeable_colormaps ) { + colormap_good = XCreateColormap( + display_good, + XRootWindow(display_good, screen_good), + visual_good, + AllocAll); + } + + if ( writeable_colormaps ) { + + estatus[0] = 1; + estatus[1] = Success; + + if ((regr_args.l_flags.good == 0) || (estatus[1] == Success)) { +/********************/ + step ("Testing XcmsStoreColors for Success\n"); +/********************/ + regr_args.l_flags.check = 1; + regr_args.l_flags.setup = 1; + regr_args.l_flags.cleanup = 1; + regr_args.l_flags.chksta = 0; + regr_args.l_flags.chkdpy = 0; + + { + write_many_color[0].format = XcmsRGBFormat ; + write_many_color[0].pixel = 10 ; + write_many_color[0].spec.RGB.red = 0xff00 ; + write_many_color[0].spec.RGB.green = 0x0000 ; + write_many_color[0].spec.RGB.blue = 0x00000 ; + write_many_color[1].format = XcmsRGBFormat ; + write_many_color[1].pixel = 11 ; + write_many_color[1].spec.RGB.red = 0x0000 ; + write_many_color[1].spec.RGB.green = 0xff00 ; + write_many_color[1].spec.RGB.blue = 0x0000 ; + svccmsStoreColors( + display_good, + colormap_good, + &write_many_color[0], + (unsigned int)2, + (Bool *)0 + ) ; + } + } /* end if */ + } else + message("Warning: not a writeable colormap\n", NULL, 0) ; + tet_result(TET_PASS); +#else + tet_infoline("INFO: Implementation not X11R5 or greater"); + tet_result(TET_UNSUPPORTED); +#endif +>>ASSERTION Good C +If the implementation is X11R5 or later: +If the color cell is unallocated or is allocated read-only a call to +xname shall return the BadAccess error. +>>CODE + +#if XT_X_RELEASE > 4 + display_arg = Dsp; +/* + * Create a GC to save environmental data in + */ + gc_save = XCreateGC(display_arg,XRootWindow(display_arg,XDefaultScreen(display_arg)),(unsigned long)0,(XGCValues *)0); + + regr_args.l_flags.check = 0; + regr_args.l_flags.nostat = 0; + regr_args.l_flags.perf = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 0; + regr_args.l_flags.chkdpy = 0; + regr_args.l_flags.verbose = 0; + regr_args.iter = 1; /* execute service once */ + estatus[0] = 1; + + +/****** + * User defined initialization code for test case sets + ******/ + display_good = display_arg; + +/***** + * Test wide set up + *****/ + + screen_good = XDefaultScreen(display_good); + + depth_good = DisplayPlanes( display_good, screen_good ); + + visual_good = XDefaultVisual(display_good, screen_good ); + + if ((visual_good->class == StaticGray) || + (visual_good->class == StaticColor) || + (visual_good->class == TrueColor)) + writeable_colormaps = 0 ; + + if ( writeable_colormaps ) { + colormap_good = XCreateColormap( + display_good, + XRootWindow(display_good, screen_good), + visual_good, + AllocAll); + } + if ( writeable_colormaps ) { + + estatus[0] = 1; + estatus[1] = BadAccess ; + + if ((regr_args.l_flags.good == 0) || (estatus[1] == Success)) { +/********************/ + step ("Testing XcmsStoreColors for BadAccess\n"); +/********************/ + regr_args.l_flags.check = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 1; + regr_args.l_flags.chkdpy = 0; + + { + colormap_dfl = XDefaultColormap(display_good, screen_good ); + write_many_color[0].format = XcmsRGBFormat ; + write_many_color[0].pixel = 10 ; + write_many_color[0].spec.RGB.red = 0xffff ; + write_many_color[0].spec.RGB.green = 0x0 ; + write_many_color[0].spec.RGB.blue = 0x0 ; + write_many_color[1].format = XcmsRGBFormat ; + write_many_color[1].pixel = 11 ; + write_many_color[1].spec.RGB.red = 0x0 ; + write_many_color[1].spec.RGB.green = 0xffff ; + write_many_color[1].spec.RGB.blue = 0x0 ; + svccmsStoreColors( + display_good, + colormap_dfl, + write_many_color, + 2, + (Bool )0 + ) ; + } + } /* end if */ + } else + message("Warning: not a writeable colormap\n", NULL, 0) ; + tet_result(TET_PASS); +#else + tet_infoline("INFO: Implementation not X11R5 or greater"); + tet_result(TET_UNSUPPORTED); +#endif + +>>ASSERTION Good C +If the implementation is X11R5 or later: +If the value for the colormap argument does not name a defined colormap, a +call to xname +shall return the BadColor error code. +>>CODE + +#if XT_X_RELEASE > 4 + display_arg = Dsp; +/* + * Create a GC to save environmental data in + */ + gc_save = XCreateGC(display_arg,XRootWindow(display_arg,XDefaultScreen(display_arg)),(unsigned long)0,(XGCValues *)0); + + regr_args.l_flags.check = 0; + regr_args.l_flags.nostat = 0; + regr_args.l_flags.perf = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 0; + regr_args.l_flags.chkdpy = 0; + regr_args.l_flags.verbose = 0; + regr_args.iter = 1; /* execute service once */ + estatus[0] = 1; + + +/****** + * User defined initialization code for test case sets + ******/ + display_good = display_arg; + +/***** + * Test wide set up + *****/ + + screen_good = XDefaultScreen(display_good); + + depth_good = DisplayPlanes( display_good, screen_good ); + + visual_good = XDefaultVisual(display_good, screen_good ); + + if ((visual_good->class == StaticGray) || + (visual_good->class == StaticColor) || + (visual_good->class == TrueColor)) + writeable_colormaps = 0 ; + + if ( writeable_colormaps ) { + colormap_good = XCreateColormap( + display_good, + XRootWindow(display_good, screen_good), + visual_good, + AllocAll); + } + if ( writeable_colormaps ) { + + chkflg = 1 ; + estatus[0] = 1; + estatus[1] = BadColor ; + + if ((regr_args.l_flags.good == 0) || (estatus[1] == Success)) { +/********************/ + step ("Testing XcmsStoreColors for BadColor\n"); +/********************/ + regr_args.l_flags.check = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 1; + regr_args.l_flags.chkdpy = 0; + + { + Colormap colormap_bad = (Colormap)-1 ; + write_many_color[0].format = XcmsRGBFormat ; + write_many_color[0].pixel = 10 ; + write_many_color[0].spec.RGB.red = 0xffff ; + write_many_color[0].spec.RGB.green = 0x0 ; + write_many_color[0].spec.RGB.blue = 0x0 ; + write_many_color[1].format = XcmsRGBFormat ; + write_many_color[1].pixel = 11 ; + write_many_color[1].spec.RGB.red = 0x0 ; + write_many_color[1].spec.RGB.green = 0xffff ; + write_many_color[1].spec.RGB.blue = 0x0 ; + svccmsStoreColors( + display_good, + colormap_bad, + write_many_color, + 2, + (Bool )0 + ) ; + } + } /* end if */ + } else + message("Warning: not a writeable colormap\n", NULL, 0) ; + tet_result(TET_PASS); +#else + tet_infoline("INFO: Implementation not X11R5 or greater"); + tet_result(TET_UNSUPPORTED); +#endif +>>ASSERTION Good C +If the implementation is X11R5 or later: +If a numeric value falls outside of the range of values accepted by +the request, a call to xname shall return the BadValue error code. +>>CODE + +#if XT_X_RELEASE > 4 + display_arg = Dsp; +/* + * Create a GC to save environmental data in + */ + gc_save = XCreateGC(display_arg,XRootWindow(display_arg,XDefaultScreen(display_arg)),(unsigned long)0,(XGCValues *)0); + + regr_args.l_flags.check = 0; + regr_args.l_flags.nostat = 0; + regr_args.l_flags.perf = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 0; + regr_args.l_flags.chkdpy = 0; + regr_args.l_flags.verbose = 0; + regr_args.iter = 1; /* execute service once */ + estatus[0] = 1; + + +/****** + * User defined initialization code for test case sets + ******/ + display_good = display_arg; + +/***** + * Test wide set up + *****/ + + screen_good = XDefaultScreen(display_good); + + depth_good = DisplayPlanes( display_good, screen_good ); + + visual_good = XDefaultVisual(display_good, screen_good ); + + if ((visual_good->class == StaticGray) || + (visual_good->class == StaticColor) || + (visual_good->class == TrueColor)) + writeable_colormaps = 0 ; + + if ( writeable_colormaps ) { + colormap_good = XCreateColormap( + display_good, + XRootWindow(display_good, screen_good), + visual_good, + AllocAll); + } + if ( writeable_colormaps ) { + + estatus[0] = 1; + estatus[1] = BadValue ; + + if ((regr_args.l_flags.good == 0) || (estatus[1] == Success)) { +/********************/ + step ("Testing XcmsStoreColors for BadValue\n"); +/********************/ + regr_args.l_flags.check = 0; + regr_args.l_flags.setup = 0; + regr_args.l_flags.cleanup = 0; + regr_args.l_flags.chksta = 1; + regr_args.l_flags.chkdpy = 0; + + { + write_many_color[0].format = XcmsRGBFormat ; + write_many_color[0].pixel = -998 ; + write_many_color[0].spec.RGB.red = 0xffff ; + write_many_color[0].spec.RGB.green = 0x0 ; + write_many_color[0].spec.RGB.blue = 0x0 ; + write_many_color[1].format = XcmsRGBFormat ; + write_many_color[1].pixel = -999 ; + write_many_color[1].spec.RGB.red = 0x0 ; + write_many_color[1].spec.RGB.green = 0xffff ; + write_many_color[1].spec.RGB.blue = 0x0 ; + svccmsStoreColors( + display_good, + colormap_good, + write_many_color, + 2, + (Bool )0 + ) ; + + } + } /* end if */ + } else + message("Warning: not a writeable colormap\n", NULL, 0) ; + tet_result(TET_PASS); +#else + tet_infoline("INFO: Implementation not X11R5 or greater"); + tet_result(TET_UNSUPPORTED); +#endif |