d1ab35
diff -up Tk-804.028/pTk/mTk/generic/tkConfig.c.seg Tk-804.028/pTk/mTk/generic/tkConfig.c
d1ab35
--- Tk-804.028/pTk/mTk/generic/tkConfig.c.seg	2008-03-11 23:29:39.000000000 -0400
d1ab35
+++ Tk-804.028/pTk/mTk/generic/tkConfig.c	2008-03-11 23:28:09.000000000 -0400
d1ab35
@@ -1210,11 +1210,11 @@ GetOptionFromObj(interp, objPtr, tablePt
d1ab35
      * First, check to see if the object already has the answer cached.
d1ab35
      */
d1ab35
 
d1ab35
-    if (objPtr->typePtr == &tkOptionObjType) {
d1ab35
+/*    if (objPtr->typePtr == &tkOptionObjType) {
d1ab35
         if (objPtr->internalRep.twoPtrValue.ptr1 == (VOID *) tablePtr) {
d1ab35
             return (Option *) objPtr->internalRep.twoPtrValue.ptr2;
d1ab35
         }
d1ab35
-    }
d1ab35
+    }*/
d1ab35
 
d1ab35
     /*
d1ab35
      * The answer isn't cached.
d1ab35
@@ -2277,9 +2277,15 @@ Tk_GetOptionValue(interp, recordPtr, opt
d1ab35
     if (optionPtr == NULL) {
d1ab35
 	return NULL;
d1ab35
     }
d1ab35
+
d1ab35
+    if (optionPtr->specPtr == NULL) {
d1ab35
+	return NULL;
d1ab35
+    }
d1ab35
+
d1ab35
     if (optionPtr->specPtr->type == TK_OPTION_SYNONYM) {
d1ab35
 	optionPtr = optionPtr->extra.synonymPtr;
d1ab35
     }
d1ab35
+
d1ab35
     if (optionPtr->specPtr->objOffset >= 0) {
d1ab35
 	resultPtr = *((Tcl_Obj **) (recordPtr + optionPtr->specPtr->objOffset));
d1ab35
 	if (resultPtr == NULL) {