lua_arith gets no fake operand for unary minus

This commit is contained in:
Roberto Ierusalimschy 2011-04-05 11:26:23 -03:00
parent 83abbac946
commit 119d5e46d5
1 changed files with 15 additions and 7 deletions

22
lapi.c
View File

@ -1,5 +1,5 @@
/* /*
** $Id: lapi.c,v 2.143 2010/12/20 19:40:07 roberto Exp roberto $ ** $Id: lapi.c,v 2.144 2010/12/29 18:00:23 roberto Exp roberto $
** Lua API ** Lua API
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -283,15 +283,23 @@ LUA_API int lua_rawequal (lua_State *L, int index1, int index2) {
LUA_API void lua_arith (lua_State *L, int op) { LUA_API void lua_arith (lua_State *L, int op) {
StkId o1; /* 1st operand */
StkId o2; /* 2nd operand */
lua_lock(L); lua_lock(L);
api_checknelems(L, 2); if (op != LUA_OPUNM) /* all other operations expect two operands */
if (ttisnumber(L->top - 2) && ttisnumber(L->top - 1)) { api_checknelems(L, 2);
changenvalue(L->top - 2, else { /* for unary minus, add fake 2nd operand */
luaO_arith(op, nvalue(L->top - 2), nvalue(L->top - 1))); api_checknelems(L, 1);
setobjs2s(L, L->top, L->top - 1);
L->top++;
}
o1 = L->top - 2;
o2 = L->top - 1;
if (ttisnumber(o1) && ttisnumber(o2)) {
changenvalue(o1, luaO_arith(op, nvalue(o1), nvalue(o2)));
} }
else else
luaV_arith(L, L->top - 2, L->top - 2, L->top - 1, luaV_arith(L, o1, o1, o2, cast(TMS, op - LUA_OPADD + TM_ADD));
cast(TMS, op - LUA_OPADD + TM_ADD));
L->top--; L->top--;
lua_unlock(L); lua_unlock(L);
} }