|
|
@ -176,10 +176,10 @@ namespace MWScript
|
|
|
|
mEnvironment.mGlobalScripts->removeScript (name);
|
|
|
|
mEnvironment.mGlobalScripts->removeScript (name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float InterpreterContext::getDistance (const std::string& name) const
|
|
|
|
float InterpreterContext::getDistance (const std::string& name, const std::string& id) const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (mReference.isEmpty())
|
|
|
|
// TODO handle exterior cells (when ref and ref2 are located in different cells)
|
|
|
|
throw std::runtime_error ("no implicit reference");
|
|
|
|
CPtrWithCell ref2 = getReference (id, false);
|
|
|
|
|
|
|
|
|
|
|
|
std::pair<MWWorld::Ptr, MWWorld::World::CellStore *> ref =
|
|
|
|
std::pair<MWWorld::Ptr, MWWorld::World::CellStore *> ref =
|
|
|
|
mEnvironment.mWorld->getPtr (name, true);
|
|
|
|
mEnvironment.mWorld->getPtr (name, true);
|
|
|
@ -187,7 +187,7 @@ namespace MWScript
|
|
|
|
double diff[3];
|
|
|
|
double diff[3];
|
|
|
|
|
|
|
|
|
|
|
|
for (int i=0; i<3; ++i)
|
|
|
|
for (int i=0; i<3; ++i)
|
|
|
|
diff[i] = ref.first.getCellRef().pos.pos[i] - mReference.getCellRef().pos.pos[i];
|
|
|
|
diff[i] = ref.first.getCellRef().pos.pos[i] - ref2.first.getCellRef().pos.pos[i];
|
|
|
|
|
|
|
|
|
|
|
|
return std::sqrt (diff[0]*diff[0] + diff[1]*diff[1] + diff[2]*diff[2]);
|
|
|
|
return std::sqrt (diff[0]*diff[0] + diff[1]*diff[1] + diff[2]*diff[2]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|