diff options
Diffstat (limited to 'generic/tclDictObj.c')
| -rw-r--r-- | generic/tclDictObj.c | 68 | 
1 files changed, 33 insertions, 35 deletions
| diff --git a/generic/tclDictObj.c b/generic/tclDictObj.c index eb3625e..e31d708 100644 --- a/generic/tclDictObj.c +++ b/generic/tclDictObj.c @@ -91,22 +91,22 @@ static const EnsembleImplMap implementationMap[] = {      {"append",	DictAppendCmd,	TclCompileDictAppendCmd, NULL, NULL, 0 },      {"create",	DictCreateCmd,	TclCompileDictCreateCmd, NULL, NULL, 0 },      {"exists",	DictExistsCmd,	TclCompileDictExistsCmd, NULL, NULL, 0 }, -    {"filter",	DictFilterCmd, NULL, NULL, NULL, 0 }, +    {"filter",	DictFilterCmd,	NULL, NULL, NULL, 0 },      {"for",	NULL,		TclCompileDictForCmd, DictForNRCmd, NULL, 0 },      {"get",	DictGetCmd,	TclCompileDictGetCmd, NULL, NULL, 0 },      {"incr",	DictIncrCmd,	TclCompileDictIncrCmd, NULL, NULL, 0 }, -    {"info",	DictInfoCmd, NULL, NULL, NULL, 0 }, -    {"keys",	DictKeysCmd, NULL, NULL, NULL, 0 }, +    {"info",	DictInfoCmd,	TclCompileBasic1ArgCmd, NULL, NULL, 0 }, +    {"keys",	DictKeysCmd,	TclCompileBasic1Or2ArgCmd, NULL, NULL, 0 },      {"lappend",	DictLappendCmd,	TclCompileDictLappendCmd, NULL, NULL, 0 },      {"map", 	NULL,       	TclCompileDictMapCmd, DictMapNRCmd, NULL, 0 },      {"merge",	DictMergeCmd,	TclCompileDictMergeCmd, NULL, NULL, 0 }, -    {"remove",	DictRemoveCmd, NULL, NULL, NULL, 0 }, +    {"remove",	DictRemoveCmd,	TclCompileBasicMin1ArgCmd, NULL, NULL, 0 },      {"replace",	DictReplaceCmd, NULL, NULL, NULL, 0 },      {"set",	DictSetCmd,	TclCompileDictSetCmd, NULL, NULL, 0 }, -    {"size",	DictSizeCmd, NULL, NULL, NULL, 0 }, +    {"size",	DictSizeCmd,	TclCompileBasic1ArgCmd, NULL, NULL, 0 },      {"unset",	DictUnsetCmd,	TclCompileDictUnsetCmd, NULL, NULL, 0 },      {"update",	DictUpdateCmd,	TclCompileDictUpdateCmd, NULL, NULL, 0 }, -    {"values",	DictValuesCmd, NULL, NULL, NULL, 0 }, +    {"values",	DictValuesCmd,	TclCompileBasic1Or2ArgCmd, NULL, NULL, 0 },      {"with",	DictWithCmd,	TclCompileDictWithCmd, NULL, NULL, 0 },      {NULL, NULL, NULL, NULL, NULL, 0}  }; @@ -361,7 +361,7 @@ DupDictInternalRep(      Tcl_Obj *srcPtr,      Tcl_Obj *copyPtr)  { -    Dict *oldDict = srcPtr->internalRep.otherValuePtr; +    Dict *oldDict = srcPtr->internalRep.twoPtrValue.ptr1;      Dict *newDict = ckalloc(sizeof(Dict));      ChainEntry *cPtr; @@ -396,7 +396,7 @@ DupDictInternalRep(       * Store in the object.       */ -    copyPtr->internalRep.otherValuePtr = newDict; +    copyPtr->internalRep.twoPtrValue.ptr1 = newDict;      copyPtr->typePtr = &tclDictType;  } @@ -422,14 +422,12 @@ static void  FreeDictInternalRep(      Tcl_Obj *dictPtr)  { -    Dict *dict = dictPtr->internalRep.otherValuePtr; +    Dict *dict = dictPtr->internalRep.twoPtrValue.ptr1;      dict->refcount--;      if (dict->refcount <= 0) {  	DeleteDict(dict);      } - -    dictPtr->internalRep.otherValuePtr = NULL;	/* Belt and braces! */      dictPtr->typePtr = NULL;  } @@ -489,7 +487,7 @@ UpdateStringOfDict(  {  #define LOCAL_SIZE 20      int localFlags[LOCAL_SIZE], *flagPtr = NULL; -    Dict *dict = dictPtr->internalRep.otherValuePtr; +    Dict *dict = dictPtr->internalRep.twoPtrValue.ptr1;      ChainEntry *cPtr;      Tcl_Obj *keyPtr, *valuePtr;      int i, length, bytesNeeded = 0; @@ -715,7 +713,7 @@ SetDictFromAny(      dict->epoch = 0;      dict->chain = NULL;      dict->refcount = 1; -    objPtr->internalRep.otherValuePtr = dict; +    objPtr->internalRep.twoPtrValue.ptr1 = dict;      objPtr->typePtr = &tclDictType;      return TCL_OK; @@ -784,7 +782,7 @@ TclTraceDictPath(  	    return NULL;  	}      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      if (flags & DICT_PATH_UPDATE) {  	dict->chain = NULL;      } @@ -827,7 +825,7 @@ TclTraceDictPath(  	    }  	} -	newDict = tmpObj->internalRep.otherValuePtr; +	newDict = tmpObj->internalRep.twoPtrValue.ptr1;  	if (flags & DICT_PATH_UPDATE) {  	    if (Tcl_IsShared(tmpObj)) {  		TclDecrRefCount(tmpObj); @@ -835,7 +833,7 @@ TclTraceDictPath(  		Tcl_IncrRefCount(tmpObj);  		Tcl_SetHashValue(hPtr, tmpObj);  		dict->epoch++; -		newDict = tmpObj->internalRep.otherValuePtr; +		newDict = tmpObj->internalRep.twoPtrValue.ptr1;  	    }  	    newDict->chain = dictPtr; @@ -870,17 +868,17 @@ static void  InvalidateDictChain(      Tcl_Obj *dictObj)  { -    Dict *dict = dictObj->internalRep.otherValuePtr; +    Dict *dict = dictObj->internalRep.twoPtrValue.ptr1;      do { -	Tcl_InvalidateStringRep(dictObj); +	TclInvalidateStringRep(dictObj);  	dict->epoch++;  	dictObj = dict->chain;  	if (dictObj == NULL) {  	    break;  	}  	dict->chain = NULL; -	dict = dictObj->internalRep.otherValuePtr; +	dict = dictObj->internalRep.twoPtrValue.ptr1;      } while (dict != NULL);  } @@ -927,9 +925,9 @@ Tcl_DictObjPut(      }      if (dictPtr->bytes != NULL) { -	Tcl_InvalidateStringRep(dictPtr); +	TclInvalidateStringRep(dictPtr);      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      hPtr = CreateChainEntry(dict, keyPtr, &isNew);      Tcl_IncrRefCount(valuePtr);      if (!isNew) { @@ -980,7 +978,7 @@ Tcl_DictObjGet(  	}      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      hPtr = Tcl_FindHashEntry(&dict->table, keyPtr);      if (hPtr == NULL) {  	*valuePtrPtr = NULL; @@ -1029,9 +1027,9 @@ Tcl_DictObjRemove(      }      if (dictPtr->bytes != NULL) { -	Tcl_InvalidateStringRep(dictPtr); +	TclInvalidateStringRep(dictPtr);      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      if (DeleteChainEntry(dict, keyPtr)) {  	dict->epoch++;      } @@ -1071,7 +1069,7 @@ Tcl_DictObjSize(  	}      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      *sizePtr = dict->table.numEntries;      return TCL_OK;  } @@ -1126,7 +1124,7 @@ Tcl_DictObjFirst(  	}      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      cPtr = dict->entryChainHead;      if (cPtr == NULL) {  	searchPtr->epoch = -1; @@ -1301,7 +1299,7 @@ Tcl_DictObjPutKeyList(  	return TCL_ERROR;      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      hPtr = CreateChainEntry(dict, keyv[keyc-1], &isNew);      Tcl_IncrRefCount(valuePtr);      if (!isNew) { @@ -1357,7 +1355,7 @@ Tcl_DictObjRemoveKeyList(  	return TCL_ERROR;      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      DeleteChainEntry(dict, keyv[keyc-1]);      InvalidateDictChain(dictPtr);      return TCL_OK; @@ -1397,13 +1395,13 @@ Tcl_NewDictObj(void)      Dict *dict;      TclNewObj(dictPtr); -    Tcl_InvalidateStringRep(dictPtr); +    TclInvalidateStringRep(dictPtr);      dict = ckalloc(sizeof(Dict));      InitChainTable(dict);      dict->epoch = 0;      dict->chain = NULL;      dict->refcount = 1; -    dictPtr->internalRep.otherValuePtr = dict; +    dictPtr->internalRep.twoPtrValue.ptr1 = dict;      dictPtr->typePtr = &tclDictType;      return dictPtr;  #endif @@ -1446,13 +1444,13 @@ Tcl_DbNewDictObj(      Dict *dict;      TclDbNewObj(dictPtr, file, line); -    Tcl_InvalidateStringRep(dictPtr); +    TclInvalidateStringRep(dictPtr);      dict = ckalloc(sizeof(Dict));      InitChainTable(dict);      dict->epoch = 0;      dict->chain = NULL;      dict->refcount = 1; -    dictPtr->internalRep.otherValuePtr = dict; +    dictPtr->internalRep.twoPtrValue.ptr1 = dict;      dictPtr->typePtr = &tclDictType;      return dictPtr;  #else /* !TCL_MEM_DEBUG */ @@ -2064,7 +2062,7 @@ DictInfoCmd(  	    return result;  	}      } -    dict = dictPtr->internalRep.otherValuePtr; +    dict = dictPtr->internalRep.twoPtrValue.ptr1;      statsStr = Tcl_HashStats(&dict->table);      Tcl_SetObjResult(interp, Tcl_NewStringObj(statsStr, -1)); @@ -2179,7 +2177,7 @@ DictIncrCmd(  	}      }      if (code == TCL_OK) { -	Tcl_InvalidateStringRep(dictPtr); +	TclInvalidateStringRep(dictPtr);  	valuePtr = Tcl_ObjSetVar2(interp, objv[1], NULL,  		dictPtr, TCL_LEAVE_ERR_MSG);  	if (valuePtr == NULL) { @@ -2268,7 +2266,7 @@ DictLappendCmd(      if (allocatedValue) {  	Tcl_DictObjPut(interp, dictPtr, objv[2], valuePtr);      } else if (dictPtr->bytes != NULL) { -	Tcl_InvalidateStringRep(dictPtr); +	TclInvalidateStringRep(dictPtr);      }      resultPtr = Tcl_ObjSetVar2(interp, objv[1], NULL, dictPtr, | 
