/* Minetest Copyright (C) 2013 celeron55, Perttu Ahola Copyright (C) 2017 nerzhul, Loic Blot 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. */ #include "l_client.h" #include "l_internal.h" #include "util/string.h" #include "cpp_api/s_base.h" #include "gettext.h" #include "common/c_converter.h" #include "common/c_content.h" #include "lua_api/l_item.h" int ModApiClient::l_get_current_modname(lua_State *L) { lua_rawgeti(L, LUA_REGISTRYINDEX, CUSTOM_RIDX_CURRENT_MOD_NAME); return 1; } // get_last_run_mod() int ModApiClient::l_get_last_run_mod(lua_State *L) { lua_rawgeti(L, LUA_REGISTRYINDEX, CUSTOM_RIDX_CURRENT_MOD_NAME); const char *current_mod = lua_tostring(L, -1); if (current_mod == NULL || current_mod[0] == '\0') { lua_pop(L, 1); lua_pushstring(L, getScriptApiBase(L)->getOrigin().c_str()); } return 1; } // set_last_run_mod(modname) int ModApiClient::l_set_last_run_mod(lua_State *L) { if (!lua_isstring(L, 1)) return 0; const char *mod = lua_tostring(L, 1); getScriptApiBase(L)->setOriginDirect(mod); lua_pushboolean(L, true); return 1; } // display_chat_message(message) int ModApiClient::l_display_chat_message(lua_State *L) { if (!lua_isstring(L, 1)) return 0; std::string message = luaL_checkstring(L, 1); getClient(L)->pushToChatQueue(utf8_to_wide(message)); lua_pushboolean(L, true); return 1; } // show_formspec(formspec) int ModApiClient::l_show_formspec(lua_State *L) { if ( !lua_isstring(L, 1) || !lua_isstring(L, 2) ) return 0; ClientEvent event; event.type = CE_SHOW_LOCAL_FORMSPEC; event.show_formspec.formname = new std::string(luaL_checkstring(L, 1)); event.show_formspec.formspec = new std::string(luaL_checkstring(L, 2)); getClient(L)->pushToEventQueue(event); lua_pushboolean(L, true); return 1; } // send_respawn() int ModApiClient::l_send_respawn(lua_State *L) { getClient(L)->sendRespawn(); return 0; } // gettext(text) int ModApiClient::l_gettext(lua_State *L) { std::string text = strgettext(std::string(luaL_checkstring(L, 1))); lua_pushstring(L, text.c_str()); return 1; } // get_node(pos) // pos = {x=num, y=num, z=num} int ModApiClient::l_get_node(lua_State *L) { // pos v3s16 pos = read_v3s16(L, 1); // Do it bool pos_ok; MapNode n = getClient(L)->getNode(pos, &pos_ok); // Return node pushnode(L, n, getClient(L)->ndef()); return 1; } // get_node_or_nil(pos) // pos = {x=num, y=num, z=num} int ModApiClient::l_get_node_or_nil(lua_State *L) { // pos v3s16 pos = read_v3s16(L, 1); // Do it bool pos_ok; MapNode n = getClient(L)->getNode(pos, &pos_ok); if (pos_ok) { // Return node pushnode(L, n, getClient(L)->ndef()); } else { lua_pushnil(L); } return 1; } int ModApiClient::l_get_wielded_item(lua_State *L) { Client *client = getClient(L); Inventory local_inventory(client->idef()); client->getLocalInventory(local_inventory); InventoryList *mlist = local_inventory.getList("main"); if (mlist && client->getPlayerItem() < mlist->getSize()) { LuaItemStack::create(L, mlist->getItem(client->getPlayerItem())); } else { LuaItemStack::create(L, ItemStack()); } return 1; } void ModApiClient::Initialize(lua_State *L, int top) { API_FCT(get_current_modname); API_FCT(display_chat_message); API_FCT(set_last_run_mod); API_FCT(get_last_run_mod); API_FCT(show_formspec); API_FCT(send_respawn); API_FCT(gettext); API_FCT(get_node); API_FCT(get_node_or_nil); API_FCT(get_wielded_item); }