aboutsummaryrefslogtreecommitdiff
path: root/lapi.c
diff options
context:
space:
mode:
authorRoberto Ierusalimschy <roberto@inf.puc-rio.br>2013-05-02 09:37:24 -0300
committerRoberto Ierusalimschy <roberto@inf.puc-rio.br>2013-05-02 09:37:24 -0300
commit67532d5a10f9bdc8ed58c6babbce49788ae3be4d (patch)
tree21d3d9aa16c7406245d670977bde294a38ac92d1 /lapi.c
parent6920a7f2e3f8cbdb9c9d43fca720b9dd459be733 (diff)
downloadlua-67532d5a10f9bdc8ed58c6babbce49788ae3be4d.tar.gz
lua-67532d5a10f9bdc8ed58c6babbce49788ae3be4d.tar.bz2
lua-67532d5a10f9bdc8ed58c6babbce49788ae3be4d.zip
constant folding and API arithmetic with integers
Diffstat (limited to 'lapi.c')
-rw-r--r--lapi.c15
1 files changed, 4 insertions, 11 deletions
diff --git a/lapi.c b/lapi.c
index e870afd2..b8c11eef 100644
--- a/lapi.c
+++ b/lapi.c
@@ -1,5 +1,5 @@
1/* 1/*
2** $Id: lapi.c,v 2.177 2013/04/26 19:51:17 roberto Exp roberto $ 2** $Id: lapi.c,v 2.178 2013/04/29 17:12:50 roberto Exp roberto $
3** Lua API 3** Lua API
4** See Copyright Notice in lua.h 4** See Copyright Notice in lua.h
5*/ 5*/
@@ -297,9 +297,6 @@ LUA_API int lua_rawequal (lua_State *L, int index1, int index2) {
297 297
298 298
299LUA_API void lua_arith (lua_State *L, int op) { 299LUA_API void lua_arith (lua_State *L, int op) {
300 StkId o1; /* 1st operand */
301 StkId o2; /* 2nd operand */
302 lua_Number n1, n2;
303 lua_lock(L); 300 lua_lock(L);
304 if (op != LUA_OPUNM) /* all other operations expect two operands */ 301 if (op != LUA_OPUNM) /* all other operations expect two operands */
305 api_checknelems(L, 2); 302 api_checknelems(L, 2);
@@ -308,13 +305,9 @@ LUA_API void lua_arith (lua_State *L, int op) {
308 setobjs2s(L, L->top, L->top - 1); 305 setobjs2s(L, L->top, L->top - 1);
309 L->top++; 306 L->top++;
310 } 307 }
311 o1 = L->top - 2; 308 /* first operand at top - 2, second at top - 1; result go to top - 2 */
312 o2 = L->top - 1; 309 luaO_arith(L, op, L->top - 2, L->top - 1, L->top - 2);
313 if (tonumber(o1, &n1) && tonumber(o2, &n2)) { 310 L->top--; /* remove second operand */
314 setnvalue(o1, luaO_numarith(op, n1, n2));
315 }
316 else luaT_trybinTM(L, o1, o2, o1, cast(TMS, op - LUA_OPADD + TM_ADD));
317 L->top--;
318 lua_unlock(L); 311 lua_unlock(L);
319} 312}
320 313