mirror of
https://github.com/minetest/minetest.git
synced 2024-12-23 22:52:25 +01:00
Add static_save property to luaentites to not save them statically. (#5112)
* Add no_static_save property to luaentites to not save them statically. This allows for temporary objects that would get deleted anyway as soon as they are loaded again without the static saving overhead. * Use positive meaning for static_save object property * Invert meaning also for the LUA parameter Note: getboolfield() does not change &result when field does not exist, so it defaults to the default value in the header file, which is 'true'. * Extend push_object_properties()
This commit is contained in:
parent
2afe62952c
commit
08846cd05c
@ -4199,6 +4199,10 @@ Definition tables
|
|||||||
nametag = "", -- by default empty, for players their name is shown if empty
|
nametag = "", -- by default empty, for players their name is shown if empty
|
||||||
nametag_color = <color>, -- sets color of nametag as ColorSpec
|
nametag_color = <color>, -- sets color of nametag as ColorSpec
|
||||||
infotext = "", -- by default empty, text to be shown when pointed at object
|
infotext = "", -- by default empty, text to be shown when pointed at object
|
||||||
|
static_save = true,
|
||||||
|
-- ^ If false, never save this object statically. It will simply be deleted when the block gets unloaded.
|
||||||
|
-- ^ The get_staticdata() callback is never called then.
|
||||||
|
-- ^ Defaults to 'true'
|
||||||
}
|
}
|
||||||
|
|
||||||
### Entity definition (`register_entity`)
|
### Entity definition (`register_entity`)
|
||||||
|
@ -105,6 +105,8 @@ public:
|
|||||||
const std::string &data);
|
const std::string &data);
|
||||||
void step(float dtime, bool send_recommended);
|
void step(float dtime, bool send_recommended);
|
||||||
std::string getClientInitializationData(u16 protocol_version);
|
std::string getClientInitializationData(u16 protocol_version);
|
||||||
|
bool isStaticAllowed() const
|
||||||
|
{ return m_prop.static_save; }
|
||||||
void getStaticData(std::string *result) const;
|
void getStaticData(std::string *result) const;
|
||||||
int punch(v3f dir,
|
int punch(v3f dir,
|
||||||
const ToolCapabilities *toolcap=NULL,
|
const ToolCapabilities *toolcap=NULL,
|
||||||
|
@ -66,6 +66,7 @@ std::string ObjectProperties::dump()
|
|||||||
os << ", selectionbox=" << PP(selectionbox.MinEdge) << "," << PP(selectionbox.MaxEdge);
|
os << ", selectionbox=" << PP(selectionbox.MinEdge) << "," << PP(selectionbox.MaxEdge);
|
||||||
os << ", pointable=" << pointable;
|
os << ", pointable=" << pointable;
|
||||||
os << ", can_zoom=" << can_zoom;
|
os << ", can_zoom=" << can_zoom;
|
||||||
|
os << ", static_save=" << static_save;
|
||||||
return os.str();
|
return os.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,6 +58,7 @@ struct ObjectProperties
|
|||||||
std::string infotext;
|
std::string infotext;
|
||||||
//! For dropped items, this contains item information.
|
//! For dropped items, this contains item information.
|
||||||
std::string wield_item;
|
std::string wield_item;
|
||||||
|
bool static_save = true;
|
||||||
|
|
||||||
ObjectProperties();
|
ObjectProperties();
|
||||||
std::string dump();
|
std::string dump();
|
||||||
|
@ -294,7 +294,10 @@ void read_object_properties(lua_State *L, int index,
|
|||||||
prop->automatic_face_movement_max_rotation_per_sec = luaL_checknumber(L, -1);
|
prop->automatic_face_movement_max_rotation_per_sec = luaL_checknumber(L, -1);
|
||||||
}
|
}
|
||||||
lua_pop(L, 1);
|
lua_pop(L, 1);
|
||||||
|
|
||||||
getstringfield(L, -1, "infotext", prop->infotext);
|
getstringfield(L, -1, "infotext", prop->infotext);
|
||||||
|
getboolfield(L, -1, "static_save", prop->static_save);
|
||||||
|
|
||||||
lua_getfield(L, -1, "wield_item");
|
lua_getfield(L, -1, "wield_item");
|
||||||
if (!lua_isnil(L, -1))
|
if (!lua_isnil(L, -1))
|
||||||
prop->wield_item = read_item(L, -1, idef).getItemString();
|
prop->wield_item = read_item(L, -1, idef).getItemString();
|
||||||
@ -376,6 +379,8 @@ void push_object_properties(lua_State *L, ObjectProperties *prop)
|
|||||||
lua_setfield(L, -2, "automatic_face_movement_max_rotation_per_sec");
|
lua_setfield(L, -2, "automatic_face_movement_max_rotation_per_sec");
|
||||||
lua_pushlstring(L, prop->infotext.c_str(), prop->infotext.size());
|
lua_pushlstring(L, prop->infotext.c_str(), prop->infotext.size());
|
||||||
lua_setfield(L, -2, "infotext");
|
lua_setfield(L, -2, "infotext");
|
||||||
|
lua_pushboolean(L, prop->static_save);
|
||||||
|
lua_setfield(L, -2, "static_save");
|
||||||
lua_pushlstring(L, prop->wield_item.c_str(), prop->wield_item.size());
|
lua_pushlstring(L, prop->wield_item.c_str(), prop->wield_item.size());
|
||||||
lua_setfield(L, -2, "wield_item");
|
lua_setfield(L, -2, "wield_item");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user