@ -140,7 +140,6 @@ namespace MWWorld
ESMStore : : StoreTuple mStores ;
ESMStore : : StoreTuple mStores ;
std : : map < ESM : : RecNameInts , DynamicStore * > mRecNameToStore ;
std : : map < ESM : : RecNameInts , DynamicStore * > mRecNameToStore ;
std : : unordered_map < const DynamicStore * , ESM : : RecNameInts > mStoreToRecName ;
// Lookup of all IDs. Makes looking up references faster. Just
// Lookup of all IDs. Makes looking up references faster. Just
// maps the id name to the record type.
// maps the id name to the record type.
@ -157,7 +156,7 @@ namespace MWWorld
assert ( & store = = & std : : get < Store < T > > ( stores . mStoreImp - > mStores ) ) ;
assert ( & store = = & std : : get < Store < T > > ( stores . mStoreImp - > mStores ) ) ;
stores . mStores [ storeIndex ] = & store ;
stores . mStores [ storeIndex ] = & store ;
if constexpr ( std : : is_convertible < Store < T > * , DynamicStore * > : : value )
if constexpr ( std : : is_convertible _v < Store < T > * , DynamicStore * > )
{
{
stores . mDynamicStores . push_back ( & store ) ;
stores . mDynamicStores . push_back ( & store ) ;
constexpr ESM : : RecNameInts recName = T : : sRecordId ;
constexpr ESM : : RecNameInts recName = T : : sRecordId ;
@ -168,19 +167,10 @@ namespace MWWorld
}
}
return 0 ;
return 0 ;
}
}
void setupAfterStoresCreation ( ESMStore & store )
{
for ( const auto & recordStorePair : mRecNameToStore )
{
const DynamicStore * storePtr = recordStorePair . second ;
mStoreToRecName [ storePtr ] = recordStorePair . first ;
}
}
} ;
} ;
int ESMStore : : find ( const std : : string_view & id ) const
int ESMStore : : find ( const std : : string_view id ) const
{
{
IDMap : : const_iterator it = mStoreImp - > mIds . find ( id ) ;
IDMap : : const_iterator it = mStoreImp - > mIds . find ( id ) ;
if ( it = = mStoreImp - > mIds . end ( ) ) {
if ( it = = mStoreImp - > mIds . end ( ) ) {
@ -189,7 +179,7 @@ namespace MWWorld
return it - > second ;
return it - > second ;
}
}
int ESMStore : : findStatic ( const std : : string & id ) const
int ESMStore : : findStatic ( const std : : string _view id ) const
{
{
IDMap : : const_iterator it = mStoreImp - > mStaticIds . find ( id ) ;
IDMap : : const_iterator it = mStoreImp - > mStaticIds . find ( id ) ;
if ( it = = mStoreImp - > mStaticIds . end ( ) ) {
if ( it = = mStoreImp - > mStaticIds . end ( ) ) {
@ -203,13 +193,10 @@ namespace MWWorld
mStoreImp = std : : make_unique < ESMStoreImp > ( ) ;
mStoreImp = std : : make_unique < ESMStoreImp > ( ) ;
std : : apply ( [ this ] ( auto & . . . x ) { ( ESMStoreImp : : assignStoreToIndex ( * this , x ) , . . . ) ; } , mStoreImp - > mStores ) ;
std : : apply ( [ this ] ( auto & . . . x ) { ( ESMStoreImp : : assignStoreToIndex ( * this , x ) , . . . ) ; } , mStoreImp - > mStores ) ;
mDynamicCount = 0 ;
mDynamicCount = 0 ;
mStoreImp - > setupAfterStoresCreation ( * this ) ;
getWritable < ESM : : Pathgrid > ( ) . setCells ( getWritable < ESM : : Cell > ( ) ) ;
getWritable < ESM : : Pathgrid > ( ) . setCells ( getWritable < ESM : : Cell > ( ) ) ;
}
}
ESMStore : : ~ ESMStore ( ) //necessary for the destruction of of unique_ptr<ESMStoreImp>
ESMStore : : ~ ESMStore ( ) = default ;
{
}
void ESMStore : : clearDynamic ( )
void ESMStore : : clearDynamic ( )
{
{
@ -325,16 +312,16 @@ void ESMStore::load(ESM::ESMReader &esm, Loading::Listener* listener, ESM::Dialo
}
}
}
}
int & ESMStore : : getIdType ( std : : string & id )
int & ESMStore : : getIdType ( const std : : string & id )
{
{
return mStoreImp - > mIds [ id ] ;
return mStoreImp - > mIds [ id ] ;
}
}
static std : : size_t sTypeIndexCounter = 0 ;
static std : : size_t sTypeIndexCounter = 0 ;
std : : size_t & ESMStore : : ge tTypeIndexCounter ( )
std : : size_t ESMStore : : ge Nex tTypeIndex( )
{
{
return sTypeIndexCounter ;
return sTypeIndexCounter + + ;
}
}
ESM : : LuaScriptsCfg ESMStore : : getLuaScriptsCfg ( ) const
ESM : : LuaScriptsCfg ESMStore : : getLuaScriptsCfg ( ) const
@ -448,8 +435,8 @@ void ESMStore::validate()
// Validate spell effects for invalid arguments
// Validate spell effects for invalid arguments
std : : vector < ESM : : Spell > spellsToReplace ;
std : : vector < ESM : : Spell > spellsToReplace ;
auto & S pells = getWritable < ESM : : Spell > ( ) ;
auto & s pells = getWritable < ESM : : Spell > ( ) ;
for ( ESM : : Spell spell : S pells)
for ( ESM : : Spell spell : s pells)
{
{
if ( spell . mEffects . mList . empty ( ) )
if ( spell . mEffects . mList . empty ( ) )
continue ;
continue ;
@ -505,8 +492,8 @@ void ESMStore::validate()
for ( const ESM : : Spell & spell : spellsToReplace )
for ( const ESM : : Spell & spell : spellsToReplace )
{
{
S pells. eraseStatic ( spell . mId ) ;
s pells. eraseStatic ( spell . mId ) ;
S pells. insertStatic ( spell ) ;
s pells. insertStatic ( spell ) ;
}
}
}
}