CSM/SSM: Add on_mods_loaded callback (#7411)
* CSM/SSM: Add on_mods_loaded callback
This commit is contained in:
parent
a2de439a91
commit
ccc3af128c
@ -59,6 +59,7 @@ local function make_registration()
|
|||||||
end
|
end
|
||||||
|
|
||||||
core.registered_globalsteps, core.register_globalstep = make_registration()
|
core.registered_globalsteps, core.register_globalstep = make_registration()
|
||||||
|
core.registered_on_mods_loaded, core.register_on_mods_loaded = make_registration()
|
||||||
core.registered_on_shutdown, core.register_on_shutdown = make_registration()
|
core.registered_on_shutdown, core.register_on_shutdown = make_registration()
|
||||||
core.registered_on_receiving_chat_message, core.register_on_receiving_chat_message = make_registration()
|
core.registered_on_receiving_chat_message, core.register_on_receiving_chat_message = make_registration()
|
||||||
core.registered_on_sending_chat_message, core.register_on_sending_chat_message = make_registration()
|
core.registered_on_sending_chat_message, core.register_on_sending_chat_message = make_registration()
|
||||||
|
@ -569,6 +569,7 @@ core.unregister_biome = make_wrap_deregistration(core.register_biome, core.clear
|
|||||||
core.registered_on_chat_messages, core.register_on_chat_message = make_registration()
|
core.registered_on_chat_messages, core.register_on_chat_message = make_registration()
|
||||||
core.registered_globalsteps, core.register_globalstep = make_registration()
|
core.registered_globalsteps, core.register_globalstep = make_registration()
|
||||||
core.registered_playerevents, core.register_playerevent = make_registration()
|
core.registered_playerevents, core.register_playerevent = make_registration()
|
||||||
|
core.registered_on_mods_loaded, core.register_on_mods_loaded = make_registration()
|
||||||
core.registered_on_shutdown, core.register_on_shutdown = make_registration()
|
core.registered_on_shutdown, core.register_on_shutdown = make_registration()
|
||||||
core.registered_on_punchnodes, core.register_on_punchnode = make_registration()
|
core.registered_on_punchnodes, core.register_on_punchnode = make_registration()
|
||||||
core.registered_on_placenodes, core.register_on_placenode = make_registration()
|
core.registered_on_placenodes, core.register_on_placenode = make_registration()
|
||||||
|
@ -200,3 +200,8 @@ core.register_chatcommand("text", {
|
|||||||
return core.localplayer:hud_change(id, "text", param)
|
return core.localplayer:hud_change(id, "text", param)
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
core.register_on_mods_loaded(function()
|
||||||
|
core.log("Yeah preview mod is loaded with other CSM mods.")
|
||||||
|
end)
|
||||||
|
@ -648,6 +648,8 @@ Call these functions only at load time!
|
|||||||
|
|
||||||
* `minetest.register_globalstep(func(dtime))`
|
* `minetest.register_globalstep(func(dtime))`
|
||||||
* Called every client environment step, usually interval of 0.1s
|
* Called every client environment step, usually interval of 0.1s
|
||||||
|
* `minetest.register_on_mods_loaded(func())`
|
||||||
|
* Called just after mods have finished loading.
|
||||||
* `minetest.register_on_shutdown(func())`
|
* `minetest.register_on_shutdown(func())`
|
||||||
* Called before client shutdown
|
* Called before client shutdown
|
||||||
* **Warning**: If the client terminates abnormally (i.e. crashes), the registered
|
* **Warning**: If the client terminates abnormally (i.e. crashes), the registered
|
||||||
|
@ -2793,6 +2793,9 @@ Call these functions only at load time!
|
|||||||
|
|
||||||
* `minetest.register_globalstep(func(dtime))`
|
* `minetest.register_globalstep(func(dtime))`
|
||||||
* Called every server step, usually interval of 0.1s
|
* Called every server step, usually interval of 0.1s
|
||||||
|
* `minetest.register_on_mods_loaded(func())`
|
||||||
|
* Called after mods have finished loading and before the media is cached or the
|
||||||
|
aliases handled.
|
||||||
* `minetest.register_on_shutdown(func())`
|
* `minetest.register_on_shutdown(func())`
|
||||||
* Called before server shutdown
|
* Called before server shutdown
|
||||||
* **Warning**: If the server terminates abnormally (i.e. crashes), the
|
* **Warning**: If the server terminates abnormally (i.e. crashes), the
|
||||||
|
@ -765,4 +765,9 @@ minetest.log("experimental modname="..dump(minetest.get_current_modname()))
|
|||||||
minetest.log("experimental modpath="..dump(minetest.get_modpath("experimental")))
|
minetest.log("experimental modpath="..dump(minetest.get_modpath("experimental")))
|
||||||
minetest.log("experimental worldpath="..dump(minetest.get_worldpath()))
|
minetest.log("experimental worldpath="..dump(minetest.get_worldpath()))
|
||||||
|
|
||||||
|
|
||||||
|
core.register_on_mods_loaded(function()
|
||||||
|
core.log("Yeah experimental loaded mods.")
|
||||||
|
end)
|
||||||
|
|
||||||
-- END
|
-- END
|
||||||
|
@ -172,6 +172,8 @@ void Client::loadMods()
|
|||||||
for (const ModSpec &mod : m_mods)
|
for (const ModSpec &mod : m_mods)
|
||||||
m_script->loadModFromMemory(mod.name);
|
m_script->loadModFromMemory(mod.name);
|
||||||
|
|
||||||
|
// Run a callback when mods are loaded
|
||||||
|
m_script->on_mods_loaded();
|
||||||
m_mods_loaded = true;
|
m_mods_loaded = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,6 +25,17 @@ with this program; if not, write to the Free Software Foundation, Inc.,
|
|||||||
#include "common/c_content.h"
|
#include "common/c_content.h"
|
||||||
#include "s_item.h"
|
#include "s_item.h"
|
||||||
|
|
||||||
|
void ScriptApiClient::on_mods_loaded()
|
||||||
|
{
|
||||||
|
SCRIPTAPI_PRECHECKHEADER
|
||||||
|
|
||||||
|
// Get registered shutdown hooks
|
||||||
|
lua_getglobal(L, "core");
|
||||||
|
lua_getfield(L, -1, "registered_on_mods_loaded");
|
||||||
|
// Call callbacks
|
||||||
|
runCallbacks(0, RUN_CALLBACKS_MODE_FIRST);
|
||||||
|
}
|
||||||
|
|
||||||
void ScriptApiClient::on_shutdown()
|
void ScriptApiClient::on_shutdown()
|
||||||
{
|
{
|
||||||
SCRIPTAPI_PRECHECKHEADER
|
SCRIPTAPI_PRECHECKHEADER
|
||||||
|
@ -37,6 +37,9 @@ class ClientEnvironment;
|
|||||||
class ScriptApiClient : virtual public ScriptApiBase
|
class ScriptApiClient : virtual public ScriptApiBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
// Calls when mods are loaded
|
||||||
|
void on_mods_loaded();
|
||||||
|
|
||||||
// Calls on_shutdown handlers
|
// Calls on_shutdown handlers
|
||||||
void on_shutdown();
|
void on_shutdown();
|
||||||
|
|
||||||
|
@ -147,6 +147,17 @@ bool ScriptApiServer::on_chat_message(const std::string &name,
|
|||||||
return ate;
|
return ate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ScriptApiServer::on_mods_loaded()
|
||||||
|
{
|
||||||
|
SCRIPTAPI_PRECHECKHEADER
|
||||||
|
|
||||||
|
// Get registered shutdown hooks
|
||||||
|
lua_getglobal(L, "core");
|
||||||
|
lua_getfield(L, -1, "registered_on_mods_loaded");
|
||||||
|
// Call callbacks
|
||||||
|
runCallbacks(0, RUN_CALLBACKS_MODE_FIRST);
|
||||||
|
}
|
||||||
|
|
||||||
void ScriptApiServer::on_shutdown()
|
void ScriptApiServer::on_shutdown()
|
||||||
{
|
{
|
||||||
SCRIPTAPI_PRECHECKHEADER
|
SCRIPTAPI_PRECHECKHEADER
|
||||||
|
@ -30,6 +30,9 @@ public:
|
|||||||
// Returns true if script handled message
|
// Returns true if script handled message
|
||||||
bool on_chat_message(const std::string &name, const std::string &message);
|
bool on_chat_message(const std::string &name, const std::string &message);
|
||||||
|
|
||||||
|
// Calls when mods are loaded
|
||||||
|
void on_mods_loaded();
|
||||||
|
|
||||||
// Calls on_shutdown handlers
|
// Calls on_shutdown handlers
|
||||||
void on_shutdown();
|
void on_shutdown();
|
||||||
|
|
||||||
|
@ -75,6 +75,9 @@ void ServerModManager::loadMods(ServerScripting *script)
|
|||||||
std::chrono::steady_clock::now() - t).count() * 0.001f
|
std::chrono::steady_clock::now() - t).count() * 0.001f
|
||||||
<< " seconds" << std::endl;
|
<< " seconds" << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Run a callback when mods are loaded
|
||||||
|
script->on_mods_loaded();
|
||||||
}
|
}
|
||||||
|
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
Loading…
x
Reference in New Issue
Block a user