@ -29,6 +29,7 @@ namespace
void readRefs ( const ESM : : Cell & cell , std : : vector < Ref > & refs , std : : vector < std : : string > & refIDs , std : : vector < ESM : : ESMReader > & readers )
void readRefs ( const ESM : : Cell & cell , std : : vector < Ref > & refs , std : : vector < std : : string > & refIDs , std : : vector < ESM : : ESMReader > & readers )
{
{
// TODO: we have many similar copies of this code.
for ( size_t i = 0 ; i < cell . mContextList . size ( ) ; i + + )
for ( size_t i = 0 ; i < cell . mContextList . size ( ) ; i + + )
{
{
size_t index = cell . mContextList [ i ] . index ;
size_t index = cell . mContextList [ i ] . index ;
@ -301,12 +302,14 @@ void ESMStore::setUp(bool validateRecords)
if ( validateRecords )
if ( validateRecords )
{
{
validate ( ) ;
validate ( ) ;
count Record s( ) ;
count AllCellRef s( ) ;
}
}
}
}
void ESMStore : : count Record s( )
void ESMStore : : count AllCellRef s( )
{
{
// TODO: We currently need to read entire files here again.
// We should consider consolidating or deferring this reading.
if ( ! mRefCount . empty ( ) )
if ( ! mRefCount . empty ( ) )
return ;
return ;
std : : vector < Ref > refs ;
std : : vector < Ref > refs ;
@ -324,6 +327,8 @@ void ESMStore::countRecords()
if ( value . mRefID ! = deletedRefID )
if ( value . mRefID ! = deletedRefID )
{
{
std : : string & refId = refIDs [ value . mRefID ] ;
std : : string & refId = refIDs [ value . mRefID ] ;
// We manually lower case IDs here for the time being to improve performance.
Misc : : StringUtils : : lowerCaseInPlace ( refId ) ;
+ + mRefCount [ std : : move ( refId ) ] ;
+ + mRefCount [ std : : move ( refId ) ] ;
}
}
} ;
} ;
@ -332,7 +337,8 @@ void ESMStore::countRecords()
int ESMStore : : getRefCount ( const std : : string & id ) const
int ESMStore : : getRefCount ( const std : : string & id ) const
{
{
auto it = mRefCount . find ( id ) ;
const std : : string lowerId = Misc : : StringUtils : : lowerCase ( id ) ;
auto it = mRefCount . find ( lowerId ) ;
if ( it = = mRefCount . end ( ) )
if ( it = = mRefCount . end ( ) )
return 0 ;
return 0 ;
return it - > second ;
return it - > second ;