Main 'mainposition' replaced by 'mainpositionTV'

Handle values in table keys as the special cases they are, and not
the other way around.
This commit is contained in:
Roberto Ierusalimschy 2021-11-25 11:07:17 -03:00
parent 48835c76c8
commit ad3942adba
1 changed files with 16 additions and 19 deletions

View File

@ -146,26 +146,24 @@ static int l_hashfloat (lua_Number n) {
/* /*
** returns the 'main' position of an element in a table (that is, ** returns the 'main' position of an element in a table (that is,
** the index of its hash value). The key comes broken (tag in 'ktt' ** the index of its hash value).
** and value in 'vkl') so that we can call it on keys inserted into
** nodes.
*/ */
static Node *mainposition (const Table *t, int ktt, const Value kvl) { static Node *mainpositionTV (const Table *t, const TValue *key) {
switch (withvariant(ktt)) { switch (ttypetag(key)) {
case LUA_VNUMINT: { case LUA_VNUMINT: {
lua_Integer key = ivalueraw(kvl); lua_Integer i = ivalue(key);
return hashint(t, key); return hashint(t, i);
} }
case LUA_VNUMFLT: { case LUA_VNUMFLT: {
lua_Number n = fltvalueraw(kvl); lua_Number n = fltvalue(key);
return hashmod(t, l_hashfloat(n)); return hashmod(t, l_hashfloat(n));
} }
case LUA_VSHRSTR: { case LUA_VSHRSTR: {
TString *ts = tsvalueraw(kvl); TString *ts = tsvalue(key);
return hashstr(t, ts); return hashstr(t, ts);
} }
case LUA_VLNGSTR: { case LUA_VLNGSTR: {
TString *ts = tsvalueraw(kvl); TString *ts = tsvalue(key);
return hashpow2(t, luaS_hashlongstr(ts)); return hashpow2(t, luaS_hashlongstr(ts));
} }
case LUA_VFALSE: case LUA_VFALSE:
@ -173,26 +171,25 @@ static Node *mainposition (const Table *t, int ktt, const Value kvl) {
case LUA_VTRUE: case LUA_VTRUE:
return hashboolean(t, 1); return hashboolean(t, 1);
case LUA_VLIGHTUSERDATA: { case LUA_VLIGHTUSERDATA: {
void *p = pvalueraw(kvl); void *p = pvalue(key);
return hashpointer(t, p); return hashpointer(t, p);
} }
case LUA_VLCF: { case LUA_VLCF: {
lua_CFunction f = fvalueraw(kvl); lua_CFunction f = fvalue(key);
return hashpointer(t, f); return hashpointer(t, f);
} }
default: { default: {
GCObject *o = gcvalueraw(kvl); GCObject *o = gcvalue(key);
return hashpointer(t, o); return hashpointer(t, o);
} }
} }
} }
/* l_sinline Node *mainpositionfromnode (const Table *t, Node *nd) {
** Returns the main position of an element given as a 'TValue' TValue key;
*/ getnodekey(cast(lua_State *, NULL), &key, nd);
static Node *mainpositionTV (const Table *t, const TValue *key) { return mainpositionTV(t, &key);
return mainposition(t, rawtt(key), valraw(key));
} }
@ -691,7 +688,7 @@ void luaH_newkey (lua_State *L, Table *t, const TValue *key, TValue *value) {
return; return;
} }
lua_assert(!isdummy(t)); lua_assert(!isdummy(t));
othern = mainposition(t, keytt(mp), keyval(mp)); othern = mainpositionfromnode(t, mp);
if (othern != mp) { /* is colliding node out of its main position? */ if (othern != mp) { /* is colliding node out of its main position? */
/* yes; move colliding node into free position */ /* yes; move colliding node into free position */
while (othern + gnext(othern) != mp) /* find previous */ while (othern + gnext(othern) != mp) /* find previous */