diff options
author | dkf <donal.k.fellows@manchester.ac.uk> | 2004-03-30 21:34:14 (GMT) |
---|---|---|
committer | dkf <donal.k.fellows@manchester.ac.uk> | 2004-03-30 21:34:14 (GMT) |
commit | b5ebf1656938111f1f790346ed24cc0bb450ee69 (patch) | |
tree | 30b9c6cb60172de893480a581b7a07cdbe9f7542 /generic | |
parent | 273d70e6d992c80dad69b0198cb21577ad7b3ba2 (diff) | |
download | tcl-b5ebf1656938111f1f790346ed24cc0bb450ee69.zip tcl-b5ebf1656938111f1f790346ed24cc0bb450ee69.tar.gz tcl-b5ebf1656938111f1f790346ed24cc0bb450ee69.tar.bz2 |
Fixed object hashing bozo-ness. The code as it stood looked like a
cargo-cult hangover from the hashing code in tclHash.c, but this looks
almost identical to that used for literals (which is fast.)
Diffstat (limited to 'generic')
-rw-r--r-- | generic/tclObj.c | 34 |
1 files changed, 12 insertions, 22 deletions
diff --git a/generic/tclObj.c b/generic/tclObj.c index e2d6056..9d71cfe 100644 --- a/generic/tclObj.c +++ b/generic/tclObj.c @@ -11,7 +11,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclObj.c,v 1.55 2004/03/19 18:33:52 kennykb Exp $ + * RCS: @(#) $Id: tclObj.c,v 1.56 2004/03/30 21:34:15 dkf Exp $ */ #include "tclInt.h" @@ -2854,7 +2854,7 @@ AllocObjEntry(tablePtr, keyPtr) hPtr = (Tcl_HashEntry *) ckalloc((unsigned) (sizeof(Tcl_HashEntry))); hPtr->key.oneWordValue = (char *) objPtr; - Tcl_IncrRefCount (objPtr); + Tcl_IncrRefCount(objPtr); return hPtr; } @@ -2897,9 +2897,9 @@ CompareObjKeys(keyPtr, hPtr) * Don't use Tcl_GetStringFromObj as it would prevent l1 and l2 being * in a register. */ - p1 = Tcl_GetString (objPtr1); + p1 = TclGetString(objPtr1); l1 = objPtr1->length; - p2 = Tcl_GetString (objPtr2); + p2 = TclGetString(objPtr2); l2 = objPtr2->length; /* @@ -2941,8 +2941,8 @@ FreeObjEntry(hPtr) { Tcl_Obj *objPtr = (Tcl_Obj *) hPtr->key.oneWordValue; - Tcl_DecrRefCount (objPtr); - ckfree ((char *) hPtr); + Tcl_DecrRefCount(objPtr); + ckfree((char *) hPtr); } /* @@ -2969,13 +2969,10 @@ HashObjKey(tablePtr, keyPtr) VOID *keyPtr; /* Key from which to compute hash value. */ { Tcl_Obj *objPtr = (Tcl_Obj *) keyPtr; - register CONST char *string; - register int length; - register unsigned int result; - register int c; - - string = Tcl_GetString (objPtr); - length = objPtr->length; + CONST char *string = TclGetString(objPtr); + int length = objPtr->length; + unsigned int result = 0; + int i; /* * I tried a zillion different hash functions and asked many other @@ -2993,15 +2990,8 @@ HashObjKey(tablePtr, keyPtr) * works well both for decimal and non-decimal strings. */ - result = 0; - while (length) { - c = *string; - string++; - length--; - if (length == 0) { - break; - } - result += (result<<3) + c; + for (i=0 ; i<length ; i++) { + result += (result << 3) + string[i]; } return result; } |