From ceaa97ff5b78db364b1608ede26e3dba9050be0e Mon Sep 17 00:00:00 2001 From: Roberto Ierusalimschy <roberto@inf.puc-rio.br> Date: Thu, 13 Apr 2000 13:46:43 -0300 Subject: tonumber must return `nil' when convertion fails. --- lbuiltin.c | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/lbuiltin.c b/lbuiltin.c index 44ed1c91..9a0939fd 100644 --- a/lbuiltin.c +++ b/lbuiltin.c @@ -1,5 +1,5 @@ /* -** $Id: lbuiltin.c,v 1.101 2000/04/03 13:20:33 roberto Exp roberto $ +** $Id: lbuiltin.c,v 1.102 2000/04/04 20:49:32 roberto Exp roberto $ ** Built-in functions ** See Copyright Notice in lua.h */ @@ -157,8 +157,10 @@ void luaB_tonumber (lua_State *L) { int base = luaL_opt_int(L, 2, 10); if (base == 10) { /* standard conversion */ lua_Object o = luaL_nonnullarg(L, 1); - if (lua_isnumber(L, o)) lua_pushnumber(L, lua_getnumber(L, o)); - else lua_pushnil(L); /* not a number */ + if (lua_isnumber(L, o)) { + lua_pushnumber(L, lua_getnumber(L, o)); + return; + } } else { const char *s1 = luaL_check_string(L, 1); @@ -166,11 +168,15 @@ void luaB_tonumber (lua_State *L) { Number n; luaL_arg_check(L, 0 <= base && base <= 36, 2, "base out of range"); n = strtoul(s1, &s2, base); - if (s1 == s2) return; /* no valid digits: return nil */ - while (isspace((unsigned char)*s2)) s2++; /* skip trailing spaces */ - if (*s2) return; /* invalid trailing character: return nil */ - lua_pushnumber(L, n); + if (s1 != s2) { /* at least one valid digit? */ + while (isspace((unsigned char)*s2)) s2++; /* skip trailing spaces */ + if (*s2 == '\0') { /* no invalid trailing characters? */ + lua_pushnumber(L, n); + return; + } + } } + lua_pushnil(L); /* else not a number */ } -- cgit v1.2.3-55-g6feb