summaryrefslogtreecommitdiffstats
path: root/generic/tkTest.c
diff options
context:
space:
mode:
authorericm <ericm>2000-09-29 17:55:30 (GMT)
committerericm <ericm>2000-09-29 17:55:30 (GMT)
commit95fc05c4b143e413f10ddc9cb14e4d322cca5e94 (patch)
tree9bdecb1bdde3ea9cc046f83fc3993dbdf3c089b8 /generic/tkTest.c
parent8d93216489667aad5317c07fc1dcc992b86b5b56 (diff)
downloadtk-95fc05c4b143e413f10ddc9cb14e4d322cca5e94.zip
tk-95fc05c4b143e413f10ddc9cb14e4d322cca5e94.tar.gz
tk-95fc05c4b143e413f10ddc9cb14e4d322cca5e94.tar.bz2
* generic/tkTest.c: Fixed tests to use updated API.
* doc/SetOptions.3: * generic/tk.h: * generic/tkConfig.c: Changed interface for Tk_CustomOptionSetProc and Tk_CustomOptionGetProc; these now take a pointer to the start of the widget record, and an integer offset to the slot for the option value, instead of just a pointer to the slot. This allows more sophisticated options to do interesting things based on other data in the widget record.
Diffstat (limited to 'generic/tkTest.c')
-rw-r--r--generic/tkTest.c33
1 files changed, 19 insertions, 14 deletions
diff --git a/generic/tkTest.c b/generic/tkTest.c
index b7a5652..891e7f6 100644
--- a/generic/tkTest.c
+++ b/generic/tkTest.c
@@ -13,7 +13,7 @@
* See the file "license.terms" for information on usage and redistribution
* of this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tkTest.c,v 1.13 2000/09/17 21:02:40 ericm Exp $
+ * RCS: @(#) $Id: tkTest.c,v 1.14 2000/09/29 17:55:31 ericm Exp $
*/
#include "tkInt.h"
@@ -190,10 +190,10 @@ static int TestobjconfigObjCmd _ANSI_ARGS_((ClientData dummy,
Tcl_Obj * CONST objv[]));
static int CustomOptionSet _ANSI_ARGS_((ClientData clientData,
Tcl_Interp *interp, Tk_Window tkwin,
- Tcl_Obj **value, char *internalPtr,
+ Tcl_Obj **value, char *recordPtr, int internalOffset,
char *saveInternalPtr, int flags));
static Tcl_Obj *CustomOptionGet _ANSI_ARGS_((ClientData clientData,
- Tk_Window tkwin, char *internalPtr));
+ Tk_Window tkwin, char *recordPtr, int internalOffset));
static void CustomOptionRestore _ANSI_ARGS_((ClientData clientData,
Tk_Window tkwin, char *internalPtr,
char *saveInternalPtr));
@@ -2440,20 +2440,28 @@ TestwrapperCmd(clientData, interp, argc, argv)
*/
static int
-CustomOptionSet(clientData,interp, tkwin, value, internalPtr,
+CustomOptionSet(clientData,interp, tkwin, value, recordPtr, internalOffset,
saveInternalPtr, flags)
ClientData clientData;
Tcl_Interp *interp;
Tk_Window tkwin;
Tcl_Obj **value;
- char *internalPtr;
+ char *recordPtr;
+ int internalOffset;
char *saveInternalPtr;
int flags;
{
int objEmpty, length;
- char *new, *string;
+ char *new, *string, *internalPtr;
objEmpty = 0;
+
+ if (internalOffset >= 0) {
+ internalPtr = recordPtr + internalOffset;
+ } else {
+ internalPtr = NULL;
+ }
+
/*
* See if the object is empty.
*/
@@ -2473,11 +2481,7 @@ CustomOptionSet(clientData,interp, tkwin, value, internalPtr,
} else {
string = Tcl_GetStringFromObj((*value), &length);
Tcl_UtfToUpper(string);
- if (objEmpty) {
- Tcl_SetResult(interp, "expected good value, got \"\"", TCL_STATIC);
- return TCL_ERROR;
- }
- if (strncmp(string, "BAD", (size_t)length) == 0) {
+ if (strcmp(string, "BAD") == 0) {
Tcl_SetResult(interp, "expected good value, got \"BAD\"",
TCL_STATIC);
return TCL_ERROR;
@@ -2499,12 +2503,13 @@ CustomOptionSet(clientData,interp, tkwin, value, internalPtr,
}
static Tcl_Obj *
-CustomOptionGet(clientData, tkwin, internalPtr)
+CustomOptionGet(clientData, tkwin, recordPtr, internalOffset)
ClientData clientData;
Tk_Window tkwin;
- char *internalPtr;
+ char *recordPtr;
+ int internalOffset;
{
- return (Tcl_NewStringObj(*(char **)internalPtr, -1));
+ return (Tcl_NewStringObj(*(char **)(recordPtr + internalOffset), -1));
}
static void