@ -129,55 +129,55 @@ namespace
static int sRecordTypeCounter = 0 ;
static int sRecordTypeCounter = 0 ;
# define AddStoreType(__Type)template<> const int MWWorld::SRecordType<__Type>::r ecordId = sRecordTypeCounter++;
# define OPENMW_ESM_ADD_STORE_TYPE(__Type)template<> const int MWWorld::SRecordType<__Type>::sR ecordId = sRecordTypeCounter++;
AddStoreType ( ESM : : Activator ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Activator ) ;
AddStoreType ( ESM : : Potion ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Potion ) ;
AddStoreType ( ESM : : Apparatus ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Apparatus ) ;
AddStoreType ( ESM : : Armor ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Armor ) ;
AddStoreType ( ESM : : BodyPart ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : BodyPart ) ;
AddStoreType ( ESM : : Book ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Book ) ;
AddStoreType ( ESM : : BirthSign ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : BirthSign ) ;
AddStoreType ( ESM : : Class ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Class ) ;
AddStoreType ( ESM : : Clothing ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Clothing ) ;
AddStoreType ( ESM : : Container ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Container ) ;
AddStoreType ( ESM : : Creature ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Creature ) ;
AddStoreType ( ESM : : Dialogue ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Dialogue ) ;
AddStoreType ( ESM : : Door ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Door ) ;
AddStoreType ( ESM : : Enchantment ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Enchantment ) ;
AddStoreType ( ESM : : Faction ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Faction ) ;
AddStoreType ( ESM : : Global ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Global ) ;
AddStoreType ( ESM : : Ingredient ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Ingredient ) ;
AddStoreType ( ESM : : CreatureLevList ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : CreatureLevList ) ;
AddStoreType ( ESM : : ItemLevList ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : ItemLevList ) ;
AddStoreType ( ESM : : Light ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Light ) ;
AddStoreType ( ESM : : Lockpick ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Lockpick ) ;
AddStoreType ( ESM : : Miscellaneous ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Miscellaneous ) ;
AddStoreType ( ESM : : NPC ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : NPC ) ;
AddStoreType ( ESM : : Probe ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Probe ) ;
AddStoreType ( ESM : : Race ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Race ) ;
AddStoreType ( ESM : : Region ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Region ) ;
AddStoreType ( ESM : : Repair ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Repair ) ;
AddStoreType ( ESM : : SoundGenerator ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : SoundGenerator ) ;
AddStoreType ( ESM : : Sound ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Sound ) ;
AddStoreType ( ESM : : Spell ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Spell ) ;
AddStoreType ( ESM : : StartScript ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : StartScript ) ;
AddStoreType ( ESM : : Static ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Static ) ;
AddStoreType ( ESM : : Weapon ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Weapon ) ;
AddStoreType ( ESM : : GameSetting ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : GameSetting ) ;
AddStoreType ( ESM : : Script ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Script ) ;
// Lists that need special rules
// Lists that need special rules
AddStoreType ( ESM : : Cell ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Cell ) ;
AddStoreType ( ESM : : Land ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Land ) ;
AddStoreType ( ESM : : LandTexture ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : LandTexture ) ;
AddStoreType ( ESM : : Pathgrid ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Pathgrid ) ;
AddStoreType ( ESM : : MagicEffect ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : MagicEffect ) ;
AddStoreType ( ESM : : Skill ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Skill ) ;
// Special entry which is hardcoded and not loaded from an ESM
// Special entry which is hardcoded and not loaded from an ESM
AddStoreType ( ESM : : Attribute ) ;
OPENMW_ESM_ADD_STORE_TYPE ( ESM : : Attribute ) ;
static const int sRecordTypeCount = sRecordTypeCounter ;
static const int sRecordTypeCount = sRecordTypeCounter ;
@ -196,11 +196,11 @@ namespace MWWorld
template < typename T >
template < typename T >
static const T * ESM 3StoreInsert( ESMStore & stores , const T & toInsert )
static const T * esm 3StoreInsert( ESMStore & stores , const T & toInsert )
{
{
const std : : string id = " $dynamic " + std : : to_string ( stores . mDynamicCount + + ) ;
const std : : string id = " $dynamic " + std : : to_string ( stores . mDynamicCount + + ) ;
Store < T > & store = const_cast < Store < T > & > ( stores . get < T > ( ) ) ;
Store < T > & store = stores . get Writable < T > ( ) ;
if ( store . search ( id ) ! = nullptr )
if ( store . search ( id ) ! = nullptr )
{
{
const std : : string msg = " Try to override existing record ' " + id + " ' " ;
const std : : string msg = " Try to override existing record ' " + id + " ' " ;
@ -211,7 +211,7 @@ namespace MWWorld
record . mId = id ;
record . mId = id ;
T * ptr = store . insert ( record ) ;
T * ptr = store . insert ( record ) ;
auto esm3RecordType_find = stores . mStoreImp - > mESM3RecordToRecordId . find ( GetRecordTypeId( T ) ) ;
auto esm3RecordType_find = stores . mStoreImp - > mESM3RecordToRecordId . find ( SRecordType< T > : : sRecordId ) ;
if ( esm3RecordType_find ! = stores . mStoreImp - > mESM3RecordToRecordId . end ( ) )
if ( esm3RecordType_find ! = stores . mStoreImp - > mESM3RecordToRecordId . end ( ) )
{
{
@ -221,11 +221,11 @@ namespace MWWorld
}
}
template < class T >
template < class T >
static const T * ESM 3overrideRecord( ESMStore & stores , const T & x ) {
static const T * esm 3overrideRecord( ESMStore & stores , const T & x ) {
Store < T > & store = const_cast < Store < T > & > ( stores . get < T > ( ) ) ;
Store < T > & store = stores . get Writable < T > ( ) ;
T * ptr = store . insert ( x ) ;
T * ptr = store . insert ( x ) ;
auto esm3RecordType_find = stores . mStoreImp - > mESM3RecordToRecordId . find ( GetRecordTypeId( T ) ) ;
auto esm3RecordType_find = stores . mStoreImp - > mESM3RecordToRecordId . find ( SRecordType< T > : : sRecordId ) ;
if ( esm3RecordType_find ! = stores . mStoreImp - > mESM3RecordToRecordId . end ( ) )
if ( esm3RecordType_find ! = stores . mStoreImp - > mESM3RecordToRecordId . end ( ) )
{
{
stores . mIds [ ptr - > mId ] = esm3RecordType_find - > first ;
stores . mIds [ ptr - > mId ] = esm3RecordType_find - > first ;
@ -234,11 +234,11 @@ namespace MWWorld
}
}
template < class T >
template < class T >
static const T * ESM 3insertStatic( ESMStore & stores , const T & x )
static const T * esm 3insertStatic( ESMStore & stores , const T & x )
{
{
const std : : string id = " $dynamic " + std : : to_string ( stores . mDynamicCount + + ) ;
const std : : string id = " $dynamic " + std : : to_string ( stores . mDynamicCount + + ) ;
Store < T > & store = const_cast < Store < T > & > ( stores . get < T > ( ) ) ;
Store < T > & store = stores . get Writable < T > ( ) ;
if ( store . search ( id ) ! = nullptr )
if ( store . search ( id ) ! = nullptr )
{
{
const std : : string msg = " Try to override existing record ' " + id + " ' " ;
const std : : string msg = " Try to override existing record ' " + id + " ' " ;
@ -247,7 +247,7 @@ namespace MWWorld
T record = x ;
T record = x ;
T * ptr = store . insertStatic ( record ) ;
T * ptr = store . insertStatic ( record ) ;
auto esm3RecordType_find = stores . mStoreImp - > mESM3RecordToRecordId . find ( GetRecordTypeId( T ) ) ;
auto esm3RecordType_find = stores . mStoreImp - > mESM3RecordToRecordId . find ( SRecordType< T > : : sRecordId ) ;
if ( esm3RecordType_find ! = stores . mStoreImp - > mESM3RecordToRecordId . end ( ) )
if ( esm3RecordType_find ! = stores . mStoreImp - > mESM3RecordToRecordId . end ( ) )
{
{
stores . mIds [ ptr - > mId ] = esm3RecordType_find - > first ;
stores . mIds [ ptr - > mId ] = esm3RecordType_find - > first ;
@ -257,45 +257,51 @@ namespace MWWorld
ESMStoreImp ( )
ESMStoreImp ( )
{
{
mESM3RecordToRecordId [ ESM : : REC_ACTI ] = GetRecordTypeId ( ESM : : Activator ) ;
mESM3RecordToRecordId [ ESM : : REC_ACTI ] = SRecordType < ESM : : Activator > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_ALCH ] = GetRecordTypeId ( ESM : : Potion ) ;
mESM3RecordToRecordId [ ESM : : REC_ALCH ] = SRecordType < ESM : : Potion > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_APPA ] = GetRecordTypeId ( ESM : : Apparatus ) ;
mESM3RecordToRecordId [ ESM : : REC_APPA ] = SRecordType < ESM : : Apparatus > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_ARMO ] = GetRecordTypeId ( ESM : : Armor ) ;
mESM3RecordToRecordId [ ESM : : REC_ARMO ] = SRecordType < ESM : : Armor > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_BODY ] = GetRecordTypeId ( ESM : : BodyPart ) ;
mESM3RecordToRecordId [ ESM : : REC_BODY ] = SRecordType < ESM : : BodyPart > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_BOOK ] = GetRecordTypeId ( ESM : : Book ) ;
mESM3RecordToRecordId [ ESM : : REC_BOOK ] = SRecordType < ESM : : Book > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_BSGN ] = GetRecordTypeId ( ESM : : BirthSign ) ;
mESM3RecordToRecordId [ ESM : : REC_BSGN ] = SRecordType < ESM : : BirthSign > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_CELL ] = GetRecordTypeId ( ESM : : Cell ) ;
mESM3RecordToRecordId [ ESM : : REC_CELL ] = SRecordType < ESM : : Cell > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_CLAS ] = GetRecordTypeId ( ESM : : Class ) ;
mESM3RecordToRecordId [ ESM : : REC_CLAS ] = SRecordType < ESM : : Class > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_CLOT ] = GetRecordTypeId ( ESM : : Clothing ) ;
mESM3RecordToRecordId [ ESM : : REC_CLOT ] = SRecordType < ESM : : Clothing > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_CONT ] = GetRecordTypeId ( ESM : : Container ) ;
mESM3RecordToRecordId [ ESM : : REC_CONT ] = SRecordType < ESM : : Container > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_CREA ] = GetRecordTypeId ( ESM : : Creature ) ;
mESM3RecordToRecordId [ ESM : : REC_CREA ] = SRecordType < ESM : : Creature > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_DIAL ] = GetRecordTypeId ( ESM : : Dialogue ) ;
mESM3RecordToRecordId [ ESM : : REC_DIAL ] = SRecordType < ESM : : Dialogue > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_DOOR ] = GetRecordTypeId ( ESM : : Door ) ;
mESM3RecordToRecordId [ ESM : : REC_DOOR ] = SRecordType < ESM : : Door > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_ENCH ] = GetRecordTypeId ( ESM : : Enchantment ) ;
mESM3RecordToRecordId [ ESM : : REC_ENCH ] = SRecordType < ESM : : Enchantment > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_FACT ] = GetRecordTypeId ( ESM : : Faction ) ;
mESM3RecordToRecordId [ ESM : : REC_FACT ] = SRecordType < ESM : : Faction > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_GLOB ] = GetRecordTypeId ( ESM : : Global ) ;
mESM3RecordToRecordId [ ESM : : REC_GLOB ] = SRecordType < ESM : : Global > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_GMST ] = GetRecordTypeId ( ESM : : GameSetting ) ;
mESM3RecordToRecordId [ ESM : : REC_GMST ] = SRecordType < ESM : : GameSetting > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_INGR ] = GetRecordTypeId ( ESM : : Ingredient ) ;
mESM3RecordToRecordId [ ESM : : REC_INGR ] = SRecordType < ESM : : Ingredient > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_LAND ] = GetRecordTypeId ( ESM : : Land ) ;
mESM3RecordToRecordId [ ESM : : REC_LAND ] = SRecordType < ESM : : Land > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_LEVC ] = GetRecordTypeId ( ESM : : CreatureLevList ) ;
mESM3RecordToRecordId [ ESM : : REC_LEVC ] = SRecordType < ESM : : CreatureLevList > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_LEVI ] = GetRecordTypeId ( ESM : : ItemLevList ) ;
mESM3RecordToRecordId [ ESM : : REC_LEVI ] = SRecordType < ESM : : ItemLevList > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_LIGH ] = GetRecordTypeId ( ESM : : Light ) ;
mESM3RecordToRecordId [ ESM : : REC_LIGH ] = SRecordType < ESM : : Light > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_LOCK ] = GetRecordTypeId ( ESM : : Lockpick ) ;
mESM3RecordToRecordId [ ESM : : REC_LOCK ] = SRecordType < ESM : : Lockpick > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_LTEX ] = GetRecordTypeId ( ESM : : LandTexture ) ;
mESM3RecordToRecordId [ ESM : : REC_LTEX ] = SRecordType < ESM : : LandTexture > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_MISC ] = GetRecordTypeId ( ESM : : Miscellaneous ) ;
mESM3RecordToRecordId [ ESM : : REC_MISC ] = SRecordType < ESM : : Miscellaneous > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_NPC_ ] = GetRecordTypeId ( ESM : : NPC ) ;
mESM3RecordToRecordId [ ESM : : REC_NPC_ ] = SRecordType < ESM : : NPC > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_PGRD ] = GetRecordTypeId ( ESM : : Pathgrid ) ;
mESM3RecordToRecordId [ ESM : : REC_PGRD ] = SRecordType < ESM : : Pathgrid > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_PROB ] = GetRecordTypeId ( ESM : : Probe ) ;
mESM3RecordToRecordId [ ESM : : REC_PROB ] = SRecordType < ESM : : Probe > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_RACE ] = GetRecordTypeId ( ESM : : Race ) ;
mESM3RecordToRecordId [ ESM : : REC_RACE ] = SRecordType < ESM : : Race > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_REGN ] = GetRecordTypeId ( ESM : : Region ) ;
mESM3RecordToRecordId [ ESM : : REC_REGN ] = SRecordType < ESM : : Region > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_REPA ] = GetRecordTypeId ( ESM : : Repair ) ;
mESM3RecordToRecordId [ ESM : : REC_REPA ] = SRecordType < ESM : : Repair > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_SCPT ] = GetRecordTypeId ( ESM : : Script ) ;
mESM3RecordToRecordId [ ESM : : REC_SCPT ] = SRecordType < ESM : : Script > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_SNDG ] = GetRecordTypeId ( ESM : : SoundGenerator ) ;
mESM3RecordToRecordId [ ESM : : REC_SNDG ] = SRecordType < ESM : : SoundGenerator > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_SOUN ] = GetRecordTypeId ( ESM : : Sound ) ;
mESM3RecordToRecordId [ ESM : : REC_SOUN ] = SRecordType < ESM : : Sound > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_SPEL ] = GetRecordTypeId ( ESM : : Spell ) ;
mESM3RecordToRecordId [ ESM : : REC_SPEL ] = SRecordType < ESM : : Spell > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_SSCR ] = GetRecordTypeId ( ESM : : StartScript ) ;
mESM3RecordToRecordId [ ESM : : REC_SSCR ] = SRecordType < ESM : : StartScript > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_STAT ] = GetRecordTypeId ( ESM : : Static ) ;
mESM3RecordToRecordId [ ESM : : REC_STAT ] = SRecordType < ESM : : Static > : : sRecordId ;
mESM3RecordToRecordId [ ESM : : REC_WEAP ] = GetRecordTypeId ( ESM : : Weapon ) ;
mESM3RecordToRecordId [ ESM : : REC_WEAP ] = SRecordType < ESM : : Weapon > : : sRecordId ;
}
template < typename T >
static void createStore ( ESMStore & stores )
{
stores . mStores [ SRecordType < T > : : sRecordId ] = std : : make_unique < Store < T > > ( ) ;
}
}
} ;
} ;
@ -303,48 +309,46 @@ namespace MWWorld
ESMStore : : ESMStore ( )
ESMStore : : ESMStore ( )
{
{
mStores . resize ( sRecordTypeCount ) ;
mStores . resize ( sRecordTypeCount ) ;
# define createStore(__Type) mStores[GetRecordTypeId(__Type)] = std::make_unique<Store<__Type>>();
ESMStoreImp : : createStore < ESM : : Activator > ( * this ) ;
createStore ( ESM : : Activator ) ;
ESMStoreImp : : createStore < ESM : : Potion > ( * this ) ;
createStore ( ESM : : Potion ) ;
ESMStoreImp : : createStore < ESM : : Apparatus > ( * this ) ;
createStore ( ESM : : Apparatus ) ;
ESMStoreImp : : createStore < ESM : : Armor > ( * this ) ;
createStore ( ESM : : Armor ) ;
ESMStoreImp : : createStore < ESM : : BodyPart > ( * this ) ;
createStore ( ESM : : BodyPart ) ;
ESMStoreImp : : createStore < ESM : : Book > ( * this ) ;
createStore ( ESM : : Book ) ;
ESMStoreImp : : createStore < ESM : : BirthSign > ( * this ) ;
createStore ( ESM : : BirthSign ) ;
ESMStoreImp : : createStore < ESM : : Class > ( * this ) ;
createStore ( ESM : : Class ) ;
ESMStoreImp : : createStore < ESM : : Clothing > ( * this ) ;
createStore ( ESM : : Clothing ) ;
ESMStoreImp : : createStore < ESM : : Container > ( * this ) ;
createStore ( ESM : : Container ) ;
ESMStoreImp : : createStore < ESM : : Creature > ( * this ) ;
createStore ( ESM : : Creature ) ;
ESMStoreImp : : createStore < ESM : : Dialogue > ( * this ) ;
createStore ( ESM : : Dialogue ) ;
ESMStoreImp : : createStore < ESM : : Door > ( * this ) ;
createStore ( ESM : : Door ) ;
ESMStoreImp : : createStore < ESM : : Enchantment > ( * this ) ;
createStore ( ESM : : Enchantment ) ;
ESMStoreImp : : createStore < ESM : : Faction > ( * this ) ;
createStore ( ESM : : Faction ) ;
ESMStoreImp : : createStore < ESM : : Global > ( * this ) ;
createStore ( ESM : : Global ) ;
ESMStoreImp : : createStore < ESM : : Ingredient > ( * this ) ;
createStore ( ESM : : Ingredient ) ;
ESMStoreImp : : createStore < ESM : : CreatureLevList > ( * this ) ;
createStore ( ESM : : CreatureLevList ) ;
ESMStoreImp : : createStore < ESM : : ItemLevList > ( * this ) ;
createStore ( ESM : : ItemLevList ) ;
ESMStoreImp : : createStore < ESM : : Light > ( * this ) ;
createStore ( ESM : : Light ) ;
ESMStoreImp : : createStore < ESM : : Lockpick > ( * this ) ;
createStore ( ESM : : Lockpick ) ;
ESMStoreImp : : createStore < ESM : : Miscellaneous > ( * this ) ;
createStore ( ESM : : Miscellaneous ) ;
ESMStoreImp : : createStore < ESM : : NPC > ( * this ) ;
createStore ( ESM : : NPC ) ;
ESMStoreImp : : createStore < ESM : : Probe > ( * this ) ;
createStore ( ESM : : Probe ) ;
ESMStoreImp : : createStore < ESM : : Race > ( * this ) ;
createStore ( ESM : : Race ) ;
ESMStoreImp : : createStore < ESM : : Region > ( * this ) ;
createStore ( ESM : : Region ) ;
ESMStoreImp : : createStore < ESM : : Repair > ( * this ) ;
createStore ( ESM : : Repair ) ;
ESMStoreImp : : createStore < ESM : : SoundGenerator > ( * this ) ;
createStore ( ESM : : SoundGenerator ) ;
ESMStoreImp : : createStore < ESM : : Sound > ( * this ) ;
createStore ( ESM : : Sound ) ;
ESMStoreImp : : createStore < ESM : : Spell > ( * this ) ;
createStore ( ESM : : Spell ) ;
ESMStoreImp : : createStore < ESM : : StartScript > ( * this ) ;
createStore ( ESM : : StartScript ) ;
ESMStoreImp : : createStore < ESM : : Static > ( * this ) ;
createStore ( ESM : : Static ) ;
ESMStoreImp : : createStore < ESM : : Weapon > ( * this ) ;
createStore ( ESM : : Weapon ) ;
ESMStoreImp : : createStore < ESM : : GameSetting > ( * this ) ;
createStore ( ESM : : GameSetting ) ;
ESMStoreImp : : createStore < ESM : : Script > ( * this ) ;
createStore ( ESM : : Script ) ;
ESMStoreImp : : createStore < ESM : : Cell > ( * this ) ;
createStore ( ESM : : Cell ) ;
ESMStoreImp : : createStore < ESM : : Land > ( * this ) ;
createStore ( ESM : : Land ) ;
ESMStoreImp : : createStore < ESM : : LandTexture > ( * this ) ;
createStore ( ESM : : LandTexture ) ;
ESMStoreImp : : createStore < ESM : : Pathgrid > ( * this ) ;
createStore ( ESM : : Pathgrid ) ;
# undef createStore
mStoreImp = std : : make_unique < ESMStoreImp > ( ) ;
mStoreImp = std : : make_unique < ESMStoreImp > ( ) ;
mDynamicCount = 0 ;
mDynamicCount = 0 ;
@ -358,8 +362,8 @@ namespace MWWorld
void ESMStore : : clearDynamic ( )
void ESMStore : : clearDynamic ( )
{
{
for ( std : : vector < std : : unique_ptr < StoreBase > > : : iterator it = mStores . begin ( ) ; it ! = mStores . end ( ) ; + + it )
for ( const auto & store : mStores )
( * it ) - > clearDynamic ( ) ;
store - > clearDynamic ( ) ;
movePlayerRecord ( ) ;
movePlayerRecord ( ) ;
}
}
@ -552,13 +556,13 @@ int ESMStore::getRefCount(std::string_view id) const
void ESMStore : : validate ( )
void ESMStore : : validate ( )
{
{
auto & NPC s = getWritable < ESM : : NPC > ( ) ;
auto & npc s = getWritable < ESM : : NPC > ( ) ;
std : : vector < ESM : : NPC > npcsToReplace = getNPCsToReplace ( getWritable < ESM : : Faction > ( ) , getWritable < ESM : : Class > ( ) , NPC s. mStatic ) ;
std : : vector < ESM : : NPC > npcsToReplace = getNPCsToReplace ( getWritable < ESM : : Faction > ( ) , getWritable < ESM : : Class > ( ) , npc s. mStatic ) ;
for ( const ESM : : NPC & npc : npcsToReplace )
for ( const ESM : : NPC & npc : npcsToReplace )
{
{
NPC s. eraseStatic ( npc . mId ) ;
npc s. eraseStatic ( npc . mId ) ;
NPC s. insertStatic ( npc ) ;
npc s. insertStatic ( npc ) ;
}
}
// Validate spell effects for invalid arguments
// Validate spell effects for invalid arguments
@ -627,20 +631,20 @@ void ESMStore::validate()
void ESMStore : : movePlayerRecord ( )
void ESMStore : : movePlayerRecord ( )
{
{
auto & NPC s = getWritable < ESM : : NPC > ( ) ;
auto & npc s = getWritable < ESM : : NPC > ( ) ;
auto player = NPC s. find ( " player " ) ;
auto player = npc s. find ( " player " ) ;
NPC s. insert ( * player ) ;
npc s. insert ( * player ) ;
}
}
void ESMStore : : validateDynamic ( )
void ESMStore : : validateDynamic ( )
{
{
auto & NPC s = getWritable < ESM : : NPC > ( ) ;
auto & npc s = getWritable < ESM : : NPC > ( ) ;
auto & scripts = getWritable < ESM : : Script > ( ) ;
auto & scripts = getWritable < ESM : : Script > ( ) ;
std : : vector < ESM : : NPC > npcsToReplace = getNPCsToReplace ( getWritable < ESM : : Faction > ( ) , getWritable < ESM : : Class > ( ) , NPC s. mDynamic ) ;
std : : vector < ESM : : NPC > npcsToReplace = getNPCsToReplace ( getWritable < ESM : : Faction > ( ) , getWritable < ESM : : Class > ( ) , npc s. mDynamic ) ;
for ( const ESM : : NPC & npc : npcsToReplace )
for ( const ESM : : NPC & npc : npcsToReplace )
NPC s. insert ( npc ) ;
npc s. insert ( npc ) ;
removeMissingScripts ( scripts , getWritable < ESM : : Armor > ( ) . mDynamic ) ;
removeMissingScripts ( scripts , getWritable < ESM : : Armor > ( ) . mDynamic ) ;
removeMissingScripts ( scripts , getWritable < ESM : : Book > ( ) . mDynamic ) ;
removeMissingScripts ( scripts , getWritable < ESM : : Book > ( ) . mDynamic ) ;
@ -784,12 +788,12 @@ void ESMStore::removeMissingObjects(Store<T>& store)
const ESM : : NPC * ESMStore : : insert < ESM : : NPC > ( const ESM : : NPC & npc )
const ESM : : NPC * ESMStore : : insert < ESM : : NPC > ( const ESM : : NPC & npc )
{
{
const std : : string id = " $dynamic " + std : : to_string ( mDynamicCount + + ) ;
const std : : string id = " $dynamic " + std : : to_string ( mDynamicCount + + ) ;
auto & NPC s = getWritable < ESM : : NPC > ( ) ;
auto & npc s = getWritable < ESM : : NPC > ( ) ;
if ( Misc : : StringUtils : : ciEqual ( npc . mId , " player " ) )
if ( Misc : : StringUtils : : ciEqual ( npc . mId , " player " ) )
{
{
return NPC s. insert ( npc ) ;
return npc s. insert ( npc ) ;
}
}
else if ( NPC s. search ( id ) ! = nullptr )
else if ( npc s. search ( id ) ! = nullptr )
{
{
const std : : string msg = " Try to override existing record ' " + id + " ' " ;
const std : : string msg = " Try to override existing record ' " + id + " ' " ;
throw std : : runtime_error ( msg ) ;
throw std : : runtime_error ( msg ) ;
@ -798,39 +802,39 @@ void ESMStore::removeMissingObjects(Store<T>& store)
record . mId = id ;
record . mId = id ;
ESM : : NPC * ptr = NPC s. insert ( record ) ;
ESM : : NPC * ptr = npc s. insert ( record ) ;
mIds [ ptr - > mId ] = ESM : : REC_NPC_ ;
mIds [ ptr - > mId ] = ESM : : REC_NPC_ ;
return ptr ;
return ptr ;
}
}
# define ESM3Insert (__Type) template<> const __Type* ESMStore::insert<__Type>(const __Type &toInsert) { return ESMStoreImp::ESM 3StoreInsert(*this, toInsert); }
# define OPENMW_ESM3_INSERT (__Type) template<> const __Type* ESMStore::insert<__Type>(const __Type &toInsert) { return ESMStoreImp::esm 3StoreInsert(*this, toInsert); }
ESM3Insert ( ESM : : Book ) ;
OPENMW_ESM3_INSERT ( ESM : : Book ) ;
ESM3Insert ( ESM : : Armor ) ;
OPENMW_ESM3_INSERT ( ESM : : Armor ) ;
ESM3Insert ( ESM : : Class ) ;
OPENMW_ESM3_INSERT ( ESM : : Class ) ;
ESM3Insert ( ESM : : Enchantment ) ;
OPENMW_ESM3_INSERT ( ESM : : Enchantment ) ;
ESM3Insert ( ESM : : Potion ) ;
OPENMW_ESM3_INSERT ( ESM : : Potion ) ;
ESM3Insert ( ESM : : Weapon ) ;
OPENMW_ESM3_INSERT ( ESM : : Weapon ) ;
ESM3Insert ( ESM : : Clothing ) ;
OPENMW_ESM3_INSERT ( ESM : : Clothing ) ;
ESM3Insert ( ESM : : Spell ) ;
OPENMW_ESM3_INSERT ( ESM : : Spell ) ;
# undef ESM3Insert
# undef OPENMW_ESM3_INSERT
# define ESM3InsertStatic (__Type) template<> const __Type* ESMStore::insertStatic<__Type>(const __Type &toInsert) { return ESMStoreImp::ESM 3insertStatic(*this, toInsert); }
# define OPENMW_ESM3_INSERT_STATIC (__Type) template<> const __Type* ESMStore::insertStatic<__Type>(const __Type &toInsert) { return ESMStoreImp::esm 3insertStatic(*this, toInsert); }
ESM3InsertStatic ( ESM : : GameSetting ) ;
OPENMW_ESM3_INSERT_STATIC ( ESM : : GameSetting ) ;
ESM3InsertStatic ( ESM : : Static ) ;
OPENMW_ESM3_INSERT_STATIC ( ESM : : Static ) ;
ESM3InsertStatic ( ESM : : Door ) ;
OPENMW_ESM3_INSERT_STATIC ( ESM : : Door ) ;
ESM3InsertStatic ( ESM : : Global ) ;
OPENMW_ESM3_INSERT_STATIC ( ESM : : Global ) ;
ESM3InsertStatic ( ESM : : NPC ) ;
OPENMW_ESM3_INSERT_STATIC ( ESM : : NPC ) ;
# undef ESM3InsertStatic
# undef OPENMW_ESM3_INSERT_STATIC
# define ESM3overrideRecord (__Type) template<> const __Type* ESMStore::overrideRecord<__Type>(const __Type &toInsert) { return ESMStoreImp::ESM 3overrideRecord(*this, toInsert); }
# define OPENMW_ESM3_OVERRIDE_RECORD (__Type) template<> const __Type* ESMStore::overrideRecord<__Type>(const __Type &toInsert) { return ESMStoreImp::esm 3overrideRecord(*this, toInsert); }
ESM3overrideRecord ( ESM : : Container ) ;
OPENMW_ESM3_OVERRIDE_RECORD ( ESM : : Container ) ;
ESM3overrideRecord ( ESM : : Creature ) ;
OPENMW_ESM3_OVERRIDE_RECORD ( ESM : : Creature ) ;
ESM3overrideRecord ( ESM : : CreatureLevList ) ;
OPENMW_ESM3_OVERRIDE_RECORD ( ESM : : CreatureLevList ) ;
ESM3overrideRecord ( ESM : : Door ) ;
OPENMW_ESM3_OVERRIDE_RECORD ( ESM : : Door ) ;
ESM3overrideRecord ( ESM : : ItemLevList ) ;
OPENMW_ESM3_OVERRIDE_RECORD ( ESM : : ItemLevList ) ;
ESM3overrideRecord ( ESM : : NPC ) ;
OPENMW_ESM3_OVERRIDE_RECORD ( ESM : : NPC ) ;
# undef ESM3overrideRecord
# undef OPENMW_ESM3_OVERRIDE_RECORD
template < > const Store < ESM : : MagicEffect > & ESMStore : : get < ESM : : MagicEffect > ( ) const { return mStoreImp - > mMagicEffect ; }
template < > const Store < ESM : : MagicEffect > & ESMStore : : get < ESM : : MagicEffect > ( ) const { return mStoreImp - > mMagicEffect ; }
template < > Store < ESM : : MagicEffect > & ESMStore : : getWritable < ESM : : MagicEffect > ( ) { return mStoreImp - > mMagicEffect ; }
template < > Store < ESM : : MagicEffect > & ESMStore : : getWritable < ESM : : MagicEffect > ( ) { return mStoreImp - > mMagicEffect ; }