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