mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-16 14:59:54 +00:00
implemented GetDistance function
This commit is contained in:
parent
cc0c21cf35
commit
34b824cb70
13 changed files with 85 additions and 3 deletions
|
@ -110,6 +110,11 @@ namespace SAInterpreter
|
|||
|
||||
void Context::stopScript (const std::string& name) {}
|
||||
|
||||
float Context::getDistance (const std::string& name)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
void Context::report()
|
||||
{
|
||||
std::size_t i = 0;
|
||||
|
|
|
@ -58,6 +58,8 @@ namespace SAInterpreter
|
|||
|
||||
virtual void stopScript (const std::string& name);
|
||||
|
||||
virtual float getDistance (const std::string& name);
|
||||
|
||||
void report();
|
||||
///< Write state to std::cout
|
||||
};
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
|
||||
#include "interpretercontext.hpp"
|
||||
|
||||
#include <cmath>
|
||||
#include <stdexcept>
|
||||
#include <iostream>
|
||||
|
||||
|
@ -137,6 +138,22 @@ namespace MWScript
|
|||
mEnvironment.mGlobalScripts->removeScript (name);
|
||||
}
|
||||
|
||||
float InterpreterContext::getDistance (const std::string& name)
|
||||
{
|
||||
if (mReference.isEmpty())
|
||||
throw std::runtime_error ("no implicit reference");
|
||||
|
||||
std::pair<MWWorld::Ptr, MWWorld::World::CellStore *> ref =
|
||||
mEnvironment.mWorld->getPtr (name, true);
|
||||
|
||||
double diff[3];
|
||||
|
||||
for (int i=0; i<3; ++i)
|
||||
diff[i] = ref.first.getCellRef().pos.pos[i] - mReference.getCellRef().pos.pos[i];
|
||||
|
||||
return std::sqrt (diff[0]*diff[0] + diff[1]*diff[1] + diff[2]*diff[2]);
|
||||
}
|
||||
|
||||
MWWorld::World& InterpreterContext::getWorld()
|
||||
{
|
||||
return *mEnvironment.mWorld;
|
||||
|
|
|
@ -67,6 +67,8 @@ namespace MWScript
|
|||
|
||||
virtual void stopScript (const std::string& name);
|
||||
|
||||
virtual float getDistance (const std::string& name);
|
||||
|
||||
MWWorld::World& getWorld();
|
||||
|
||||
MWSound::SoundManager& getSoundManager();
|
||||
|
|
|
@ -326,6 +326,19 @@ namespace Compiler
|
|||
mNextOperand = false;
|
||||
return true;
|
||||
}
|
||||
else if (keyword==Scanner::K_getdistance)
|
||||
{
|
||||
mTokenLoc = loc;
|
||||
parseArguments ("c", scanner);
|
||||
|
||||
Generator::getDistance (mCode);
|
||||
mOperands.push_back ('f');
|
||||
|
||||
mNextOperand = false;
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
else
|
||||
{
|
||||
// check for custom extensions
|
||||
|
|
|
@ -274,6 +274,11 @@ namespace
|
|||
{
|
||||
code.push_back (Compiler::Generator::segment5 (48));
|
||||
}
|
||||
|
||||
void opGetDistance (Compiler::Generator::CodeContainer& code)
|
||||
{
|
||||
code.push_back (Compiler::Generator::segment5 (49));
|
||||
}
|
||||
}
|
||||
|
||||
namespace Compiler
|
||||
|
@ -665,6 +670,11 @@ namespace Compiler
|
|||
{
|
||||
opStopScript (code);
|
||||
}
|
||||
|
||||
void getDistance (CodeContainer& code)
|
||||
{
|
||||
opGetDistance (code);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -106,6 +106,8 @@ namespace Compiler
|
|||
void startScript (CodeContainer& code);
|
||||
|
||||
void stopScript (CodeContainer& code);
|
||||
|
||||
void getDistance (CodeContainer& code);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -245,6 +245,7 @@ namespace Compiler
|
|||
"menumode",
|
||||
"random",
|
||||
"startscript", "stopscript", "scriptrunning",
|
||||
"getdistance",
|
||||
0
|
||||
};
|
||||
|
||||
|
|
|
@ -51,7 +51,8 @@ namespace Compiler
|
|||
K_getsquareroot,
|
||||
K_menumode,
|
||||
K_random,
|
||||
K_startscript, K_stopscript, K_scriptrunning
|
||||
K_startscript, K_stopscript, K_scriptrunning,
|
||||
K_getdistance
|
||||
};
|
||||
|
||||
enum special
|
||||
|
|
|
@ -51,7 +51,9 @@ namespace Interpreter
|
|||
|
||||
virtual void startScript (const std::string& name) = 0;
|
||||
|
||||
virtual void stopScript (const std::string& name) = 0;
|
||||
virtual void stopScript (const std::string& name) = 0;
|
||||
|
||||
virtual float getDistance (const std::string& name) = 0;
|
||||
};
|
||||
}
|
||||
|
||||
|
|
|
@ -107,6 +107,7 @@ op 45: replace stack[0] with a random integer value in the range [0, stack[0]-1
|
|||
op 46: replace stack[0] with 1, if global script stack[0] is running, 0 else
|
||||
op 47: start script stack[0] and pop
|
||||
op 48: stop script stack[0] and pop
|
||||
opcodes 49-33554431 unused
|
||||
op 49: replace stack[0] with distance between implicit reference and a reference of ID stack[0]
|
||||
opcodes 50-33554431 unused
|
||||
opcodes 33554432-67108863 reserved for extensions
|
||||
|
||||
|
|
|
@ -10,6 +10,7 @@
|
|||
#include "controlopcodes.hpp"
|
||||
#include "miscopcodes.hpp"
|
||||
#include "scriptopcodes.hpp"
|
||||
#include "spatialopcodes.hpp"
|
||||
|
||||
namespace Interpreter
|
||||
{
|
||||
|
@ -92,6 +93,9 @@ namespace Interpreter
|
|||
interpreter.installSegment5 (46, new OpScriptRunning);
|
||||
interpreter.installSegment5 (47, new OpStartScript);
|
||||
interpreter.installSegment5 (48, new OpStopScript);
|
||||
|
||||
// spacial
|
||||
interpreter.installSegment5 (49, new OpGetDistance);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
22
components/interpreter/spatialopcodes.hpp
Normal file
22
components/interpreter/spatialopcodes.hpp
Normal file
|
@ -0,0 +1,22 @@
|
|||
#ifndef INTERPRETER_SPATIALOPCODES_H_INCLUDED
|
||||
#define INTERPRETER_SPATIALOPCODES_H_INCLUDED
|
||||
|
||||
#include "opcodes.hpp"
|
||||
#include "runtime.hpp"
|
||||
|
||||
namespace Interpreter
|
||||
{
|
||||
class OpGetDistance : public Opcode0
|
||||
{
|
||||
public:
|
||||
|
||||
virtual void execute (Runtime& runtime)
|
||||
{
|
||||
std::string name = runtime.getStringLiteral (runtime[0]);
|
||||
runtime[0] = runtime.getContext().getDistance (name);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
||||
|
Loading…
Reference in a new issue