Add a way of filtering out ingame scripts for upcoming script packets

pull/112/merge
David Cernat 8 years ago
parent aaf4cc0d7e
commit 75f6d82f08

@ -77,6 +77,13 @@ void OMW::Engine::executeLocalScripts()
{ {
MWScript::InterpreterContext interpreterContext ( MWScript::InterpreterContext interpreterContext (
&script.second.getRefData().getLocals(), script.second); &script.second.getRefData().getLocals(), script.second);
// Added by tes3mp
if (mwmp::Main::isValidPacketScript(script.first))
{
interpreterContext.sendPackets = true;
}
mEnvironment.getScriptManager()->run (script.first, interpreterContext); mEnvironment.getScriptManager()->run (script.first, interpreterContext);
} }
} }

@ -224,4 +224,23 @@ void Main::PressedKey(int key)
if (pMain == nullptr) return; if (pMain == nullptr) return;
if (get().getGUIController()->pressedKey(key)) if (get().getGUIController()->pressedKey(key))
return; // if any gui bind pressed return; // if any gui bind pressed
} }
// When sending packets with ingame script values, certain packets
// should be ignored because of their potential for spam
bool Main::isValidPacketScript(std::string script)
{
static const int invalidPacketScriptsCount = 2;
static const std::string invalidPacketScripts[invalidPacketScriptsCount] = {
"OutsideBanner",
"sleeperScript"
};
for (int i = 0; i < invalidPacketScriptsCount; i++)
{
if (Misc::StringUtils::ciEqual(script, invalidPacketScripts[i]))
return false;
}
return true;
}

@ -21,6 +21,8 @@ namespace mwmp
static void Frame(float dt); static void Frame(float dt);
static void PressedKey(int key); static void PressedKey(int key);
static bool isValidPacketScript(std::string script);
Networking *getNetworking() const; Networking *getNetworking() const;
LocalPlayer *getLocalPlayer() const; LocalPlayer *getLocalPlayer() const;
GUIController *getGUIController() const; GUIController *getGUIController() const;
@ -38,7 +40,6 @@ namespace mwmp
LocalPlayer *mLocalPlayer; LocalPlayer *mLocalPlayer;
GUIController *mGUIController; GUIController *mGUIController;
std::string server; std::string server;
unsigned short port; unsigned short port;
}; };

@ -177,6 +177,10 @@ namespace MWScript
throw std::runtime_error ("local variables not available in this context"); throw std::runtime_error ("local variables not available in this context");
mLocals->mShorts.at (index) = value; mLocals->mShorts.at (index) = value;
if (sendPackets)
printf("Sending ID_SCRIPT_LOCAL_SHORT for %s\n",
this->mReference.getClass().getScript(mReference));
} }
void InterpreterContext::setLocalLong (int index, int value) void InterpreterContext::setLocalLong (int index, int value)

@ -55,6 +55,9 @@ namespace MWScript
const std::string& targetId = ""); const std::string& targetId = "");
///< The ownership of \a locals is not transferred. 0-pointer allowed. ///< The ownership of \a locals is not transferred. 0-pointer allowed.
// Added by tes3mp
bool sendPackets = false;
virtual int getLocalShort (int index) const; virtual int getLocalShort (int index) const;
virtual int getLocalLong (int index) const; virtual int getLocalLong (int index) const;

Loading…
Cancel
Save