Scripting : add support for "onStart" callbacks in library objects

This commit is contained in:
auria.mg 2017-01-19 21:03:09 -05:00
parent 4506f4baed
commit 52fff152de
3 changed files with 43 additions and 3 deletions

View File

@ -31,6 +31,7 @@
#include "scriptengine/script_utils.hpp"
#include "scriptengine/scriptstdstring.hpp"
#include "scriptengine/scriptvec3.hpp"
#include "scriptengine/scriptarray.hpp"
#include <string.h>
#include "states_screens/dialogs/tutorial_message_dialog.hpp"
#include "tracks/track_object_manager.hpp"
@ -307,9 +308,20 @@ namespace Scripting
// Find the function for the function we want to execute.
// This is how you call a normal function with arguments
// asIScriptFunction *func = engine->GetModule(0)->GetFunctionByDecl("void func(arg1Type, arg2Type)");
func = m_engine->GetModule(MODULE_ID_MAIN_SCRIPT_FILE)
->GetFunctionByDecl(function_name.c_str());
asIScriptModule* module = m_engine->GetModule(MODULE_ID_MAIN_SCRIPT_FILE);
if (module == NULL)
{
if (warn_if_not_found)
Log::warn("Scripting", "Scripting function was not found : %s (module not found)", function_name.c_str());
else
Log::debug("Scripting", "Scripting function was not found : %s (module not found)", function_name.c_str());
m_functions_cache[function_name] = NULL; // remember that this function is unavailable
return;
}
func = module->GetFunctionByDecl(function_name.c_str());
if (func == NULL)
{
if (warn_if_not_found)
@ -428,6 +440,7 @@ namespace Scripting
// Register the script string type
RegisterStdString(engine); //register std::string
RegisterVec3(engine); //register Vec3
RegisterScriptArray(engine, true);
Scripting::Track::registerScriptFunctions(m_engine);
Scripting::Challenges::registerScriptFunctions(m_engine);

View File

@ -180,6 +180,7 @@ TrackObjectPresentationLibraryNode::TrackObjectPresentationLibraryNode(
{
std::string name;
xml_node.get("name", &name);
m_name = name;
m_node = irr_driver->getSceneManager()->addEmptySceneNode();
#ifdef DEBUG
@ -210,13 +211,17 @@ TrackObjectPresentationLibraryNode::TrackObjectPresentationLibraryNode(
lib_path = track->getTrackFile("library/" + name);
libroot = file_manager->createXMLTree(local_lib_node_path);
if (track != NULL)
{
Scripting::ScriptEngine::getInstance()->loadScript(local_script_file_path, false);
}
}
else if (file_manager->fileExists(lib_node_path))
{
libroot = file_manager->createXMLTree(lib_node_path);
if (track != NULL)
{
Scripting::ScriptEngine::getInstance()->loadScript(lib_script_file_path, false);
}
}
else
{
@ -272,6 +277,25 @@ TrackObjectPresentationLibraryNode::TrackObjectPresentationLibraryNode(
m_parent = parent;
} // TrackObjectPresentationLibraryNode
// ----------------------------------------------------------------------------
void TrackObjectPresentationLibraryNode::update(float dt)
{
if (!m_start_executed)
{
m_start_executed = true;
std::string fn_name = StringUtils::insertValues("void %s::onStart(const string)", m_name.c_str());
std::string lib_id = m_parent->getID();
std::string* lib_id_ptr = &lib_id;
Scripting::ScriptEngine::getInstance()->runFunction(false, fn_name,
[&](asIScriptContext* ctx) {
ctx->SetArgObject(0, lib_id_ptr);
});
}
}
// ----------------------------------------------------------------------------
TrackObjectPresentationLibraryNode::~TrackObjectPresentationLibraryNode()
{

View File

@ -186,11 +186,14 @@ class TrackObjectPresentationLibraryNode : public TrackObjectPresentationSceneNo
{
TrackObject* m_parent;
using TrackObjectPresentationSceneNode::move;
std::string m_name;
bool m_start_executed = false;
public:
TrackObjectPresentationLibraryNode(TrackObject* parent,
const XMLNode& xml_node,
ModelDefinitionLoader& model_def_loader);
virtual ~TrackObjectPresentationLibraryNode();
virtual void update(float dt);
void move(const core::vector3df& xyz, const core::vector3df& hpr,
const core::vector3df& scale, bool isAbsoluteCoord, bool moveChildrenPhysicalBodies);
}; // TrackObjectPresentationLibraryNode