@ -417,10 +417,8 @@ namespace MWWorld
void World : : write ( ESM : : ESMWriter & writer , Loading : : Listener & progress ) const
void World : : write ( ESM : : ESMWriter & writer , Loading : : Listener & progress ) const
{
{
// Active cells could have a dirty fog of war, sync it to the CellStore first
// Active cells could have a dirty fog of war, sync it to the CellStore first
for ( Scene : : CellStoreCollection : : const_iterator iter ( mWorldScene - > getActiveCells ( ) . begin ( ) ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
iter ! = mWorldScene - > getActiveCells ( ) . end ( ) ; + + iter )
{
{
CellStore * cellstore = * iter ;
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > writeFog ( cellstore ) ;
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > writeFog ( cellstore ) ;
}
}
@ -524,6 +522,17 @@ namespace MWWorld
gmst [ " iWereWolfBounty " ] = ESM : : Variant ( 1000 ) ;
gmst [ " iWereWolfBounty " ] = ESM : : Variant ( 1000 ) ;
gmst [ " fCombatDistanceWerewolfMod " ] = ESM : : Variant ( 0.3f ) ;
gmst [ " fCombatDistanceWerewolfMod " ] = ESM : : Variant ( 0.3f ) ;
for ( const std : : pair < std : : string , ESM : : Variant > & params : gmst )
{
if ( ! mStore . get < ESM : : GameSetting > ( ) . search ( params . first ) )
{
ESM : : GameSetting record ;
record . mId = params . first ;
record . mValue = params . second ;
mStore . insertStatic ( record ) ;
}
}
std : : map < std : : string , ESM : : Variant > globals ;
std : : map < std : : string , ESM : : Variant > globals ;
// vanilla Morrowind does not define dayspassed.
// vanilla Morrowind does not define dayspassed.
globals [ " dayspassed " ] = ESM : : Variant ( 1 ) ; // but the addons start counting at 1 :(
globals [ " dayspassed " ] = ESM : : Variant ( 1 ) ; // but the addons start counting at 1 :(
@ -543,25 +552,47 @@ namespace MWWorld
globals [ " crimegoldturnin " ] = ESM : : Variant ( 0 ) ;
globals [ " crimegoldturnin " ] = ESM : : Variant ( 0 ) ;
globals [ " pchasturnin " ] = ESM : : Variant ( 0 ) ;
globals [ " pchasturnin " ] = ESM : : Variant ( 0 ) ;
for ( std : : map < std : : string , ESM : : Variant > : : iterator it = gmst . begin ( ) ; it ! = gmst . end ( ) ; + + it )
for ( const std : : pair < std : : string , ESM : : Variant > & params : globals )
{
if ( ! mStore . get < ESM : : Global > ( ) . search ( params . first ) )
{
ESM : : Global record ;
record . mId = params . first ;
record . mValue = params . second ;
mStore . insertStatic ( record ) ;
}
}
std : : map < std : : string , std : : string > statics ;
// Total conversions from SureAI lack marker records
statics [ " divinemarker " ] = " marker_divine.nif " ;
statics [ " doormarker " ] = " marker_arrow.nif " ;
statics [ " northmarker " ] = " marker_north.nif " ;
statics [ " templemarker " ] = " marker_temple.nif " ;
statics [ " travelmarker " ] = " marker_travel.nif " ;
for ( const std : : pair < std : : string , std : : string > & params : statics )
{
{
if ( ! mStore . get < ESM : : GameSetting > ( ) . search ( it - > first ) )
if ( ! mStore . get < ESM : : Static> ( ) . search ( params . first ) )
{
{
ESM : : GameSetting setting ;
ESM : : Static record ;
setting . mId = it - > first ;
record. mId = params . first ;
setting . mValue = it - > second ;
record. mModel = params . second ;
mStore . insertStatic ( setting ) ;
mStore . insertStatic ( record ) ;
}
}
}
}
for ( std : : map < std : : string , ESM : : Variant > : : iterator it = globals . begin ( ) ; it ! = globals . end ( ) ; + + it )
std : : map < std : : string , std : : string > doors ;
doors [ " prisonmarker " ] = " marker_prison.nif " ;
for ( const std : : pair < std : : string , std : : string > & params : doors )
{
{
if ( ! mStore . get < ESM : : Global > ( ) . search ( it - > first ) )
if ( ! mStore . get < ESM : : Door> ( ) . search ( params . first ) )
{
{
ESM : : Global setting ;
ESM : : Door record ;
setting . mId = it - > first ;
record. mId = params . first ;
setting . mValue = it - > second ;
record. mModel = params . second ;
mStore . insertStatic ( setting ) ;
mStore . insertStatic ( record ) ;
}
}
}
}
}
}
@ -576,22 +607,19 @@ namespace MWWorld
{
{
// first try named cells
// first try named cells
const ESM : : Cell * cell = mStore . get < ESM : : Cell > ( ) . searchExtByName ( cellName ) ;
const ESM : : Cell * cell = mStore . get < ESM : : Cell > ( ) . searchExtByName ( cellName ) ;
if ( cell ! = 0 ) {
if ( cell )
return cell ;
return cell ;
}
// didn't work -> now check for regions
// didn't work -> now check for regions
const MWWorld : : Store < ESM : : Region > & regions = mStore . get < ESM : : Region > ( ) ;
for ( const ESM : : Region & region : mStore . get < ESM : : Region > ( ) )
MWWorld : : Store < ESM : : Region > : : iterator it = regions . begin ( ) ;
for ( ; it ! = regions . end ( ) ; + + it )
{
{
if ( Misc : : StringUtils : : ciEqual ( cellName , it- > mName ) )
if ( Misc : : StringUtils : : ciEqual ( cellName , region . mName ) )
{
{
return mStore . get < ESM : : Cell > ( ) . searchExtByRegion ( it- > mId ) ;
return mStore . get < ESM : : Cell > ( ) . searchExtByRegion ( region. mId ) ;
}
}
}
}
return 0 ;
return nullptr ;
}
}
const Fallback : : Map * World : : getFallback ( ) const
const Fallback : : Map * World : : getFallback ( ) const
@ -713,10 +741,10 @@ namespace MWWorld
if ( ! cell - > getCell ( ) - > isExterior ( ) | | ! cell - > getCell ( ) - > mName . empty ( ) )
if ( ! cell - > getCell ( ) - > isExterior ( ) | | ! cell - > getCell ( ) - > mName . empty ( ) )
return cell - > getCell ( ) - > mName ;
return cell - > getCell ( ) - > mName ;
if ( const ESM : : Region * region = getStore( ) . get < ESM : : Region > ( ) . search ( cell - > getCell ( ) - > mRegion ) )
if ( const ESM : : Region * region = mStore . get < ESM : : Region > ( ) . search ( cell - > getCell ( ) - > mRegion ) )
return region - > mName ;
return region - > mName ;
return getStore ( ) . get < ESM : : GameSetting > ( ) . find ( " sDefaultCellname " ) - > mValue . getString ( ) ;
return mStore . get < ESM : : GameSetting > ( ) . find ( " sDefaultCellname " ) - > mValue . getString ( ) ;
}
}
void World : : removeRefScript ( MWWorld : : RefData * ref )
void World : : removeRefScript ( MWWorld : : RefData * ref )
@ -735,11 +763,9 @@ namespace MWWorld
std : : string lowerCaseName = Misc : : StringUtils : : lowerCase ( name ) ;
std : : string lowerCaseName = Misc : : StringUtils : : lowerCase ( name ) ;
for ( Scene : : CellStoreCollection : : const_iterator iter ( mWorldScene - > getActiveCells ( ) . begin ( ) ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
iter ! = mWorldScene - > getActiveCells ( ) . end ( ) ; + + iter )
{
{
// TODO: caching still doesn't work efficiently here (only works for the one CellStore that the reference is in)
// TODO: caching still doesn't work efficiently here (only works for the one CellStore that the reference is in)
CellStore * cellstore = * iter ;
Ptr ptr = mCells . getPtr ( lowerCaseName , * cellstore , false ) ;
Ptr ptr = mCells . getPtr ( lowerCaseName , * cellstore , false ) ;
if ( ! ptr . isEmpty ( ) )
if ( ! ptr . isEmpty ( ) )
@ -753,10 +779,8 @@ namespace MWWorld
return ret ;
return ret ;
}
}
for ( Scene : : CellStoreCollection : : const_iterator iter ( mWorldScene - > getActiveCells ( ) . begin ( ) ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
iter ! = mWorldScene - > getActiveCells ( ) . end ( ) ; + + iter )
{
{
CellStore * cellstore = * iter ;
Ptr ptr = cellstore - > searchInContainer ( lowerCaseName ) ;
Ptr ptr = cellstore - > searchInContainer ( lowerCaseName ) ;
if ( ! ptr . isEmpty ( ) )
if ( ! ptr . isEmpty ( ) )
return ptr ;
return ptr ;
@ -884,15 +908,14 @@ namespace MWWorld
if ( ptr . getContainerStore ( ) = = & player . getClass ( ) . getContainerStore ( player ) )
if ( ptr . getContainerStore ( ) = = & player . getClass ( ) . getContainerStore ( player ) )
return player ;
return player ;
const Scene : : CellStoreCollection & collection = mWorldScene - > getActiveCells ( ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
for ( Scene : : CellStoreCollection : : const_iterator cellIt = collection . begin ( ) ; cellIt ! = collection . end ( ) ; + + cellIt )
{
{
FindContainerVisitor visitor ( ptr ) ;
FindContainerVisitor visitor ( ptr ) ;
( * cellIt ) - > forEachType < ESM : : Container > ( visitor ) ;
cellstore - > forEachType < ESM : : Container > ( visitor ) ;
if ( visitor . mResult . isEmpty ( ) )
if ( visitor . mResult . isEmpty ( ) )
( * cellIt ) - > forEachType < ESM : : Creature > ( visitor ) ;
cellstore - > forEachType < ESM : : Creature > ( visitor ) ;
if ( visitor . mResult . isEmpty ( ) )
if ( visitor . mResult . isEmpty ( ) )
( * cellIt ) - > forEachType < ESM : : NPC > ( visitor ) ;
cellstore - > forEachType < ESM : : NPC > ( visitor ) ;
if ( ! visitor . mResult . isEmpty ( ) )
if ( ! visitor . mResult . isEmpty ( ) )
return visitor . mResult ;
return visitor . mResult ;
@ -1135,7 +1158,7 @@ namespace MWWorld
" sMonthHeartfire " , " sMonthFrostfall " , " sMonthSunsdusk " , " sMonthEveningstar "
" sMonthHeartfire " , " sMonthFrostfall " , " sMonthSunsdusk " , " sMonthEveningstar "
} ;
} ;
return getStore ( ) . get < ESM : : GameSetting > ( ) . find ( monthNames [ month ] ) - > mValue . getString ( ) ;
return mStore . get < ESM : : GameSetting > ( ) . find ( monthNames [ month ] ) - > mValue . getString ( ) ;
}
}
TimeStamp World : : getTimeStamp ( ) const
TimeStamp World : : getTimeStamp ( ) const
@ -1224,7 +1247,7 @@ namespace MWWorld
if ( mActivationDistanceOverride > = 0 )
if ( mActivationDistanceOverride > = 0 )
return static_cast < float > ( mActivationDistanceOverride ) ;
return static_cast < float > ( mActivationDistanceOverride ) ;
static const int iMaxActivateDist = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " iMaxActivateDist " ) - > mValue . getInteger ( ) ;
static const int iMaxActivateDist = mStore . get < ESM : : GameSetting > ( ) . find ( " iMaxActivateDist " ) - > mValue . getInteger ( ) ;
return static_cast < float > ( iMaxActivateDist ) ;
return static_cast < float > ( iMaxActivateDist ) ;
}
}
@ -1492,7 +1515,10 @@ namespace MWWorld
{
{
mRendering - > moveObject ( newPtr , vec ) ;
mRendering - > moveObject ( newPtr , vec ) ;
if ( movePhysics )
if ( movePhysics )
{
mPhysics - > updatePosition ( newPtr ) ;
mPhysics - > updatePosition ( newPtr ) ;
mPhysics - > updatePtr ( ptr , newPtr ) ;
}
}
}
if ( isPlayer )
if ( isPlayer )
{
{
@ -2019,7 +2045,6 @@ namespace MWWorld
if ( ! paused )
if ( ! paused )
{
{
doPhysics ( duration ) ;
updateNavigator ( ) ;
updateNavigator ( ) ;
}
}
@ -2039,6 +2064,14 @@ namespace MWWorld
}
}
}
}
void World : : updatePhysics ( float duration , bool paused )
{
if ( ! paused )
{
doPhysics ( duration ) ;
}
}
void World : : updatePlayer ( )
void World : : updatePlayer ( )
{
{
MWWorld : : Ptr player = getPlayerPtr ( ) ;
MWWorld : : Ptr player = getPlayerPtr ( ) ;
@ -2071,7 +2104,7 @@ namespace MWWorld
bool swimming = isSwimming ( player ) ;
bool swimming = isSwimming ( player ) ;
bool flying = isFlying ( player ) ;
bool flying = isFlying ( player ) ;
static const float i1stPersonSneakDelta = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " i1stPersonSneakDelta " ) - > mValue . getFloat ( ) ;
static const float i1stPersonSneakDelta = mStore . get < ESM : : GameSetting > ( ) . find ( " i1stPersonSneakDelta " ) - > mValue . getFloat ( ) ;
if ( sneaking & & ! swimming & & ! flying )
if ( sneaking & & ! swimming & & ! flying )
mRendering - > getCamera ( ) - > setSneakOffset ( i1stPersonSneakDelta ) ;
mRendering - > getCamera ( ) - > setSneakOffset ( i1stPersonSneakDelta ) ;
else
else
@ -2697,9 +2730,8 @@ namespace MWWorld
player . getClass ( ) . getInventoryStore ( player ) . setInvListener ( anim , player ) ;
player . getClass ( ) . getInventoryStore ( player ) . setInvListener ( anim , player ) ;
player . getClass ( ) . getInventoryStore ( player ) . setContListener ( anim ) ;
player . getClass ( ) . getInventoryStore ( player ) . setContListener ( anim ) ;
scaleObject ( getPlayerPtr ( ) , 1.f ) ; // apply race height
scaleObject ( player , player . getCellRef ( ) . getScale ( ) ) ; // apply race height
rotateObject ( player , 0.f , 0.f , 0.f , true ) ;
rotateObject ( getPlayerPtr ( ) , 0.f , 0.f , 0.f , true ) ;
MWBase : : Environment : : get ( ) . getMechanicsManager ( ) - > add ( getPlayerPtr ( ) ) ;
MWBase : : Environment : : get ( ) . getMechanicsManager ( ) - > add ( getPlayerPtr ( ) ) ;
MWBase : : Environment : : get ( ) . getMechanicsManager ( ) - > watchActor ( getPlayerPtr ( ) ) ;
MWBase : : Environment : : get ( ) . getMechanicsManager ( ) - > watchActor ( getPlayerPtr ( ) ) ;
@ -2893,17 +2925,16 @@ namespace MWWorld
std : : vector < MWWorld : : Ptr > actors ;
std : : vector < MWWorld : : Ptr > actors ;
mPhysics - > getActorsStandingOn ( object , actors ) ;
mPhysics - > getActorsStandingOn ( object , actors ) ;
for ( std : : vector < MWWorld : : Ptr > : : iterator it = actors . begin ( ) ; it ! = actors . end ( ) ; + + it )
for ( const Ptr & actor : actors )
{
{
MWWorld : : Ptr actor = * it ;
MWMechanics : : CreatureStats & stats = actor . getClass ( ) . getCreatureStats ( actor ) ;
MWMechanics : : CreatureStats & stats = actor . getClass ( ) . getCreatureStats ( actor ) ;
if ( stats . isDead ( ) )
if ( stats . isDead ( ) )
continue ;
continue ;
mPhysics - > markAsNonSolid ( object ) ;
mPhysics - > markAsNonSolid ( object ) ;
if ( actor = = getPlayerPtr ( ) & & MWBase: : Environ ment: : get ( ) . getWorld ( ) - > get GodModeState( ) )
if ( actor = = getPlayerPtr ( ) & & mGodMode)
return ;
continue ;
MWMechanics : : DynamicStat < float > health = stats . getHealth ( ) ;
MWMechanics : : DynamicStat < float > health = stats . getHealth ( ) ;
health . setCurrent ( health . getCurrent ( ) - healthPerSecond * MWBase : : Environment : : get ( ) . getFrameDuration ( ) ) ;
health . setCurrent ( health . getCurrent ( ) - healthPerSecond * MWBase : : Environment : : get ( ) . getFrameDuration ( ) ) ;
@ -2934,19 +2965,18 @@ namespace MWWorld
End of tes3mp change ( major )
End of tes3mp change ( major )
*/
*/
std : : vector < MWWorld: : Ptr> actors ;
std : : vector < Ptr> actors ;
mPhysics - > getActorsCollidingWith ( object , actors ) ;
mPhysics - > getActorsCollidingWith ( object , actors ) ;
for ( std : : vector < MWWorld : : Ptr > : : iterator it = actors . begin ( ) ; it ! = actors . end ( ) ; + + it )
for ( const Ptr & actor : actors )
{
{
MWWorld : : Ptr actor = * it ;
MWMechanics : : CreatureStats & stats = actor . getClass ( ) . getCreatureStats ( actor ) ;
MWMechanics : : CreatureStats & stats = actor . getClass ( ) . getCreatureStats ( actor ) ;
if ( stats . isDead ( ) )
if ( stats . isDead ( ) )
continue ;
continue ;
mPhysics - > markAsNonSolid ( object ) ;
mPhysics - > markAsNonSolid ( object ) ;
if ( actor = = getPlayerPtr ( ) & & MWBase: : Environ ment: : get ( ) . getWorld ( ) - > get GodModeState( ) )
if ( actor = = getPlayerPtr ( ) & & mGodMode)
return ;
continue ;
MWMechanics : : DynamicStat < float > health = stats . getHealth ( ) ;
MWMechanics : : DynamicStat < float > health = stats . getHealth ( ) ;
health . setCurrent ( health . getCurrent ( ) - healthPerSecond * MWBase : : Environment : : get ( ) . getFrameDuration ( ) ) ;
health . setCurrent ( health . getCurrent ( ) - healthPerSecond * MWBase : : Environment : : get ( ) . getFrameDuration ( ) ) ;
@ -3016,11 +3046,10 @@ namespace MWWorld
void World : : getContainersOwnedBy ( const MWWorld : : ConstPtr & owner , std : : vector < MWWorld : : Ptr > & out )
void World : : getContainersOwnedBy ( const MWWorld : : ConstPtr & owner , std : : vector < MWWorld : : Ptr > & out )
{
{
const Scene : : CellStoreCollection & collection = mWorldScene - > getActiveCells ( ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
for ( Scene : : CellStoreCollection : : const_iterator cellIt = collection . begin ( ) ; cellIt ! = collection . end ( ) ; + + cellIt )
{
{
GetContainersOwnedByVisitor visitor ( owner , out ) ;
GetContainersOwnedByVisitor visitor ( owner , out ) ;
( * cellIt ) - > forEachType < ESM : : Container > ( visitor ) ;
cellstore - > forEachType < ESM : : Container > ( visitor ) ;
}
}
}
}
@ -3038,15 +3067,14 @@ namespace MWWorld
void World : : getItemsOwnedBy ( const MWWorld : : ConstPtr & npc , std : : vector < MWWorld : : Ptr > & out )
void World : : getItemsOwnedBy ( const MWWorld : : ConstPtr & npc , std : : vector < MWWorld : : Ptr > & out )
{
{
const Scene : : CellStoreCollection & collection = mWorldScene - > getActiveCells ( ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
for ( Scene : : CellStoreCollection : : const_iterator cellIt = collection . begin ( ) ; cellIt ! = collection . end ( ) ; + + cellIt )
{
{
ListObjectsVisitor visitor ;
ListObjectsVisitor visitor ;
( * cellIt ) - > forEach ( visitor ) ;
cellstore - > forEach ( visitor ) ;
for ( std : : vector < MWWorld : : Ptr > : : iterator it = visitor . mObjects . begin ( ) ; it ! = visitor . mObjects . end ( ) ; + + it )
for ( const Ptr & object : visitor . mObjects )
if ( Misc : : StringUtils : : ciEqual ( it- > getCellRef ( ) . getOwner ( ) , npc . getCellRef ( ) . getRefId ( ) ) )
if ( Misc : : StringUtils : : ciEqual ( object. getCellRef ( ) . getOwner ( ) , npc . getCellRef ( ) . getRefId ( ) ) )
out . push_back ( * i t) ;
out . push_back ( objec t) ;
}
}
}
}
@ -3087,28 +3115,21 @@ namespace MWWorld
bool World : : findInteriorPosition ( const std : : string & name , ESM : : Position & pos )
bool World : : findInteriorPosition ( const std : : string & name , ESM : : Position & pos )
{
{
typedef MWWorld : : CellRefList < ESM : : Door > : : List DoorList ;
typedef MWWorld : : CellRefList < ESM : : Static > : : List StaticList ;
pos . rot [ 0 ] = pos . rot [ 1 ] = pos . rot [ 2 ] = 0 ;
pos . rot [ 0 ] = pos . rot [ 1 ] = pos . rot [ 2 ] = 0 ;
pos . pos [ 0 ] = pos . pos [ 1 ] = pos . pos [ 2 ] = 0 ;
pos . pos [ 0 ] = pos . pos [ 1 ] = pos . pos [ 2 ] = 0 ;
MWWorld : : CellStore * cellStore = getInterior ( name ) ;
MWWorld : : CellStore * cellStore = getInterior ( name ) ;
if ( 0 = = cellStore ) {
if ( ! cellStore )
return false ;
return false ;
}
std : : vector < const MWWorld : : CellRef * > sortedDoors ;
std : : vector < const MWWorld : : CellRef * > sortedDoors ;
const DoorList & doors = cellStore - > getReadOnlyDoors ( ) . mList ;
for ( const MWWorld : : LiveCellRef < ESM : : Door > & door : cellStore - > getReadOnlyDoors ( ) . mList )
for ( DoorList : : const_iterator it = doors . begin ( ) ; it ! = doors . end ( ) ; + + it )
{
if ( ! it - > mRef . getTeleport ( ) )
{
{
if ( ! door . mRef . getTeleport ( ) )
continue ;
continue ;
}
sortedDoors . push_back ( & it- > mRef ) ;
sortedDoors . push_back ( & door. mRef ) ;
}
}
// Sort teleporting doors alphabetically, first by ID, then by destination cell to make search consistent
// Sort teleporting doors alphabetically, first by ID, then by destination cell to make search consistent
@ -3120,44 +3141,43 @@ namespace MWWorld
return lhs - > getDestCell ( ) < rhs - > getDestCell ( ) ;
return lhs - > getDestCell ( ) < rhs - > getDestCell ( ) ;
} ) ;
} ) ;
for ( std : : vector < const MWWorld : : CellRef * > : : const_iterator it = sortedDoors . begin ( ) ; it ! = sortedDoors . end ( ) ; + + it )
for ( const MWWorld : : CellRef * door : sortedDoors )
{
{
MWWorld : : CellStore * source = 0 ;
MWWorld : : CellStore * source = nullptr ;
// door to exterior
// door to exterior
if ( ( * it ) - > getDestCell ( ) . empty ( ) )
if ( door - > getDestCell ( ) . empty ( ) )
{
{
int x , y ;
int x , y ;
ESM : : Position doorDest = ( * it ) - > getDoorDest ( ) ;
ESM : : Position doorDest = door - > getDoorDest ( ) ;
positionToIndex ( doorDest . pos [ 0 ] , doorDest . pos [ 1 ] , x , y ) ;
positionToIndex ( doorDest . pos [ 0 ] , doorDest . pos [ 1 ] , x , y ) ;
source = getExterior ( x , y ) ;
source = getExterior ( x , y ) ;
}
}
// door to interior
// door to interior
else
else
{
{
source = getInterior ( ( * it ) - > getDestCell ( ) ) ;
source = getInterior ( door - > getDestCell ( ) ) ;
}
}
if ( 0 ! = source )
if ( source )
{
{
// Find door leading to our current teleport door
// Find door leading to our current teleport door
// and use its destination to position inside cell.
// and use its destination to position inside cell.
const DoorList & destinationDoors = source - > getReadOnlyDoors ( ) . mList ;
for ( const MWWorld : : LiveCellRef < ESM : : Door > & destDoor : source - > getReadOnlyDoors ( ) . mList )
for ( DoorList : : const_iterator jt = destinationDoors . begin ( ) ; jt ! = destinationDoors . end ( ) ; + + jt )
{
{
if ( ( * it ) - > getTeleport ( ) & &
if ( Misc : : StringUtils : : ciEqual ( name , destDoor . mRef . getDestCell ( ) ) )
Misc : : StringUtils : : ciEqual ( name , jt - > mRef . getDestCell ( ) ) )
{
{
/// \note Using _any_ door pointed to the interior,
/// \note Using _any_ door pointed to the interior,
/// not the one pointed to current door.
/// not the one pointed to current door.
pos = jt- > mRef . getDoorDest ( ) ;
pos = destDoor. mRef . getDoorDest ( ) ;
return true ;
return true ;
}
}
}
}
}
}
}
}
// Fall back to the first static location.
// Fall back to the first static location.
const StaticList & statics = cellStore - > getReadOnlyStatics ( ) . mList ;
const MWWorld : : CellRefList < ESM : : Static > : : List & statics = cellStore - > getReadOnlyStatics ( ) . mList ;
if ( statics . begin ( ) ! = statics . end ( ) ) {
if ( ! statics . empty ( ) )
{
pos = statics . begin ( ) - > mRef . getPosition ( ) ;
pos = statics . begin ( ) - > mRef . getPosition ( ) ;
return true ;
return true ;
}
}
@ -3252,22 +3272,21 @@ namespace MWWorld
void World : : loadContentFiles ( const Files : : Collections & fileCollections ,
void World : : loadContentFiles ( const Files : : Collections & fileCollections ,
const std : : vector < std : : string > & content , ContentLoader & contentLoader )
const std : : vector < std : : string > & content , ContentLoader & contentLoader )
{
{
std : : vector < std : : string > : : const_iterator it ( content . begin ( ) ) ;
int idx = 0 ;
std : : vector < std : : string > : : const_iterator end ( content . end ( ) ) ;
for ( const std : : string & file : content )
for ( int idx = 0 ; it ! = end ; + + it , + + idx )
{
{
boost : : filesystem : : path filename ( * it ) ;
boost : : filesystem : : path filename ( file ) ;
const Files : : MultiDirCollection & col = fileCollections . getCollection ( filename . extension ( ) . string ( ) ) ;
const Files : : MultiDirCollection & col = fileCollections . getCollection ( filename . extension ( ) . string ( ) ) ;
if ( col . doesExist ( * it ) )
if ( col . doesExist ( file ) )
{
{
contentLoader . load ( col . getPath ( * it ) , idx ) ;
contentLoader . load ( col . getPath ( file ) , idx ) ;
}
}
else
else
{
{
std : : stringstream msg ;
std : : string message = " Failed loading " + file + " : the content file does not exist " ;
msg < < " Failed loading " < < * it < < " : the content file does not exist " ;
throw std : : runtime_error ( message ) ;
throw std : : runtime_error ( msg . str ( ) ) ;
}
}
idx + + ;
}
}
}
}
@ -3307,10 +3326,10 @@ namespace MWWorld
End of tes3mp addition
End of tes3mp addition
*/
*/
const ESM : : Spell * spell = getStore( ) . get < ESM : : Spell > ( ) . find ( selectedSpell ) ;
const ESM : : Spell * spell = mStore . get < ESM : : Spell > ( ) . find ( selectedSpell ) ;
// Check mana
// Check mana
bool godmode = ( isPlayer & & getGodModeState( ) ) ;
bool godmode = ( isPlayer & & mGodMode ) ;
MWMechanics : : DynamicStat < float > magicka = stats . getMagicka ( ) ;
MWMechanics : : DynamicStat < float > magicka = stats . getMagicka ( ) ;
if ( magicka . getCurrent ( ) < spell - > mData . mCost & & ! godmode )
if ( magicka . getCurrent ( ) < spell - > mData . mCost & & ! godmode )
{
{
@ -3348,7 +3367,7 @@ namespace MWWorld
if ( ! actor . isEmpty ( ) & & actor ! = MWMechanics : : getPlayer ( ) & & ! manualSpell )
if ( ! actor . isEmpty ( ) & & actor ! = MWMechanics : : getPlayer ( ) & & ! manualSpell )
stats . getAiSequence ( ) . getCombatTargets ( targetActors ) ;
stats . getAiSequence ( ) . getCombatTargets ( targetActors ) ;
const float fCombatDistance = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " fCombatDistance " ) - > mValue . getFloat ( ) ;
const float fCombatDistance = mStore . get < ESM : : GameSetting > ( ) . find ( " fCombatDistance " ) - > mValue . getFloat ( ) ;
osg : : Vec3f hitPosition = actor . getRefData ( ) . getPosition ( ) . asVec3 ( ) ;
osg : : Vec3f hitPosition = actor . getRefData ( ) . getPosition ( ) . asVec3 ( ) ;
@ -3366,14 +3385,13 @@ namespace MWWorld
// For scripted spells we should not use hit contact
// For scripted spells we should not use hit contact
if ( manualSpell )
if ( manualSpell )
{
{
// Actors that are targeted by this actor's Follow or Escort packages also side with them
if ( actor ! = MWMechanics : : getPlayer ( ) )
if ( actor ! = MWMechanics : : getPlayer ( ) )
{
{
for ( std : : list < MWMechanics : : AiPackage * > : : const_iterator it = stats . getAiSequence ( ) . begin ( ) ; it ! = stats . getAiSequence ( ) . end ( ) ; + + it )
for ( const MWMechanics : : AiPackage * package : stats . getAiSequence ( ) )
{
{
if ( ( * it ) - > getTypeId ( ) = = MWMechanics : : AiPackage : : TypeIdCast )
if ( package - > getTypeId ( ) = = MWMechanics : : AiPackage : : TypeIdCast )
{
{
target = ( * it ) - > getTarget ( ) ;
target = package - > getTarget ( ) ;
break ;
break ;
}
}
}
}
@ -3431,7 +3449,7 @@ namespace MWWorld
if ( ! selectedSpell . empty ( ) )
if ( ! selectedSpell . empty ( ) )
{
{
const ESM : : Spell * spell = getStore( ) . get < ESM : : Spell > ( ) . find ( selectedSpell ) ;
const ESM : : Spell * spell = mStore . get < ESM : : Spell > ( ) . find ( selectedSpell ) ;
cast . cast ( spell ) ;
cast . cast ( spell ) ;
}
}
else if ( actor . getClass ( ) . hasInventoryStore ( actor ) )
else if ( actor . getClass ( ) . hasInventoryStore ( actor ) )
@ -3566,17 +3584,14 @@ namespace MWWorld
while ( ! nextCells . empty ( ) ) {
while ( ! nextCells . empty ( ) ) {
currentCells = nextCells ;
currentCells = nextCells ;
nextCells . clear ( ) ;
nextCells . clear ( ) ;
for ( std : : set < std : : string > : : const_iterator i = currentCells . begin ( ) ; i ! = currentCells . end ( ) ; + + i ) {
for ( const std : : string & currentCell : currentCells )
MWWorld : : CellStore * next = getInterior ( * i ) ;
{
MWWorld : : CellStore * next = getInterior ( currentCell ) ;
if ( ! next ) continue ;
if ( ! next ) continue ;
const MWWorld : : CellRefList < ESM : : Door > & doors = next - > getReadOnlyDoors ( ) ;
const CellRefList < ESM : : Door > : : List & refList = doors . mList ;
// Check if any door in the cell leads to an exterior directly
// Check if any door in the cell leads to an exterior directly
for ( CellRefList < ESM : : Door > :: List : : const_iterator it = refList . begin ( ) ; it ! = refList . end ( ) ; + + i t)
for ( const MWWorld : : LiveCellRef < ESM : : Door > & ref : next - > getReadOnlyDoors ( ) . mList )
{
{
const MWWorld : : LiveCellRef < ESM : : Door > & ref = * it ;
if ( ! ref . mRef . getTeleport ( ) ) continue ;
if ( ! ref . mRef . getTeleport ( ) ) continue ;
if ( ref . mRef . getDestCell ( ) . empty ( ) )
if ( ref . mRef . getDestCell ( ) . empty ( ) )
@ -3593,7 +3608,7 @@ namespace MWWorld
}
}
}
}
checkedCells . insert ( * i ) ;
checkedCells . insert ( currentCell ) ;
}
}
}
}
@ -3619,9 +3634,9 @@ namespace MWWorld
while ( ! nextCells . empty ( ) ) {
while ( ! nextCells . empty ( ) ) {
currentCells = nextCells ;
currentCells = nextCells ;
nextCells . clear ( ) ;
nextCells . clear ( ) ;
for ( std : : set < std : : string > : : const_iterator i = currentCells . begin ( ) ; i ! = currentCells . end ( ) ; + + i ) {
for ( const std : : string & cell : currentCells ) {
MWWorld : : CellStore * next = getInterior ( * i ) ;
MWWorld : : CellStore * next = getInterior ( cell ) ;
checkedCells . insert ( * i ) ;
checkedCells . insert ( cell ) ;
if ( ! next ) continue ;
if ( ! next ) continue ;
closestMarker = next - > searchConst ( id ) ;
closestMarker = next - > searchConst ( id ) ;
@ -3630,14 +3645,9 @@ namespace MWWorld
return closestMarker ;
return closestMarker ;
}
}
const MWWorld : : CellRefList < ESM : : Door > & doors = next - > getReadOnlyDoors ( ) ;
const CellRefList < ESM : : Door > : : List & doorList = doors . mList ;
// Check if any door in the cell leads to an exterior directly
// Check if any door in the cell leads to an exterior directly
for ( CellRefList < ESM : : Door > :: List : : const_iterator it = doorList . begin ( ) ; it ! = doorList . end ( ) ; + + i t)
for ( const MWWorld : : LiveCellRef < ESM : : Door > & ref : next - > getReadOnlyDoors ( ) . mList )
{
{
const MWWorld : : LiveCellRef < ESM : : Door > & ref = * it ;
if ( ! ref . mRef . getTeleport ( ) ) continue ;
if ( ! ref . mRef . getTeleport ( ) ) continue ;
if ( ref . mRef . getDestCell ( ) . empty ( ) )
if ( ref . mRef . getDestCell ( ) . empty ( ) )
@ -3663,15 +3673,14 @@ namespace MWWorld
std : : vector < MWWorld : : Ptr > markers ;
std : : vector < MWWorld : : Ptr > markers ;
mCells . getExteriorPtrs ( id , markers ) ;
mCells . getExteriorPtrs ( id , markers ) ;
for ( std : : vector < MWWorld : : Ptr > : : iterator it2 = markers . begin ( ) ; it2 ! = markers . end ( ) ; + + it2 )
for ( const Ptr & marker : markers )
{
{
ESM : : Position pos = it2 - > getRefData ( ) . getPosition ( ) ;
osg : : Vec3f markerPos = marker . getRefData ( ) . getPosition ( ) . asVec3 ( ) ;
osg : : Vec3f markerPos = pos . asVec3 ( ) ;
float distance = ( worldPos - markerPos ) . length2 ( ) ;
float distance = ( worldPos - markerPos ) . length2 ( ) ;
if ( distance < closestDistance )
if ( distance < closestDistance )
{
{
closestDistance = distance ;
closestDistance = distance ;
closestMarker = * it2 ;
closestMarker = marker ;
}
}
}
}
@ -3802,10 +3811,8 @@ namespace MWWorld
AddDetectedReferenceVisitor visitor ( out , ptr , type , dist * dist ) ;
AddDetectedReferenceVisitor visitor ( out , ptr , type , dist * dist ) ;
const Scene : : CellStoreCollection & active = mWorldScene - > getActiveCells ( ) ;
for ( CellStore * cellStore : mWorldScene - > getActiveCells ( ) )
for ( Scene : : CellStoreCollection : : const_iterator it = active . begin ( ) ; it ! = active . end ( ) ; + + it )
{
{
MWWorld : : CellStore * cellStore = * it ;
cellStore - > forEach ( visitor ) ;
cellStore - > forEach ( visitor ) ;
}
}
}
}
@ -3840,8 +3847,8 @@ namespace MWWorld
int bounty = player . getClass ( ) . getNpcStats ( player ) . getBounty ( ) ;
int bounty = player . getClass ( ) . getNpcStats ( player ) . getBounty ( ) ;
int playerGold = player . getClass ( ) . getContainerStore ( player ) . count ( ContainerStore : : sGoldId ) ;
int playerGold = player . getClass ( ) . getContainerStore ( player ) . count ( ContainerStore : : sGoldId ) ;
float fCrimeGoldDiscountMult = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " fCrimeGoldDiscountMult " ) - > mValue . getFloat ( ) ;
static float fCrimeGoldDiscountMult = mStore . get < ESM : : GameSetting > ( ) . find ( " fCrimeGoldDiscountMult " ) - > mValue . getFloat ( ) ;
float fCrimeGoldTurnInMult = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " fCrimeGoldTurnInMult " ) - > mValue . getFloat ( ) ;
static float fCrimeGoldTurnInMult = mStore . get < ESM : : GameSetting > ( ) . find ( " fCrimeGoldTurnInMult " ) - > mValue . getFloat ( ) ;
int discount = static_cast < int > ( bounty * fCrimeGoldDiscountMult ) ;
int discount = static_cast < int > ( bounty * fCrimeGoldDiscountMult ) ;
int turnIn = static_cast < int > ( bounty * fCrimeGoldTurnInMult ) ;
int turnIn = static_cast < int > ( bounty * fCrimeGoldTurnInMult ) ;
@ -3906,7 +3913,7 @@ namespace MWWorld
mPlayer - > recordCrimeId ( ) ;
mPlayer - > recordCrimeId ( ) ;
confiscateStolenItems ( player ) ;
confiscateStolenItems ( player ) ;
int iDaysinPrisonMod = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " iDaysinPrisonMod " ) - > mValue . getInteger ( ) ;
static int iDaysinPrisonMod = mStore . get < ESM : : GameSetting > ( ) . find ( " iDaysinPrisonMod " ) - > mValue . getInteger ( ) ;
mDaysInPrison = std : : max ( 1 , bounty / iDaysinPrisonMod ) ;
mDaysInPrison = std : : max ( 1 , bounty / iDaysinPrisonMod ) ;
return ;
return ;
@ -3962,18 +3969,18 @@ namespace MWWorld
void World : : spawnRandomCreature ( const std : : string & creatureList )
void World : : spawnRandomCreature ( const std : : string & creatureList )
{
{
const ESM : : CreatureLevList * list = getStore( ) . get < ESM : : CreatureLevList > ( ) . find ( creatureList ) ;
const ESM : : CreatureLevList * list = mStore . get < ESM : : CreatureLevList > ( ) . find ( creatureList ) ;
int iNumberCreatures = getStore( ) . get < ESM : : GameSetting > ( ) . find ( " iNumberCreatures " ) - > mValue . getInteger ( ) ;
static int iNumberCreatures = mStore . get < ESM : : GameSetting > ( ) . find ( " iNumberCreatures " ) - > mValue . getInteger ( ) ;
int numCreatures = 1 + Misc : : Rng : : rollDice ( iNumberCreatures ) ; // [1, iNumberCreatures]
int numCreatures = 1 + Misc : : Rng : : rollDice ( iNumberCreatures ) ; // [1, iNumberCreatures]
for ( int i = 0 ; i < numCreatures ; + + i )
for ( int i = 0 ; i < numCreatures ; + + i )
{
{
std : : string selectedCreature = MWMechanics : : getLevelledItem ( list , true ) ;
std : : string selectedCreature = MWMechanics : : getLevelledItem ( list , true ) ;
if ( selectedCreature . empty ( ) )
if ( selectedCreature . empty ( ) )
return ;
continue ;
MWWorld : : ManualRef ref ( getStore( ) , selectedCreature , 1 ) ;
MWWorld : : ManualRef ref ( mStore , selectedCreature , 1 ) ;
/*
/*
Start of tes3mp change ( major )
Start of tes3mp change ( major )
@ -4001,27 +4008,8 @@ namespace MWWorld
if ( ptr = = getPlayerPtr ( ) & & Settings : : Manager : : getBool ( " hit fader " , " GUI " ) )
if ( ptr = = getPlayerPtr ( ) & & Settings : : Manager : : getBool ( " hit fader " , " GUI " ) )
return ;
return ;
int type = ptr . getClass ( ) . getBloodTexture ( ptr ) ;
std : : string texture = getFallback ( ) - > getFallbackString ( " Blood_Texture_ " + std : : to_string ( ptr . getClass ( ) . getBloodTexture ( ptr ) ) ) ;
std : : string texture ;
std : : string model = " meshes \\ " + getFallback ( ) - > getFallbackString ( " Blood_Model_ " + std : : to_string ( Misc : : Rng : : rollDice ( 3 ) ) ) ; // [0, 2]
switch ( type )
{
case 2 :
texture = getFallback ( ) - > getFallbackString ( " Blood_Texture_2 " ) ;
break ;
case 1 :
texture = getFallback ( ) - > getFallbackString ( " Blood_Texture_1 " ) ;
break ;
case 0 :
default :
texture = getFallback ( ) - > getFallbackString ( " Blood_Texture_0 " ) ;
break ;
}
std : : stringstream modelName ;
modelName < < " Blood_Model_ " ;
int roll = Misc : : Rng : : rollDice ( 3 ) ; // [0, 2]
modelName < < roll ;
std : : string model = " meshes \\ " + getFallback ( ) - > getFallbackString ( modelName . str ( ) ) ;
mRendering - > spawnEffect ( model , texture , worldPosition , 1.0f , false ) ;
mRendering - > spawnEffect ( model , texture , worldPosition , 1.0f , false ) ;
}
}
@ -4038,7 +4026,7 @@ namespace MWWorld
for ( std : : vector < ESM : : ENAMstruct > : : const_iterator effectIt = effects . mList . begin ( ) ;
for ( std : : vector < ESM : : ENAMstruct > : : const_iterator effectIt = effects . mList . begin ( ) ;
effectIt ! = effects . mList . end ( ) ; + + effectIt )
effectIt ! = effects . mList . end ( ) ; + + effectIt )
{
{
const ESM : : MagicEffect * effect = getStore( ) . get < ESM : : MagicEffect > ( ) . find ( effectIt - > mEffectID ) ;
const ESM : : MagicEffect * effect = mStore . get < ESM : : MagicEffect > ( ) . find ( effectIt - > mEffectID ) ;
if ( effectIt - > mRange ! = rangeType | | ( effectIt - > mArea < = 0 & & ! ignore . isEmpty ( ) & & ignore . getClass ( ) . isActor ( ) ) )
if ( effectIt - > mRange ! = rangeType | | ( effectIt - > mArea < = 0 & & ! ignore . isEmpty ( ) & & ignore . getClass ( ) . isActor ( ) ) )
continue ; // Not right range type, or not area effect and hit an actor
continue ; // Not right range type, or not area effect and hit an actor
@ -4052,9 +4040,9 @@ namespace MWWorld
// Spawn the explosion orb effect
// Spawn the explosion orb effect
const ESM : : Static * areaStatic ;
const ESM : : Static * areaStatic ;
if ( ! effect - > mArea . empty ( ) )
if ( ! effect - > mArea . empty ( ) )
areaStatic = getStore( ) . get < ESM : : Static > ( ) . find ( effect - > mArea ) ;
areaStatic = mStore . get < ESM : : Static > ( ) . find ( effect - > mArea ) ;
else
else
areaStatic = getStore( ) . get < ESM : : Static > ( ) . find ( " VFX_DefaultArea " ) ;
areaStatic = mStore . get < ESM : : Static > ( ) . find ( " VFX_DefaultArea " ) ;
std : : string texture = effect - > mParticle ;
std : : string texture = effect - > mParticle ;
@ -4082,13 +4070,13 @@ namespace MWWorld
std : : vector < MWWorld : : Ptr > objects ;
std : : vector < MWWorld : : Ptr > objects ;
MWBase : : Environment : : get ( ) . getMechanicsManager ( ) - > getObjectsInRange (
MWBase : : Environment : : get ( ) . getMechanicsManager ( ) - > getObjectsInRange (
origin , feetToGameUnits ( static_cast < float > ( effectIt - > mArea ) ) , objects ) ;
origin , feetToGameUnits ( static_cast < float > ( effectIt - > mArea ) ) , objects ) ;
for ( std : : vector < MWWorld : : Ptr > : : iterator affected = objects . begin ( ) ; affected ! = objects . end ( ) ; + + affected )
for ( const Ptr & affected : objects )
{
{
// Ignore actors without collisions here, otherwise it will be possible to hit actors outside processing range.
// Ignore actors without collisions here, otherwise it will be possible to hit actors outside processing range.
if ( affected - > getClass ( ) . isActor ( ) & & ! isActorCollisionEnabled ( * affected ) )
if ( affected . getClass ( ) . isActor ( ) & & ! isActorCollisionEnabled ( affected ) )
continue ;
continue ;
toApply [ * affected ] . push_back ( * effectIt ) ;
toApply [ affected ] . push_back ( * effectIt ) ;
}
}
}
}
@ -4148,10 +4136,8 @@ namespace MWWorld
} ;
} ;
void World : : resetActors ( )
void World : : resetActors ( )
{
{
for ( Scene : : CellStoreCollection : : const_iterator iter ( mWorldScene - > getActiveCells ( ) . begin ( ) ) ;
for ( CellStore * cellstore : mWorldScene - > getActiveCells ( ) )
iter ! = mWorldScene - > getActiveCells ( ) . end ( ) ; + + iter )
{
{
CellStore * cellstore = * iter ;
ResetActorsVisitor visitor ;
ResetActorsVisitor visitor ;
cellstore - > forEach ( visitor ) ;
cellstore - > forEach ( visitor ) ;
}
}