2013-05-25 00:51:02 +02:00
|
|
|
/*
|
|
|
|
Minetest
|
|
|
|
Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2.1 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public License along
|
|
|
|
with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
/* WARNING!!!! do NOT add this header in any include file or any code file */
|
|
|
|
/* not being a modapi file!!!!!!!! */
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
|
2017-08-17 22:19:39 +02:00
|
|
|
#pragma once
|
2013-05-25 00:51:02 +02:00
|
|
|
|
|
|
|
extern "C" {
|
2013-08-11 04:09:45 +02:00
|
|
|
#include <lua.h>
|
|
|
|
#include <lauxlib.h>
|
2013-05-25 00:51:02 +02:00
|
|
|
}
|
|
|
|
|
2013-08-11 04:09:45 +02:00
|
|
|
#include "common/c_types.h"
|
2013-05-25 00:51:02 +02:00
|
|
|
|
2015-08-25 07:00:56 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
Define our custom indices into the Lua registry table.
|
|
|
|
|
|
|
|
Lua 5.2 and above define the LUA_RIDX_LAST macro. Only numbers above that
|
|
|
|
may be used for custom indices, anything else is reserved.
|
|
|
|
|
|
|
|
Lua 5.1 / LuaJIT do not use any numeric indices (only string indices),
|
|
|
|
so we can use numeric indices freely.
|
|
|
|
*/
|
|
|
|
#ifdef LUA_RIDX_LAST
|
|
|
|
#define CUSTOM_RIDX_BASE ((LUA_RIDX_LAST)+1)
|
|
|
|
#else
|
|
|
|
#define CUSTOM_RIDX_BASE 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define CUSTOM_RIDX_SCRIPTAPI (CUSTOM_RIDX_BASE)
|
|
|
|
#define CUSTOM_RIDX_GLOBALS_BACKUP (CUSTOM_RIDX_BASE + 1)
|
|
|
|
#define CUSTOM_RIDX_CURRENT_MOD_NAME (CUSTOM_RIDX_BASE + 2)
|
2017-06-30 20:14:39 +02:00
|
|
|
#define CUSTOM_RIDX_BACKTRACE (CUSTOM_RIDX_BASE + 3)
|
2015-08-25 07:00:56 +02:00
|
|
|
|
2015-08-25 07:44:53 +02:00
|
|
|
// Pushes the error handler onto the stack and returns its index
|
|
|
|
#define PUSH_ERROR_HANDLER(L) \
|
2017-06-30 20:14:39 +02:00
|
|
|
(lua_rawgeti((L), LUA_REGISTRYINDEX, CUSTOM_RIDX_BACKTRACE), lua_gettop((L)))
|
2015-08-25 07:00:56 +02:00
|
|
|
|
2017-08-20 13:30:50 +02:00
|
|
|
#define PCALL_RESL(L, RES) { \
|
2015-08-12 04:27:54 +02:00
|
|
|
int result_ = (RES); \
|
|
|
|
if (result_ != 0) { \
|
|
|
|
script_error((L), result_, NULL, __FUNCTION__); \
|
|
|
|
} \
|
2017-08-20 13:30:50 +02:00
|
|
|
}
|
2015-08-05 06:49:35 +02:00
|
|
|
|
|
|
|
#define script_run_callbacks(L, nargs, mode) \
|
|
|
|
script_run_callbacks_f((L), (nargs), (mode), __FUNCTION__)
|
|
|
|
|
2013-08-11 04:09:45 +02:00
|
|
|
// What script_run_callbacks does with the return values of callbacks.
|
|
|
|
// Regardless of the mode, if only one callback is defined,
|
|
|
|
// its return value is the total return value.
|
|
|
|
// Modes only affect the case where 0 or >= 2 callbacks are defined.
|
|
|
|
enum RunCallbacksMode
|
|
|
|
{
|
|
|
|
// Returns the return value of the first callback
|
|
|
|
// Returns nil if list of callbacks is empty
|
|
|
|
RUN_CALLBACKS_MODE_FIRST,
|
|
|
|
// Returns the return value of the last callback
|
|
|
|
// Returns nil if list of callbacks is empty
|
|
|
|
RUN_CALLBACKS_MODE_LAST,
|
|
|
|
// If any callback returns a false value, the first such is returned
|
|
|
|
// Otherwise, the first callback's return value (trueish) is returned
|
|
|
|
// Returns true if list of callbacks is empty
|
|
|
|
RUN_CALLBACKS_MODE_AND,
|
|
|
|
// Like above, but stops calling callbacks (short circuit)
|
|
|
|
// after seeing the first false value
|
|
|
|
RUN_CALLBACKS_MODE_AND_SC,
|
|
|
|
// If any callback returns a true value, the first such is returned
|
|
|
|
// Otherwise, the first callback's return value (falseish) is returned
|
|
|
|
// Returns false if list of callbacks is empty
|
|
|
|
RUN_CALLBACKS_MODE_OR,
|
|
|
|
// Like above, but stops calling callbacks (short circuit)
|
|
|
|
// after seeing the first true value
|
|
|
|
RUN_CALLBACKS_MODE_OR_SC,
|
|
|
|
// Note: "a true value" and "a false value" refer to values that
|
2018-06-30 17:11:38 +02:00
|
|
|
// are converted by readParam<bool> to true or false, respectively.
|
2013-08-11 04:09:45 +02:00
|
|
|
};
|
2013-05-25 00:51:02 +02:00
|
|
|
|
2013-11-05 18:06:15 +01:00
|
|
|
std::string script_get_backtrace(lua_State *L);
|
2013-12-18 22:35:55 +01:00
|
|
|
int script_exception_wrapper(lua_State *L, lua_CFunction f);
|
2015-08-12 04:27:54 +02:00
|
|
|
void script_error(lua_State *L, int pcall_result, const char *mod, const char *fxn);
|
2015-08-05 06:49:35 +02:00
|
|
|
void script_run_callbacks_f(lua_State *L, int nargs,
|
|
|
|
RunCallbacksMode mode, const char *fxn);
|
|
|
|
void log_deprecated(lua_State *L, const std::string &message);
|