buildat/games/test/__loader/__loader.cpp

77 lines
1.7 KiB
C++

#include "core/log.h"
#include "interface/module.h"
#include "interface/server.h"
#include "interface/fs.h"
#include "interface/event.h"
#include "loader/api.h"
using interface::Event;
namespace __loader {
struct Module: public interface::Module
{
interface::Server *m_server;
ss_ m_shutdown_reason;
Module(interface::Server *server):
interface::Module("__loader"),
m_server(server)
{
log_v(MODULE, "__loader construct");
}
~Module()
{
log_v(MODULE, "__loader destruct");
if(m_shutdown_reason != ""){
log_w(MODULE, "Shut down: %s", cs(m_shutdown_reason));
}
}
void init()
{
log_v(MODULE, "__loader init");
m_server->sub_event(this, Event::t("core:load_modules"));
m_server->sub_event(this, Event::t("core:module_modified"));
}
void event(const Event::Type &type, const Event::Private *p)
{
EVENT_VOIDN("core:load_modules", on_load_modules)
EVENT_TYPEN("core:module_modified", on_module_modified,
interface::ModuleModifiedEvent)
}
void on_load_modules()
{
bool ok = m_server->load_module("loader",
m_server->get_builtin_modules_path()+"/loader");
if(!ok){
m_shutdown_reason = ss_()+"Error loading builtin/loader";
m_server->shutdown(1);
return;
}
loader::access(m_server, [&](loader::Interface * i){
i->activate();
});
}
void on_module_modified(const interface::ModuleModifiedEvent &event)
{
log_v(MODULE, "__loader::on_module_modified(): %s", cs(event.name));
if(event.name == "__loader")
return;
m_server->reload_module(event.name, event.path);
}
};
extern "C" {
EXPORT void* createModule___loader(interface::Server *server){
return (void*)(new Module(server));
}
}
}
// vim: set noet ts=4 sw=4: