mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 10:23:56 +00:00
Restore getReadOnlyDoors()
This commit is contained in:
parent
abcf91be5b
commit
51b892195b
2 changed files with 18 additions and 13 deletions
|
@ -286,6 +286,18 @@ namespace MWWorld
|
|||
|
||||
/// \todo add const version of forEach
|
||||
|
||||
|
||||
// NOTE: does not account for moved references
|
||||
// Should be phased out when we have const version of forEach
|
||||
inline const CellRefList<ESM::Door>& getReadOnlyDoors() const
|
||||
{
|
||||
return mDoors;
|
||||
}
|
||||
inline const CellRefList<ESM::Static>& getReadOnlyStatics() const
|
||||
{
|
||||
return mStatics;
|
||||
}
|
||||
|
||||
bool isExterior() const;
|
||||
|
||||
Ptr searchInContainer (const std::string& id);
|
||||
|
|
|
@ -2341,8 +2341,6 @@ namespace MWWorld
|
|||
|
||||
bool World::findInteriorPosition(const std::string &name, ESM::Position &pos)
|
||||
{
|
||||
return false;
|
||||
/*
|
||||
typedef MWWorld::CellRefList<ESM::Door>::List DoorList;
|
||||
typedef MWWorld::CellRefList<ESM::Static>::List StaticList;
|
||||
|
||||
|
@ -2354,7 +2352,8 @@ namespace MWWorld
|
|||
if (0 == cellStore) {
|
||||
return false;
|
||||
}
|
||||
const DoorList &doors = cellStore->get<ESM::Door>().mList;
|
||||
|
||||
const DoorList &doors = cellStore->getReadOnlyDoors().mList;
|
||||
for (DoorList::const_iterator it = doors.begin(); it != doors.end(); ++it) {
|
||||
if (!it->mRef.getTeleport()) {
|
||||
continue;
|
||||
|
@ -2376,7 +2375,7 @@ namespace MWWorld
|
|||
if (0 != source) {
|
||||
// Find door leading to our current teleport door
|
||||
// and use it destination to position inside cell.
|
||||
const DoorList &doors = source->get<ESM::Door>().mList;
|
||||
const DoorList &doors = source->getReadOnlyDoors().mList;
|
||||
for (DoorList::const_iterator jt = doors.begin(); jt != doors.end(); ++jt) {
|
||||
if (it->mRef.getTeleport() &&
|
||||
Misc::StringUtils::ciEqual(name, jt->mRef.getDestCell()))
|
||||
|
@ -2390,12 +2389,11 @@ namespace MWWorld
|
|||
}
|
||||
}
|
||||
// Fall back to the first static location.
|
||||
const StaticList &statics = cellStore->get<ESM::Static>().mList;
|
||||
const StaticList &statics = cellStore->getReadOnlyStatics().mList;
|
||||
if ( statics.begin() != statics.end() ) {
|
||||
pos = statics.begin()->mRef.getPosition();
|
||||
return true;
|
||||
}
|
||||
*/
|
||||
|
||||
return false;
|
||||
}
|
||||
|
@ -2743,8 +2741,6 @@ namespace MWWorld
|
|||
|
||||
bool World::findInteriorPositionInWorldSpace(MWWorld::CellStore* cell, osg::Vec3f& result)
|
||||
{
|
||||
return false;
|
||||
/*
|
||||
if (cell->isExterior())
|
||||
return false;
|
||||
|
||||
|
@ -2791,7 +2787,6 @@ namespace MWWorld
|
|||
|
||||
// No luck :(
|
||||
return false;
|
||||
*/
|
||||
}
|
||||
|
||||
MWWorld::Ptr World::getClosestMarker( const MWWorld::Ptr &ptr, const std::string &id )
|
||||
|
@ -2800,7 +2795,6 @@ namespace MWWorld
|
|||
return getClosestMarkerFromExteriorPosition(mPlayer->getLastKnownExteriorPosition(), id);
|
||||
}
|
||||
|
||||
/*
|
||||
// Search for a 'nearest' marker, counting each cell between the starting
|
||||
// cell and the exterior as a distance of 1. If an exterior is found, jump
|
||||
// to the nearest exterior marker, without further interior searching.
|
||||
|
@ -2848,7 +2842,6 @@ namespace MWWorld
|
|||
}
|
||||
}
|
||||
}
|
||||
*/
|
||||
return MWWorld::Ptr();
|
||||
}
|
||||
|
||||
|
@ -2916,7 +2909,7 @@ namespace MWWorld
|
|||
Ptr mDetector;
|
||||
float mSquaredDist;
|
||||
World::DetectionType mType;
|
||||
bool operator() (MWWorld::Ptr ptr)
|
||||
bool operator() (const MWWorld::Ptr& ptr)
|
||||
{
|
||||
if ((ptr.getRefData().getPosition().asVec3() - mDetector.getRefData().getPosition().asVec3()).length2() >= mSquaredDist)
|
||||
return true;
|
||||
|
@ -2947,7 +2940,7 @@ namespace MWWorld
|
|||
return true;
|
||||
}
|
||||
|
||||
bool needToAdd (MWWorld::Ptr ptr, MWWorld::Ptr detector)
|
||||
bool needToAdd (const MWWorld::Ptr& ptr, const MWWorld::Ptr& detector)
|
||||
{
|
||||
if (mType == World::Detect_Creature)
|
||||
{
|
||||
|
|
Loading…
Reference in a new issue