implemented GetDistance function

actorid
Marc Zinnschlag 15 years ago
parent cc0c21cf35
commit 34b824cb70

@ -110,6 +110,11 @@ namespace SAInterpreter
void Context::stopScript (const std::string& name) {} void Context::stopScript (const std::string& name) {}
float Context::getDistance (const std::string& name)
{
return 0;
}
void Context::report() void Context::report()
{ {
std::size_t i = 0; std::size_t i = 0;

@ -58,6 +58,8 @@ namespace SAInterpreter
virtual void stopScript (const std::string& name); virtual void stopScript (const std::string& name);
virtual float getDistance (const std::string& name);
void report(); void report();
///< Write state to std::cout ///< Write state to std::cout
}; };

@ -1,6 +1,7 @@
#include "interpretercontext.hpp" #include "interpretercontext.hpp"
#include <cmath>
#include <stdexcept> #include <stdexcept>
#include <iostream> #include <iostream>
@ -137,6 +138,22 @@ namespace MWScript
mEnvironment.mGlobalScripts->removeScript (name); 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() MWWorld::World& InterpreterContext::getWorld()
{ {
return *mEnvironment.mWorld; return *mEnvironment.mWorld;

@ -67,6 +67,8 @@ namespace MWScript
virtual void stopScript (const std::string& name); virtual void stopScript (const std::string& name);
virtual float getDistance (const std::string& name);
MWWorld::World& getWorld(); MWWorld::World& getWorld();
MWSound::SoundManager& getSoundManager(); MWSound::SoundManager& getSoundManager();

@ -326,6 +326,19 @@ namespace Compiler
mNextOperand = false; mNextOperand = false;
return true; 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 else
{ {
// check for custom extensions // check for custom extensions

@ -274,6 +274,11 @@ namespace
{ {
code.push_back (Compiler::Generator::segment5 (48)); code.push_back (Compiler::Generator::segment5 (48));
} }
void opGetDistance (Compiler::Generator::CodeContainer& code)
{
code.push_back (Compiler::Generator::segment5 (49));
}
} }
namespace Compiler namespace Compiler
@ -665,6 +670,11 @@ namespace Compiler
{ {
opStopScript (code); opStopScript (code);
} }
void getDistance (CodeContainer& code)
{
opGetDistance (code);
}
} }
} }

@ -106,6 +106,8 @@ namespace Compiler
void startScript (CodeContainer& code); void startScript (CodeContainer& code);
void stopScript (CodeContainer& code); void stopScript (CodeContainer& code);
void getDistance (CodeContainer& code);
} }
} }

@ -245,6 +245,7 @@ namespace Compiler
"menumode", "menumode",
"random", "random",
"startscript", "stopscript", "scriptrunning", "startscript", "stopscript", "scriptrunning",
"getdistance",
0 0
}; };

@ -51,7 +51,8 @@ namespace Compiler
K_getsquareroot, K_getsquareroot,
K_menumode, K_menumode,
K_random, K_random,
K_startscript, K_stopscript, K_scriptrunning K_startscript, K_stopscript, K_scriptrunning,
K_getdistance
}; };
enum special enum special

@ -52,6 +52,8 @@ namespace Interpreter
virtual void startScript (const std::string& name) = 0; 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 46: replace stack[0] with 1, if global script stack[0] is running, 0 else
op 47: start script stack[0] and pop op 47: start script stack[0] and pop
op 48: stop 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 opcodes 33554432-67108863 reserved for extensions

@ -10,6 +10,7 @@
#include "controlopcodes.hpp" #include "controlopcodes.hpp"
#include "miscopcodes.hpp" #include "miscopcodes.hpp"
#include "scriptopcodes.hpp" #include "scriptopcodes.hpp"
#include "spatialopcodes.hpp"
namespace Interpreter namespace Interpreter
{ {
@ -92,6 +93,9 @@ namespace Interpreter
interpreter.installSegment5 (46, new OpScriptRunning); interpreter.installSegment5 (46, new OpScriptRunning);
interpreter.installSegment5 (47, new OpStartScript); interpreter.installSegment5 (47, new OpStartScript);
interpreter.installSegment5 (48, new OpStopScript); interpreter.installSegment5 (48, new OpStopScript);
// spacial
interpreter.installSegment5 (49, new OpGetDistance);
} }
} }

@ -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…
Cancel
Save