mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 13:47:41 +03:00
util-src: Use the luaL_pushfail API added in Lua 5.4 to highlight all failure conditions
Actually just an alias of pushnil, but it does make it more obvious where the failure conditions are, which is good for readability.
This commit is contained in:
parent
b50db46086
commit
625ec0a93f
6 changed files with 70 additions and 49 deletions
|
@ -33,6 +33,9 @@
|
|||
#if (LUA_VERSION_NUM == 501)
|
||||
#define luaL_setfuncs(L, R, N) luaL_register(L, NULL, R)
|
||||
#endif
|
||||
#if (LUA_VERSION_NUM < 504)
|
||||
#define luaL_pushfail lua_pushnil
|
||||
#endif
|
||||
|
||||
/* Enumerate all locally configured IP addresses */
|
||||
|
||||
|
@ -59,7 +62,7 @@ static int lc_local_addresses(lua_State *L) {
|
|||
#ifndef _WIN32
|
||||
|
||||
if(getifaddrs(&addr) < 0) {
|
||||
lua_pushnil(L);
|
||||
luaL_pushfail(L);
|
||||
lua_pushfstring(L, "getifaddrs failed (%d): %s", errno,
|
||||
strerror(errno));
|
||||
return 2;
|
||||
|
@ -141,14 +144,14 @@ static int lc_pton(lua_State *L) {
|
|||
|
||||
case -1:
|
||||
errno_ = errno;
|
||||
lua_pushnil(L);
|
||||
luaL_pushfail(L);
|
||||
lua_pushstring(L, strerror(errno_));
|
||||
lua_pushinteger(L, errno_);
|
||||
return 3;
|
||||
|
||||
default:
|
||||
case 0:
|
||||
lua_pushnil(L);
|
||||
luaL_pushfail(L);
|
||||
lua_pushstring(L, strerror(EINVAL));
|
||||
lua_pushinteger(L, EINVAL);
|
||||
return 3;
|
||||
|
@ -170,7 +173,7 @@ static int lc_ntop(lua_State *L) {
|
|||
family = AF_INET;
|
||||
}
|
||||
else {
|
||||
lua_pushnil(L);
|
||||
luaL_pushfail(L);
|
||||
lua_pushstring(L, strerror(EAFNOSUPPORT));
|
||||
lua_pushinteger(L, EAFNOSUPPORT);
|
||||
return 3;
|
||||
|
@ -179,7 +182,7 @@ static int lc_ntop(lua_State *L) {
|
|||
if(!inet_ntop(family, ipaddr, buf, INET6_ADDRSTRLEN))
|
||||
{
|
||||
errno_ = errno;
|
||||
lua_pushnil(L);
|
||||
luaL_pushfail(L);
|
||||
lua_pushstring(L, strerror(errno_));
|
||||
lua_pushinteger(L, errno_);
|
||||
return 3;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue