mirror of https://github.com/rusefi/lua.git
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:
parent
48835c76c8
commit
ad3942adba
35
ltable.c
35
ltable.c
|
@ -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 */
|
||||||
|
|
Loading…
Reference in New Issue