|
@@ -1,5 +1,5 @@
|
|
|
/*
|
|
|
-** $Id: lvm.c,v 2.341 2018/02/17 19:20:00 roberto Exp roberto $
|
|
|
+** $Id: lvm.c,v 2.342 2018/02/19 20:06:56 roberto Exp roberto $
|
|
|
** Lua virtual machine
|
|
|
** See Copyright Notice in lua.h
|
|
|
*/
|
|
@@ -90,36 +90,42 @@ int luaV_tonumber_ (const TValue *obj, lua_Number *n) {
|
|
|
** mode == 1: takes the floor of the number
|
|
|
** mode == 2: takes the ceil of the number
|
|
|
*/
|
|
|
-int luaV_flttointeger (const TValue *obj, lua_Integer *p, int mode) {
|
|
|
- if (!ttisfloat(obj))
|
|
|
- return 0;
|
|
|
- else {
|
|
|
- lua_Number n = fltvalue(obj);
|
|
|
- lua_Number f = l_floor(n);
|
|
|
- if (n != f) { /* not an integral value? */
|
|
|
- if (mode == 0) return 0; /* fails if mode demands integral value */
|
|
|
- else if (mode > 1) /* needs ceil? */
|
|
|
- f += 1; /* convert floor to ceil (remember: n != f) */
|
|
|
- }
|
|
|
- return lua_numbertointeger(f, p);
|
|
|
+int luaV_flttointeger (lua_Number n, lua_Integer *p, int mode) {
|
|
|
+ lua_Number f = l_floor(n);
|
|
|
+ if (n != f) { /* not an integral value? */
|
|
|
+ if (mode == 0) return 0; /* fails if mode demands integral value */
|
|
|
+ else if (mode > 1) /* needs ceil? */
|
|
|
+ f += 1; /* convert floor to ceil (remember: n != f) */
|
|
|
}
|
|
|
+ return lua_numbertointeger(f, p);
|
|
|
}
|
|
|
|
|
|
|
|
|
/*
|
|
|
-** try to convert a value to an integer. ("Fast track" is handled
|
|
|
-** by macro 'tointeger'.)
|
|
|
+** try to convert a value to an integer, rounding according to 'mode',
|
|
|
+** without string coercion.
|
|
|
+** ("Fast track" handled by macro 'tointegerns'.)
|
|
|
*/
|
|
|
-int luaV_tointeger (const TValue *obj, lua_Integer *p, int mode) {
|
|
|
- TValue v;
|
|
|
- if (cvt2num(obj) && luaO_str2num(svalue(obj), &v) == vslen(obj) + 1)
|
|
|
- obj = &v; /* change string to its corresponding number */
|
|
|
- if (ttisinteger(obj)) {
|
|
|
+int luaV_tointegerns (const TValue *obj, lua_Integer *p, int mode) {
|
|
|
+ if (ttisfloat(obj))
|
|
|
+ return luaV_flttointeger(fltvalue(obj), p, mode);
|
|
|
+ else if (ttisinteger(obj)) {
|
|
|
*p = ivalue(obj);
|
|
|
return 1;
|
|
|
}
|
|
|
else
|
|
|
- return luaV_flttointeger(obj, p, mode);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+/*
|
|
|
+** try to convert a value to an integer.
|
|
|
+*/
|
|
|
+int luaV_tointeger (const TValue *obj, lua_Integer *p, int mode) {
|
|
|
+ TValue v;
|
|
|
+ if (cvt2num(obj) && luaO_str2num(svalue(obj), &v) == vslen(obj) + 1)
|
|
|
+ obj = &v; /* change string to its corresponding number */
|
|
|
+ return luaV_tointegerns(obj, p, mode);
|
|
|
}
|
|
|
|
|
|
|