Revert 5134297. This caused overload ambiguities.
[luabind.git] / src / pcall.cpp
blob66dbeaa189f10ff6fca7b14af4b62d742da1ed99
1 // Copyright (c) 2003 Daniel Wallin and Arvid Norberg
3 // Permission is hereby granted, free of charge, to any person obtaining a
4 // copy of this software and associated documentation files (the "Software"),
5 // to deal in the Software without restriction, including without limitation
6 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
7 // and/or sell copies of the Software, and to permit persons to whom the
8 // Software is furnished to do so, subject to the following conditions:
10 // The above copyright notice and this permission notice shall be included
11 // in all copies or substantial portions of the Software.
13 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF
14 // ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
15 // TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
16 // PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
17 // SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR
18 // ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
19 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE
21 // OR OTHER DEALINGS IN THE SOFTWARE.
23 #define LUABIND_BUILDING
25 #include <luabind/detail/pcall.hpp>
26 #include <luabind/error.hpp>
27 #include <luabind/lua_include.hpp>
29 namespace luabind { namespace detail
31 int pcall(lua_State *L, int nargs, int nresults)
33 pcall_callback_fun e = get_pcall_callback();
34 int en = 0;
35 if ( e )
37 int base = lua_gettop(L) - nargs;
38 lua_pushcfunction(L, e);
39 lua_insert(L, base); // push pcall_callback under chunk and args
40 en = base;
42 int result = lua_pcall(L, nargs, nresults, en);
43 if ( en )
44 lua_remove(L, en); // remove pcall_callback
45 return result;
48 int resume_impl(lua_State *L, int nargs, int)
50 #if LUA_VERSION_NUM >= 501
51 // Lua 5.1 added LUA_YIELD as a possible return value,
52 // this was causing crashes, because the caller expects 0 on success.
53 int res = lua_resume(L, nargs);
54 return (res == LUA_YIELD) ? 0 : res;
55 #else
56 return lua_resume(L, nargs);
57 #endif