2018-03-06 22:22:19 +01:00
|
|
|
#include <Logging/Logger.h>
|
|
|
|
#include <Exd/ExdDataGenerated.h>
|
2018-06-10 16:34:26 +00:00
|
|
|
#include <Config/ConfigMgr.h>
|
2018-03-06 22:22:19 +01:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
#include <watchdog/Watchdog.h>
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-12-01 00:27:16 +11:00
|
|
|
#include "Territory/Zone.h"
|
|
|
|
#include "Territory/InstanceContent.h"
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Actor/Player.h"
|
2018-11-30 23:15:58 +11:00
|
|
|
#include "Actor/EventObject.h"
|
2018-11-20 21:32:13 +01:00
|
|
|
#include "ServerMgr.h"
|
2018-01-09 23:50:54 +01:00
|
|
|
#include "Event/EventHandler.h"
|
2018-12-23 03:53:08 +01:00
|
|
|
|
|
|
|
#include "Manager/EventMgr.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "StatusEffect/StatusEffect.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
|
2017-12-08 15:38:25 +01:00
|
|
|
#include "Network/PacketWrappers/ServerNoticePacket.h"
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "Script/ScriptMgr.h"
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "NativeScriptMgr.h"
|
2018-11-20 21:32:13 +01:00
|
|
|
#include "ServerMgr.h"
|
2018-03-02 07:22:25 -03:00
|
|
|
#include "Framework.h"
|
2018-01-28 11:16:34 +01:00
|
|
|
|
|
|
|
// enable the ambiguity fix for every platform to avoid #define nonsense
|
|
|
|
#define WIN_AMBIGUITY_FIX
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
namespace fs = std::experimental::filesystem;
|
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
Sapphire::Scripting::ScriptMgr::ScriptMgr( FrameworkPtr pFw ) :
|
|
|
|
World::Manager::BaseManager( pFw ),
|
2018-08-29 21:40:59 +02:00
|
|
|
m_firstScriptChangeNotificiation( false )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
m_nativeScriptMgr = createNativeScriptMgr( pFw );
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
Sapphire::Scripting::ScriptMgr::~ScriptMgr()
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
Watchdog::unwatchAll();
|
2017-12-14 22:30:06 +11:00
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
void Sapphire::Scripting::ScriptMgr::update()
|
2017-12-14 22:30:06 +11:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
m_nativeScriptMgr->processLoadQueue();
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::init()
|
2017-12-10 23:51:06 +11:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
std::set< std::string > files;
|
2018-12-23 03:53:08 +01:00
|
|
|
auto pConfig = framework()->get< ConfigMgr >();
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2018-10-25 17:48:22 +11:00
|
|
|
auto status = loadDir( pConfig->getValue< std::string >( "Scripts", "Path", "./compiledscripts/" ),
|
2018-08-29 21:40:59 +02:00
|
|
|
files, m_nativeScriptMgr->getModuleExtension() );
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !status )
|
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::error( "ScriptMgr: failed to load scripts, the server will not function correctly without scripts loaded." );
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
|
|
|
}
|
2018-04-04 11:25:07 +10:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
uint32_t scriptsFound = 0;
|
|
|
|
uint32_t scriptsLoaded = 0;
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
for( auto itr = files.begin(); itr != files.end(); ++itr )
|
|
|
|
{
|
|
|
|
auto& path = *itr;
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
scriptsFound++;
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( m_nativeScriptMgr->loadScript( path ) )
|
|
|
|
scriptsLoaded++;
|
|
|
|
}
|
2017-12-10 23:51:06 +11:00
|
|
|
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::info( "ScriptMgr: Loaded {0}/{1} modules", scriptsLoaded, scriptsFound );
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
watchDirectories();
|
2017-12-14 22:30:06 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
2017-12-10 23:51:06 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
void Sapphire::Scripting::ScriptMgr::watchDirectories()
|
2017-12-14 22:30:06 +11:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
auto pConfig = framework()->get< ConfigMgr >();
|
2018-10-25 17:48:22 +11:00
|
|
|
auto shouldWatch = pConfig->getValue< bool >( "Scripts", "HotSwap", true );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !shouldWatch )
|
|
|
|
return;
|
|
|
|
|
2018-10-25 17:48:22 +11:00
|
|
|
Watchdog::watchMany( pConfig->getValue< std::string >( "Scripts", "Path", "./compiledscripts/" ) + "*" +
|
2018-08-29 21:40:59 +02:00
|
|
|
m_nativeScriptMgr->getModuleExtension(),
|
|
|
|
[ this ]( const std::vector< ci::fs::path >& paths )
|
|
|
|
{
|
|
|
|
if( !m_firstScriptChangeNotificiation )
|
|
|
|
{
|
|
|
|
// for whatever reason, the first time this runs, it detects every file as changed
|
|
|
|
// so we're always going to ignore the first notification
|
|
|
|
m_firstScriptChangeNotificiation = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
for( const auto& path : paths )
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
|
|
|
if( m_nativeScriptMgr->isModuleLoaded( path.stem().string() ) )
|
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::debug( "Reloading changed script: {0}", path.stem().string() );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
|
|
|
m_nativeScriptMgr->queueScriptReload( path.stem().string() );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::debug( "Loading new script: {0}", path.stem().string() );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
|
|
|
m_nativeScriptMgr->loadScript( path.string() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} );
|
2017-12-14 22:30:06 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::loadDir( const std::string& dirname, std::set< std::string >& files,
|
2018-12-02 02:01:41 +01:00
|
|
|
const std::string& ext )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2019-01-04 22:37:01 +11:00
|
|
|
Logger::info( "ScriptMgr: loading scripts from: {0}", dirname );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
if( !fs::exists( dirname ) )
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
Logger::error( "ScriptMgr: scripts directory doesn't exist" );
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
fs::path targetDir( dirname );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-10-25 13:38:06 +11:00
|
|
|
fs::directory_iterator iter( targetDir );
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-10-25 15:15:27 +02:00
|
|
|
for( const auto& i : iter )
|
2018-09-26 08:47:22 -04:00
|
|
|
{
|
2018-10-25 15:15:27 +02:00
|
|
|
if( fs::is_regular_file( i ) && fs::path( i ).extension() == ext )
|
2018-09-26 08:47:22 -04:00
|
|
|
{
|
2018-10-26 14:11:02 +02:00
|
|
|
files.insert( fs::path( i ).string() );
|
2018-09-26 08:47:22 -04:00
|
|
|
}
|
|
|
|
}
|
2018-08-29 21:40:59 +02:00
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
if( !files.empty() )
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
|
|
|
else
|
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
Logger::error( "ScriptMgr: couldn't find any script modules" );
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
void Sapphire::Scripting::ScriptMgr::onPlayerFirstEnterWorld( Entity::Player& player )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2017-12-10 01:52:03 +11:00
|
|
|
// try
|
|
|
|
// {
|
|
|
|
// std::string test = m_onFirstEnterWorld( player );
|
|
|
|
// }
|
|
|
|
// catch( const std::exception &e )
|
|
|
|
// {
|
|
|
|
// std::string what = e.what();
|
|
|
|
// g_log.Log( LoggingSeverity::error, what );
|
|
|
|
// }
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onTalk( Entity::Player& player, uint64_t actorId, uint32_t eventId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-30 23:15:58 +11:00
|
|
|
// check if the actor is an eobj and call its script if we have one
|
|
|
|
auto zone = player.getCurrentZone();
|
|
|
|
if( auto eobj = zone->getEObj( actorId ) )
|
|
|
|
{
|
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventObjectScript >( eobj->getObjectId() );
|
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onTalk( eventId, player, *eobj );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// check for a direct eventid match first, otherwise default to base type
|
2018-11-22 13:12:21 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-11-20 22:52:57 +11:00
|
|
|
if( script )
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
2018-11-20 22:52:57 +11:00
|
|
|
script->onTalk( eventId, player, actorId );
|
|
|
|
return true;
|
2018-08-29 21:40:59 +02:00
|
|
|
}
|
2018-11-20 22:52:57 +11:00
|
|
|
else
|
2018-08-29 21:40:59 +02:00
|
|
|
{
|
2018-12-02 02:01:41 +01:00
|
|
|
script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId & 0xFFFF0000 );
|
2018-11-20 22:52:57 +11:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
script->onTalk( eventId, player, actorId );
|
|
|
|
return true;
|
2018-08-29 21:40:59 +02:00
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEnterTerritory( Entity::Player& player, uint32_t eventId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint16_t param1, uint16_t param2 )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onEnterTerritory( player, eventId, param1, param2 );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onWithinRange( Entity::Player& player, uint32_t eventId, uint32_t param1,
|
2018-12-02 02:01:41 +01:00
|
|
|
float x, float y, float z )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onWithinRange( player, eventId, param1, x, y, z );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onOutsideRange( Entity::Player& player, uint32_t eventId, uint32_t param1,
|
2018-12-02 02:01:41 +01:00
|
|
|
float x, float y, float z )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onOutsideRange( player, eventId, param1, x, y, z );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEmote( Entity::Player& player, uint64_t actorId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint32_t eventId, uint8_t emoteId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( !script )
|
|
|
|
return false;
|
|
|
|
script->onEmote( actorId, eventId, emoteId, player );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEventHandlerReturn( Entity::Player& player, uint32_t eventId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint16_t subEvent, uint16_t param1, uint16_t param2,
|
|
|
|
uint16_t param3 )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEventHandlerTradeReturn( Entity::Player& player, uint32_t eventId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint16_t subEvent, uint16_t param, uint32_t catalogId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onEventHandlerTradeReturn( player, eventId, subEvent, param, catalogId );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onEventItem( Entity::Player& player, uint32_t eventItemId,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint32_t eventId, uint32_t castTime, uint64_t targetId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
auto pEventMgr = framework()->get< World::Manager::EventMgr >();
|
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
std::string eventName = "onEventItem";
|
2018-12-23 03:53:08 +01:00
|
|
|
std::string objName = pEventMgr->getEventName( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName + " - " + std::to_string( eventId ) );
|
2017-12-13 22:19:00 +11:00
|
|
|
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( eventId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
player.eventStart( targetId, eventId, Event::EventHandler::Item, 0, 0 );
|
2017-12-13 22:19:00 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onEventItem( player, eventItemId, eventId, castTime, targetId );
|
|
|
|
return true;
|
|
|
|
}
|
2017-12-13 22:19:00 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onMobKill( Entity::Player& player, uint16_t nameId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
auto pEventMgr = framework()->get< World::Manager::EventMgr >();
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-12-23 03:53:08 +01:00
|
|
|
std::string eventName = "onBnpcKill_" + std::to_string( nameId );
|
2017-12-10 01:52:03 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
// loop through all active quests and try to call available onMobKill callbacks
|
|
|
|
for( size_t i = 0; i < 30; i++ )
|
|
|
|
{
|
|
|
|
auto activeQuests = player.getQuestActive( static_cast< uint16_t >( i ) );
|
|
|
|
if( !activeQuests )
|
|
|
|
continue;
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
uint16_t questId = activeQuests->c.questId;
|
2017-12-10 01:52:03 +11:00
|
|
|
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::EventScript >( questId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
2018-12-23 03:53:08 +01:00
|
|
|
std::string objName = pEventMgr->getEventName( 0x00010000 | questId );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
player.sendDebug( "Calling: " + objName + "." + eventName );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onNpcKill( nameId, player );
|
|
|
|
}
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onCastFinish( Entity::Player& player, Entity::CharaPtr pTarget, uint32_t actionId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::ActionScript >( actionId );
|
2017-12-10 01:52:03 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
script->onCastFinish( player, *pTarget );
|
|
|
|
return true;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStatusReceive( Entity::CharaPtr pActor, uint32_t effectId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::StatusEffectScript >( effectId );
|
2018-01-04 16:14:14 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
if( pActor->isPlayer() )
|
|
|
|
pActor->getAsPlayer()->sendDebug( "Calling status receive for statusid: " + std::to_string( effectId ) );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onApply( *pActor );
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStatusTick( Entity::CharaPtr pChara, Sapphire::StatusEffect::StatusEffect& effect )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::StatusEffectScript >( effect.getId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
if( pChara->isPlayer() )
|
|
|
|
pChara->getAsPlayer()->sendDebug( "Calling status tick for statusid: " + std::to_string( effect.getId() ) );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onTick( *pChara );
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onStatusTimeOut( Entity::CharaPtr pChara, uint32_t effectId )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::StatusEffectScript >( effectId );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
if( pChara->isPlayer() )
|
|
|
|
pChara->getAsPlayer()->sendDebug( "Calling status timeout for statusid: " + std::to_string( effectId ) );
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
script->onExpire( *pChara );
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-18 17:29:36 +02:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onZoneInit( ZonePtr pZone )
|
2017-08-18 17:29:36 +02:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::ZoneScript >( pZone->getTerritoryTypeId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onZoneInit();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2017-08-18 17:29:36 +02:00
|
|
|
}
|
2017-12-12 01:45:24 +11:00
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInstanceInit( InstanceContentPtr instance )
|
2018-02-09 02:34:43 +11:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::InstanceContentScript >( instance->getDirectorId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onInit( instance );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2018-02-09 02:34:43 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInstanceUpdate( InstanceContentPtr instance, uint32_t currTime )
|
2018-02-09 02:34:43 +11:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::InstanceContentScript >( instance->getDirectorId() );
|
2018-03-06 00:10:36 +01:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onUpdate( instance, currTime );
|
|
|
|
return true;
|
|
|
|
}
|
2018-02-09 02:34:43 +11:00
|
|
|
|
2018-08-29 21:40:59 +02:00
|
|
|
return false;
|
2018-02-09 02:34:43 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
bool Sapphire::Scripting::ScriptMgr::onInstanceEnterTerritory( InstanceContentPtr instance, Entity::Player& player,
|
2018-12-02 02:01:41 +01:00
|
|
|
uint32_t eventId, uint16_t param1, uint16_t param2 )
|
2018-03-05 22:10:14 +11:00
|
|
|
{
|
2018-11-13 21:34:44 +11:00
|
|
|
auto script = m_nativeScriptMgr->getScript< Sapphire::ScriptAPI::InstanceContentScript >( instance->getDirectorId() );
|
2018-08-29 21:40:59 +02:00
|
|
|
if( script )
|
|
|
|
{
|
|
|
|
script->onEnterTerritory( instance, player, eventId, param1, param2 );
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2018-03-05 22:10:14 +11:00
|
|
|
}
|
|
|
|
|
2018-11-29 16:55:48 +01:00
|
|
|
Sapphire::Scripting::NativeScriptMgr& Sapphire::Scripting::ScriptMgr::getNativeScriptHandler()
|
2017-12-12 01:45:24 +11:00
|
|
|
{
|
2018-08-29 21:40:59 +02:00
|
|
|
return *m_nativeScriptMgr;
|
2017-12-12 01:45:24 +11:00
|
|
|
}
|