mirror of https://github.com/rusefi/lua.git
more robust implementation for table.insert
This commit is contained in:
parent
502d8f9a06
commit
056b6a8ef4
29
ltablib.c
29
ltablib.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: ltablib.c,v 1.36 2005/09/20 17:56:47 roberto Exp roberto $
|
** $Id: ltablib.c,v 1.37 2005/10/21 13:47:42 roberto Exp roberto $
|
||||||
** Library for Table Manipulation
|
** Library for Table Manipulation
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -90,16 +90,23 @@ static int setn (lua_State *L) {
|
||||||
static int tinsert (lua_State *L) {
|
static int tinsert (lua_State *L) {
|
||||||
int e = aux_getn(L, 1) + 1; /* first empty element */
|
int e = aux_getn(L, 1) + 1; /* first empty element */
|
||||||
int pos; /* where to insert new element */
|
int pos; /* where to insert new element */
|
||||||
if (lua_isnone(L, 3)) /* called with only 2 arguments */
|
switch (lua_gettop(L)) {
|
||||||
pos = e; /* insert new element at the end */
|
case 2: { /* called with only 2 arguments */
|
||||||
else {
|
pos = e; /* insert new element at the end */
|
||||||
int i;
|
break;
|
||||||
pos = luaL_checkint(L, 2); /* 2nd argument is the position */
|
}
|
||||||
if (pos > e) e = pos; /* `grow' array if necessary */
|
case 3: {
|
||||||
lua_settop(L, 3); /* function may be called with more than 3 args */
|
int i;
|
||||||
for (i = e; i > pos; i--) { /* move up elements */
|
pos = luaL_checkint(L, 2); /* 2nd argument is the position */
|
||||||
lua_rawgeti(L, 1, i-1);
|
if (pos > e) e = pos; /* `grow' array if necessary */
|
||||||
lua_rawseti(L, 1, i); /* t[i] = t[i-1] */
|
for (i = e; i > pos; i--) { /* move up elements */
|
||||||
|
lua_rawgeti(L, 1, i-1);
|
||||||
|
lua_rawseti(L, 1, i); /* t[i] = t[i-1] */
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default: {
|
||||||
|
return luaL_error(L, "wrong number of arguments to " LUA_QL("insert"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
luaL_setn(L, 1, e); /* new size */
|
luaL_setn(L, 1, e); /* new size */
|
||||||
|
|
Loading…
Reference in New Issue