mirror of https://github.com/rusefi/lua.git
BUG: table.remove removes last element of a table when given
an out-of-bound index
This commit is contained in:
parent
64ecf24210
commit
9f0d62ad9f
25
bugs
25
bugs
|
@ -1569,6 +1569,31 @@ lstrlib.c:
|
||||||
]],
|
]],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Bug{
|
||||||
|
what = [[table.remove removes last element of a table when given
|
||||||
|
an out-of-bound index]],
|
||||||
|
report = [[Patrick Donnelly, on 11/2007]],
|
||||||
|
since = [[at least 5.0]],
|
||||||
|
example = [[
|
||||||
|
a = {1,2,3}
|
||||||
|
table.remove(a, 4)
|
||||||
|
print(a[3]) --> nil (should be 3)
|
||||||
|
]],
|
||||||
|
patch = [[
|
||||||
|
ltablib.c:
|
||||||
|
@@ -118,7 +118,8 @@
|
||||||
|
static int tremove (lua_State *L) {
|
||||||
|
int e = aux_getn(L, 1);
|
||||||
|
int pos = luaL_optint(L, 2, e);
|
||||||
|
- if (e == 0) return 0; /* table is `empty' */
|
||||||
|
+ if (!(1 <= pos && pos <= e)) /* position is outside bounds? */
|
||||||
|
+ return 0; /* nothing to remove */
|
||||||
|
luaL_setn(L, 1, e - 1); /* t.n = n-1 */
|
||||||
|
lua_rawgeti(L, 1, pos); /* result = t[pos] */
|
||||||
|
for ( ;pos<e; pos++) {
|
||||||
|
]],
|
||||||
|
}
|
||||||
|
|
||||||
Bug{
|
Bug{
|
||||||
what = [[ ]],
|
what = [[ ]],
|
||||||
report = [[ , on ]],
|
report = [[ , on ]],
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: ltablib.c,v 1.40 2007/06/21 13:50:53 roberto Exp roberto $
|
** $Id: ltablib.c,v 1.41 2007/09/12 20:53:24 roberto Exp roberto $
|
||||||
** Library for Table Manipulation
|
** Library for Table Manipulation
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -110,7 +110,8 @@ static int tinsert (lua_State *L) {
|
||||||
static int tremove (lua_State *L) {
|
static int tremove (lua_State *L) {
|
||||||
int e = aux_getn(L, 1);
|
int e = aux_getn(L, 1);
|
||||||
int pos = luaL_optint(L, 2, e);
|
int pos = luaL_optint(L, 2, e);
|
||||||
if (e == 0) return 0; /* table is `empty' */
|
if (!(1 <= pos && pos <= e)) /* position is outside bounds? */
|
||||||
|
return 0; /* nothing to remove */
|
||||||
lua_rawgeti(L, 1, pos); /* result = t[pos] */
|
lua_rawgeti(L, 1, pos); /* result = t[pos] */
|
||||||
for ( ;pos<e; pos++) {
|
for ( ;pos<e; pos++) {
|
||||||
lua_rawgeti(L, 1, pos+1);
|
lua_rawgeti(L, 1, pos+1);
|
||||||
|
|
Loading…
Reference in New Issue