aboutsummaryrefslogtreecommitdiff
path: root/src/mapnode.cpp
Commit message (Expand)AuthorAge
* Increase performance of getLight() by at least 2xCraig Robbins2014-12-10
* Optimise getTileInfo()Craig Robbins2014-11-21
* Custom collision boxes node property.RealBadAngel2014-10-19
* Cavegen: Respect is_ground_content MapNode setting; fix some code formatting ...kwolekr2013-11-29
* Better snow fall, finite liquid transform, leveled nodes apiproller2013-07-28
* Weather supportproller2013-07-27
* Leveled nodeboxproller2013-07-13
* Fix wallmounted rotations along Y axis for 90 and 270 degree caseskwolekr2013-07-08
* Decoration: Handle facedir and wallmounted param2types with schematic rotationkwolekr2013-07-08
* 6d facedirRealBadAngel2013-03-23
* Update Copyright YearsSfan52013-02-24
* Change Minetest-c55 to MinetestPilzAdam2013-02-24
* darkrose should work at a nuclear power plant.Perttu Ahola2012-07-24
* Fix map deserialization and remove old serialization codePerttu Ahola2012-07-23
* Increase node id/param0 to 16 bits, leaving param2 always with 8 bitsdarkrose2012-07-23
* Custom boxy nodes (stairs, slabs) and collision changesKahrl2012-06-17
* Optimize headersPerttu Ahola2012-06-17
* Properly and efficiently use split utility headersPerttu Ahola2012-06-17
* Switch the license to be LGPLv2/later, with small parts still remaining as GP...Perttu Ahola2012-06-05
* MapBlockMesh, mesh animation system, urgent mesh updates, athmospheric light,...Kahrl2012-03-15
* Cleanup (some stuff went wrong when reverting 4-byte mapnodes); fix legacy_wa...Kahrl2012-01-22
* Node placement / mineral / serialization / iron freq / node_dig callbackKahrl2012-01-22
* MapNode constructor to allow ndef+namePerttu Ahola2011-11-29
* Node definition namesPerttu Ahola2011-11-29
* Clean mapnode.h and fix other files accordinglyPerttu Ahola2011-11-29
* Completely generalized mesh generation; ContentFeatures serializationPerttu Ahola2011-11-29
* GameDef compilesPerttu Ahola2011-11-29
* Create framework for getting rid of global definitions of node/tool/item/what...Perttu Ahola2011-11-29
* Move ContentFeatures to mapnode_contentfeatures.{h,cpp} and clean stuffPerttu Ahola2011-11-29
* Fix water-glass and water-lava surfacesPerttu Ahola2011-11-08
* Make CONTENT_IGNORE to not block the view when occlusion cullingPerttu Ahola2011-11-03
* Automate texture listing for texture atlas makingPerttu Ahola2011-10-18
* Header file tweaking; mainly for speedPerttu Ahola2011-10-12
* lava!Perttu Ahola2011-08-15
* Added MaterialItem conversion from old content type namespace to newPerttu Ahola2011-07-31
* extended content-type rangePerttu Ahola2011-07-23
* Fixed the problem of <=r548 clients fucking up maps on >=r549 servers. Also, ...Perttu Ahola2011-07-22
* Fixed small error in mapnode.cpp (didn't cause any harm though)Perttu Ahola2011-07-22
* initial steps in doing content type extensionPerttu Ahola2011-07-02
* fixed bug in inventory textures caused from better handling of unknown blocksPerttu Ahola2011-06-27
* better handling of unknown blocks on clientPerttu Ahola2011-06-27
* Moved stuff from mapblock{h,cpp} to mapblock_mesh.{h,cpp} and content_mapbloc...Perttu Ahola2011-06-17
* Moved some mapnode content stuff from mapnode.{h,cpp} and digging property st...Perttu Ahola2011-06-17
* A very poor (but better than nothing) inventory icon for fencesCiaran Gultnieks2011-05-24
* Merged CiaranG's fence and fixed two thingsPerttu Ahola2011-05-24
|\
| * Added fences (but still needs an icon or something to display in inventory)Ciaran Gultnieks2011-05-24
* | Some work-in-progress stuff and many comment updatesPerttu Ahola2011-05-22
|/
* fixed a small memory leak in mapnode.cppPerttu Ahola2011-05-21
* Added glass, with rendering and furnace support.Ciaran Gultnieks2011-05-09
* added cobblestone to the texture atlasPerttu Ahola2011-04-29
ass="hl kwa">if (player == NULL) return; // Get minetest.registered_playerevents lua_getglobal(L, "minetest"); lua_getfield(L, -1, "registered_playerevents"); // Call callbacks objectrefGetOrCreate(L, player); // player lua_pushstring(L,type.c_str()); // event type try { runCallbacks(2, RUN_CALLBACKS_MODE_FIRST); } catch (LuaError &e) { getServer()->setAsyncFatalError( std::string("player_event: ") + e.what() + "\n" + script_get_backtrace(L) ); } } void ScriptApiEnv::initializeEnvironment(ServerEnvironment *env) { SCRIPTAPI_PRECHECKHEADER verbosestream << "ScriptApiEnv: Environment initialized" << std::endl; setEnv(env); /* Add {Loading,Active}BlockModifiers to environment */ // Get core.registered_abms lua_getglobal(L, "core"); lua_getfield(L, -1, "registered_abms"); int registered_abms = lua_gettop(L); if (!lua_istable(L, registered_abms)) { lua_pop(L, 1); throw LuaError("core.registered_abms was not a lua table, as expected."); } lua_pushnil(L); while (lua_next(L, registered_abms)) { // key at index -2 and value at index -1 int id = lua_tonumber(L, -2); int current_abm = lua_gettop(L); std::vector<std::string> trigger_contents; lua_getfield(L, current_abm, "nodenames"); if (lua_istable(L, -1)) { int table = lua_gettop(L); lua_pushnil(L); while (lua_next(L, table)) { // key at index -2 and value at index -1 luaL_checktype(L, -1, LUA_TSTRING); trigger_contents.emplace_back(readParam<std::string>(L, -1)); // removes value, keeps key for next iteration lua_pop(L, 1); } } else if (lua_isstring(L, -1)) { trigger_contents.emplace_back(readParam<std::string>(L, -1)); } lua_pop(L, 1); std::vector<std::string> required_neighbors; lua_getfield(L, current_abm, "neighbors"); if (lua_istable(L, -1)) { int table = lua_gettop(L); lua_pushnil(L); while (lua_next(L, table)) { // key at index -2 and value at index -1 luaL_checktype(L, -1, LUA_TSTRING); required_neighbors.emplace_back(readParam<std::string>(L, -1)); // removes value, keeps key for next iteration lua_pop(L, 1); } } else if (lua_isstring(L, -1)) { required_neighbors.emplace_back(readParam<std::string>(L, -1)); } lua_pop(L, 1); float trigger_interval = 10.0; getfloatfield(L, current_abm, "interval", trigger_interval); int trigger_chance = 50; getintfield(L, current_abm, "chance", trigger_chance); bool simple_catch_up = true; getboolfield(L, current_abm, "catch_up", simple_catch_up); lua_getfield(L, current_abm, "action"); luaL_checktype(L, current_abm + 1, LUA_TFUNCTION); lua_pop(L, 1); LuaABM *abm = new LuaABM(L, id, trigger_contents, required_neighbors, trigger_interval, trigger_chance, simple_catch_up); env->addActiveBlockModifier(abm); // removes value, keeps key for next iteration lua_pop(L, 1); } lua_pop(L, 1); // Get core.registered_lbms lua_getglobal(L, "core"); lua_getfield(L, -1, "registered_lbms"); int registered_lbms = lua_gettop(L); if (!lua_istable(L, registered_lbms)) { lua_pop(L, 1); throw LuaError("core.registered_lbms was not a lua table, as expected."); } lua_pushnil(L); while (lua_next(L, registered_lbms)) { // key at index -2 and value at index -1 int id = lua_tonumber(L, -2); int current_lbm = lua_gettop(L); std::set<std::string> trigger_contents; lua_getfield(L, current_lbm, "nodenames"); if (lua_istable(L, -1)) { int table = lua_gettop(L); lua_pushnil(L); while (lua_next(L, table)) { // key at index -2 and value at index -1 luaL_checktype(L, -1, LUA_TSTRING); trigger_contents.insert(readParam<std::string>(L, -1)); // removes value, keeps key for next iteration lua_pop(L, 1); } } else if (lua_isstring(L, -1)) { trigger_contents.insert(readParam<std::string>(L, -1)); } lua_pop(L, 1); std::string name; getstringfield(L, current_lbm, "name", name); bool run_at_every_load = getboolfield_default(L, current_lbm, "run_at_every_load", false); lua_getfield(L, current_lbm, "action"); luaL_checktype(L, current_lbm + 1, LUA_TFUNCTION); lua_pop(L, 1); LuaLBM *lbm = new LuaLBM(L, id, trigger_contents, name, run_at_every_load); env->addLoadingBlockModifierDef(lbm); // removes value, keeps key for next iteration lua_pop(L, 1); } lua_pop(L, 1); } void ScriptApiEnv::on_emerge_area_completion( v3s16 blockpos, int action, ScriptCallbackState *state) { Server *server = getServer(); // This function should be executed with envlock held. // The caller (LuaEmergeAreaCallback in src/script/lua_api/l_env.cpp) // should have obtained the lock. // Note that the order of these locks is important! Envlock must *ALWAYS* // be acquired before attempting to acquire scriptlock, or else ServerThread // will try to acquire scriptlock after it already owns envlock, thus // deadlocking EmergeThread and ServerThread SCRIPTAPI_PRECHECKHEADER int error_handler = PUSH_ERROR_HANDLER(L); lua_rawgeti(L, LUA_REGISTRYINDEX, state->callback_ref); luaL_checktype(L, -1, LUA_TFUNCTION); push_v3s16(L, blockpos); lua_pushinteger(L, action); lua_pushinteger(L, state->refcount); lua_rawgeti(L, LUA_REGISTRYINDEX, state->args_ref); setOriginDirect(state->origin.c_str()); try { PCALL_RES(lua_pcall(L, 4, 0, error_handler)); } catch (LuaError &e) { server->setAsyncFatalError( std::string("on_emerge_area_completion: ") + e.what() + "\n" + script_get_backtrace(L)); } lua_pop(L, 1); // Pop error handler if (state->refcount == 0) { luaL_unref(L, LUA_REGISTRYINDEX, state->callback_ref); luaL_unref(L, LUA_REGISTRYINDEX, state->args_ref); } }