@ -1,7 +1,9 @@
# include "referenceablecheck.hpp"
# include "referenceablecheck.hpp"
# include <components/misc/stringops.hpp>
# include "../world/record.hpp"
# include "../world/record.hpp"
# include "../world/universalid.hpp"
# include "../world/universalid.hpp"
# include <components/misc/stringops.hpp>
CSMTools : : ReferenceableCheckStage : : ReferenceableCheckStage (
CSMTools : : ReferenceableCheckStage : : ReferenceableCheckStage (
const CSMWorld : : RefIdData & referenceable , const CSMWorld : : IdCollection < ESM : : Race > & races ,
const CSMWorld : : RefIdData & referenceable , const CSMWorld : : IdCollection < ESM : : Race > & races ,
@ -16,7 +18,7 @@ CSMTools::ReferenceableCheckStage::ReferenceableCheckStage(
{
{
}
}
void CSMTools : : ReferenceableCheckStage : : perform ( int stage , std : : vector < std : : string > & messages )
void CSMTools : : ReferenceableCheckStage : : perform ( int stage , Messages & messages )
{
{
//Checks for books, than, when stage is above mBooksSize goes to other checks, with (stage - PrevSum) as stage.
//Checks for books, than, when stage is above mBooksSize goes to other checks, with (stage - PrevSum) as stage.
const int bookSize ( mReferencables . getBooks ( ) . getSize ( ) ) ;
const int bookSize ( mReferencables . getBooks ( ) . getSize ( ) ) ;
@ -230,7 +232,7 @@ int CSMTools::ReferenceableCheckStage::setup()
void CSMTools : : ReferenceableCheckStage : : bookCheck (
void CSMTools : : ReferenceableCheckStage : : bookCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Book > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Book > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -248,7 +250,7 @@ void CSMTools::ReferenceableCheckStage::bookCheck(
void CSMTools : : ReferenceableCheckStage : : activatorCheck (
void CSMTools : : ReferenceableCheckStage : : activatorCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Activator > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Activator > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -262,15 +264,13 @@ void CSMTools::ReferenceableCheckStage::activatorCheck(
//Checking for model, IIRC all activators should have a model
//Checking for model, IIRC all activators should have a model
if ( activator . mModel . empty ( ) )
if ( activator . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , activator . mId + " has no model " ) ) ;
messages . push_back ( id . toString ( ) + " | " + activator . mId + " has no model " ) ;
}
}
}
void CSMTools : : ReferenceableCheckStage : : potionCheck (
void CSMTools : : ReferenceableCheckStage : : potionCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Potion > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Potion > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -290,7 +290,7 @@ void CSMTools::ReferenceableCheckStage::potionCheck(
void CSMTools : : ReferenceableCheckStage : : apparatusCheck (
void CSMTools : : ReferenceableCheckStage : : apparatusCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Apparatus > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Apparatus > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -310,7 +310,7 @@ void CSMTools::ReferenceableCheckStage::apparatusCheck(
void CSMTools : : ReferenceableCheckStage : : armorCheck (
void CSMTools : : ReferenceableCheckStage : : armorCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Armor > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Armor > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -326,21 +326,17 @@ void CSMTools::ReferenceableCheckStage::armorCheck(
//checking for armor class, armor should have poistive armor class, but 0 is considered legal
//checking for armor class, armor should have poistive armor class, but 0 is considered legal
if ( armor . mData . mArmor < 0 )
if ( armor . mData . mArmor < 0 )
{
messages . push_back ( std : : make_pair ( id , armor . mId + " has negative armor class " ) ) ;
messages . push_back ( id . toString ( ) + " | " + armor . mId + " has negative armor class " ) ;
}
//checking for health. Only positive numbers are allowed, or 0 is illegal
//checking for health. Only positive numbers are allowed, or 0 is illegal
if ( armor . mData . mHealth < = 0 )
if ( armor . mData . mHealth < = 0 )
{
messages . push_back ( std : : make_pair ( id , armor . mId + " has non positive health " ) ) ;
messages . push_back ( id . toString ( ) + " | " + armor . mId + " has non positive health " ) ;
}
}
}
void CSMTools : : ReferenceableCheckStage : : clothingCheck (
void CSMTools : : ReferenceableCheckStage : : clothingCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Clothing > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Clothing > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -357,7 +353,7 @@ void CSMTools::ReferenceableCheckStage::clothingCheck(
void CSMTools : : ReferenceableCheckStage : : containerCheck (
void CSMTools : : ReferenceableCheckStage : : containerCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Container > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Container > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -371,153 +367,109 @@ void CSMTools::ReferenceableCheckStage::containerCheck(
//Checking for model, IIRC all containers should have a model
//Checking for model, IIRC all containers should have a model
if ( container . mModel . empty ( ) )
if ( container . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , container . mId + " has no model " ) ) ;
messages . push_back ( id . toString ( ) + " | " + container . mId + " has no model " ) ;
}
//Checking for capacity (weight)
//Checking for capacity (weight)
if ( container . mWeight < 0 ) //0 is allowed
if ( container . mWeight < 0 ) //0 is allowed
{
messages . push_back ( std : : make_pair ( id ,
messages . push_back ( id . toString ( ) + " | " + container . mId + " has negative weight (capacity) " ) ;
container . mId + " has negative weight (capacity) " ) ) ;
}
//checking for name
//checking for name
if ( container . mName . empty ( ) )
if ( container . mName . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , container . mId + " has an empty name " ) ) ;
messages . push_back ( id . toString ( ) + " | " + container . mId + " has an empty name " ) ;
}
}
}
void CSMTools : : ReferenceableCheckStage : : creatureCheck (
void CSMTools : : ReferenceableCheckStage : : creatureCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : Creature > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Creature > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : Creature & creature = ( dynamic_cast < const CSMWorld : : Record < ESM : : Creature > & > ( baseRecord ) ) . get ( ) ;
const ESM : : Creature & creature = ( dynamic_cast < const CSMWorld : : Record < ESM : : Creature > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Creature , creature . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Creature , creature . mId ) ;
if ( creature . mModel . empty ( ) )
if ( creature . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has no model " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has no model " ) ;
}
if ( creature . mName . empty ( ) )
if ( creature . mName . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has an empty name " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has an empty name " ) ;
}
//stats checks
//stats checks
if ( creature . mData . mLevel < 1 )
if ( creature . mData . mLevel < 1 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has non-postive level " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has non-postive level " ) ;
}
if ( creature . mData . mStrength < 0 )
if ( creature . mData . mStrength < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative strength " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative strength " ) ;
}
if ( creature . mData . mIntelligence < 0 )
if ( creature . mData . mIntelligence < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative intelligence " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative intelligence " ) ;
}
if ( creature . mData . mWillpower < 0 )
if ( creature . mData . mWillpower < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative willpower " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative willpower " ) ;
}
if ( creature . mData . mAgility < 0 )
if ( creature . mData . mAgility < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative agility " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative agility " ) ;
}
if ( creature . mData . mSpeed < 0 )
if ( creature . mData . mSpeed < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative speed " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative speed " ) ;
}
if ( creature . mData . mEndurance < 0 )
if ( creature . mData . mEndurance < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative endurance " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative endurance " ) ;
}
if ( creature . mData . mPersonality < 0 )
if ( creature . mData . mPersonality < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative personality " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative personality " ) ;
}
if ( creature . mData . mLuck < 0 )
if ( creature . mData . mLuck < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative luck " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative luck " ) ;
}
if ( creature . mData . mHealth < 0 )
if ( creature . mData . mHealth < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative health " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative health " ) ;
}
if ( creature . mData . mSoul < 0 )
if ( creature . mData . mSoul < 0 )
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative soul value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative soul value " ) ;
}
for ( int i = 0 ; i < 6 ; + + i )
for ( int i = 0 ; i < 6 ; + + i )
{
{
if ( creature . mData . mAttack [ i ] < 0 )
if ( creature . mData . mAttack [ i ] < 0 )
{
{
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative attack strength " ) ;
messages . push_back ( std : : make_pair ( id ,
creature . mId + " has negative attack strength " ) ) ;
break ;
break ;
}
}
}
}
//TODO, find meaning of other values
//TODO, find meaning of other values
if ( creature . mData . mGold < 0 ) //It seems that this is for gold in merchant creatures
if ( creature . mData . mGold < 0 ) //It seems that this is for gold in merchant creatures
{
messages . push_back ( std : : make_pair ( id , creature . mId + " has negative gold " ) ) ;
messages . push_back ( id . toString ( ) + " | " + creature . mId + " has negative gold " ) ;
}
}
}
void CSMTools : : ReferenceableCheckStage : : doorCheck (
void CSMTools : : ReferenceableCheckStage : : doorCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : Door > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Door > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : Door & Door = ( dynamic_cast < const CSMWorld : : Record < ESM : : Door > & > ( baseRecord ) ) . get ( ) ;
const ESM : : Door & Door = ( dynamic_cast < const CSMWorld : : Record < ESM : : Door > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Door , Door . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Door , Door . mId ) ;
//usual, name or model
//usual, name or model
if ( Door . mName . empty ( ) )
if ( Door . mName . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , Door . mId + " has an empty name " ) ) ;
messages . push_back ( id . toString ( ) + " | " + Door . mId + " has an empty name " ) ;
}
if ( Door . mModel . empty ( ) )
if ( Door . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , Door . mId + " has no model " ) ) ;
messages . push_back ( id . toString ( ) + " | " + Door . mId + " has no model " ) ;
}
//TODO, check what static unsigned int sRecordId; is for
}
}
void CSMTools : : ReferenceableCheckStage : : ingredientCheck (
void CSMTools : : ReferenceableCheckStage : : ingredientCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Ingredient > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Ingredient > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -535,7 +487,7 @@ void CSMTools::ReferenceableCheckStage::ingredientCheck(
void CSMTools : : ReferenceableCheckStage : : creaturesLevListCheck (
void CSMTools : : ReferenceableCheckStage : : creaturesLevListCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : CreatureLevList > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : CreatureLevList > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -553,7 +505,7 @@ void CSMTools::ReferenceableCheckStage::creaturesLevListCheck(
void CSMTools : : ReferenceableCheckStage : : itemLevelledListCheck (
void CSMTools : : ReferenceableCheckStage : : itemLevelledListCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : ItemLevList > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : ItemLevList > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -569,40 +521,33 @@ void CSMTools::ReferenceableCheckStage::itemLevelledListCheck(
}
}
void CSMTools : : ReferenceableCheckStage : : lightCheck (
void CSMTools : : ReferenceableCheckStage : : lightCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : Light > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Light > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : Light & light = ( dynamic_cast < const CSMWorld : : Record < ESM : : Light > & > ( baseRecord ) ) . get ( ) ;
const ESM : : Light & light = ( dynamic_cast < const CSMWorld : : Record < ESM : : Light > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Light , light . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Light , light . mId ) ;
if ( light . mData . mRadius < 0 )
if ( light . mData . mRadius < 0 )
{
messages . push_back ( std : : make_pair ( id , light . mId + " has negative light radius " ) ) ;
messages . push_back ( id . toString ( ) + " | " + light . mId + " has negative light radius " ) ;
}
if ( light . mData . mFlags & ESM : : Light : : Carry )
if ( light . mData . mFlags & ESM : : Light : : Carry )
{
{
inventoryItemCheck < ESM : : Light > ( light , messages , id . toString ( ) ) ;
inventoryItemCheck < ESM : : Light > ( light , messages , id . toString ( ) ) ;
if ( light . mData . mTime = = 0 )
if ( light . mData . mTime = = 0 )
{
messages . push_back ( std : : make_pair ( id , light . mId + " has zero duration " ) ) ;
messages . push_back ( id . toString ( ) + " | " + light . mId + " has zero duration " ) ;
}
}
}
}
}
void CSMTools : : ReferenceableCheckStage : : lockpickCheck (
void CSMTools : : ReferenceableCheckStage : : lockpickCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Lockpick > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Lockpick > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -622,7 +567,7 @@ void CSMTools::ReferenceableCheckStage::lockpickCheck(
void CSMTools : : ReferenceableCheckStage : : miscCheck (
void CSMTools : : ReferenceableCheckStage : : miscCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Miscellaneous > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Miscellaneous > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -637,20 +582,17 @@ void CSMTools::ReferenceableCheckStage::miscCheck(
inventoryItemCheck < ESM : : Miscellaneous > ( miscellaneous , messages , id . toString ( ) ) ;
inventoryItemCheck < ESM : : Miscellaneous > ( miscellaneous , messages , id . toString ( ) ) ;
}
}
void CSMTools : : ReferenceableCheckStage : : npcCheck (
void CSMTools : : ReferenceableCheckStage : : npcCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : NPC > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : NPC > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : NPC & npc = ( dynamic_cast < const CSMWorld : : Record < ESM : : NPC > & > ( baseRecord ) ) . get ( ) ;
const ESM : : NPC & npc = ( dynamic_cast < const CSMWorld : : Record < ESM : : NPC > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Npc , npc . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Npc , npc . mId ) ;
short level ( npc . mNpdt52 . mLevel ) ;
short level ( npc . mNpdt52 . mLevel ) ;
char disposition ( npc . mNpdt52 . mDisposition ) ;
char disposition ( npc . mNpdt52 . mDisposition ) ;
@ -661,15 +603,13 @@ void CSMTools::ReferenceableCheckStage::npcCheck(
//Detect if player is present
//Detect if player is present
if ( Misc : : StringUtils : : ciEqual ( npc . mId , " player " ) ) //Happy now, scrawl?
if ( Misc : : StringUtils : : ciEqual ( npc . mId , " player " ) ) //Happy now, scrawl?
{
mPlayerPresent = true ;
mPlayerPresent = true ;
}
if ( npc . mNpdtType = = ESM : : NPC : : NPC_WITH_AUTOCALCULATED_STATS ) //12 = autocalculated
if ( npc . mNpdtType = = ESM : : NPC : : NPC_WITH_AUTOCALCULATED_STATS ) //12 = autocalculated
{
{
if ( ( npc . mFlags & ESM : : NPC : : Autocalc ) = = 0 ) //0x0008 = autocalculated flag
if ( ( npc . mFlags & ESM : : NPC : : Autocalc ) = = 0 ) //0x0008 = autocalculated flag
{
{
messages . push_back ( id . toString ( ) + " | " + npc . mId + " mNpdtType or flags mismatch! " ) ; //should not happend?
messages . push_back ( std : : make_pair ( id , npc . mId + " mNpdtType or flags mismatch! " ) ) ; //should not happend?
return ;
return ;
}
}
@ -682,145 +622,100 @@ void CSMTools::ReferenceableCheckStage::npcCheck(
else
else
{
{
if ( npc . mNpdt52 . mMana < 0 )
if ( npc . mNpdt52 . mMana < 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " mana has negative value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " mana has negative value " ) ;
}
if ( npc . mNpdt52 . mFatigue < 0 )
if ( npc . mNpdt52 . mFatigue < 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " fatigue has negative value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " fatigue has negative value " ) ;
}
if ( npc . mNpdt52 . mAgility = = 0 )
if ( npc . mNpdt52 . mAgility = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " agility has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " agility has zero value " ) ;
}
if ( npc . mNpdt52 . mEndurance = = 0 )
if ( npc . mNpdt52 . mEndurance = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " endurance has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " endurance has zero value " ) ;
}
if ( npc . mNpdt52 . mIntelligence = = 0 )
if ( npc . mNpdt52 . mIntelligence = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " intelligence has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " intelligence has zero value " ) ;
}
if ( npc . mNpdt52 . mLuck = = 0 )
if ( npc . mNpdt52 . mLuck = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " luck has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " luck has zero value " ) ;
}
if ( npc . mNpdt52 . mPersonality = = 0 )
if ( npc . mNpdt52 . mPersonality = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " personality has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " personality has zero value " ) ;
}
if ( npc . mNpdt52 . mStrength = = 0 )
if ( npc . mNpdt52 . mStrength = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " strength has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " strength has zero value " ) ;
}
if ( npc . mNpdt52 . mSpeed = = 0 )
if ( npc . mNpdt52 . mSpeed = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " speed has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " speed has zero value " ) ;
}
if ( npc . mNpdt52 . mWillpower = = 0 )
if ( npc . mNpdt52 . mWillpower = = 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " willpower has zero value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " willpower has zero value " ) ;
}
}
}
if ( level < 1 )
if ( level < 1 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " level is non positive " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " level is non positive " ) ;
}
if ( gold < 0 )
if ( gold < 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " gold has negative value " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " gold has negative value " ) ;
}
if ( npc . mName . empty ( ) )
if ( npc . mName . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " has any empty name " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has any empty name " ) ;
}
if ( npc . mClass . empty ( ) )
if ( npc . mClass . empty ( ) )
{
{
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has any empty class " ) ;
messages . push_back ( std : : make_pair ( id , npc . mId + " has any empty class " ) ) ;
}
}
else //checking if there is such class
else if ( mClasses . searchId ( npc . mClass ) = = - 1 )
{
{
if ( mClasses . searchId ( npc . mClass ) = = - 1 )
messages . push_back ( std : : make_pair ( id , npc . mId + " has invalid class " ) ) ;
{
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has invalid class " ) ;
}
}
}
if ( npc . mRace . empty ( ) )
if ( npc . mRace . empty ( ) )
{
{
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has any empty race " ) ;
messages . push_back ( std : : make_pair ( id , npc . mId + " has any empty race " ) ) ;
}
}
else //checking if there is a such race
else if ( mRaces . searchId ( npc . mRace ) = = - 1 )
{
{
if ( mRaces . searchId ( npc . mRace ) = = - 1 )
messages . push_back ( std : : make_pair ( id , npc . mId + " has invalid race " ) ) ;
{
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has invalid race " ) ;
}
}
}
if ( disposition < 0 )
if ( disposition < 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " has negative disposition " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has negative disposition " ) ;
}
if ( reputation < 0 ) //It seems that no character in Morrowind.esm have negative reputation. I'm assuming that negative reputation is invalid
if ( reputation < 0 ) //It seems that no character in Morrowind.esm have negative reputation. I'm assuming that negative reputation is invalid
{
{
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has negative reputation " ) ;
messages . push_back ( std : : make_pair ( id , npc . mId + " has negative reputation " ) ) ;
}
}
if ( npc . mFaction . empty ( ) = = false )
if ( ! npc . mFaction . empty ( ) )
{
{
if ( rank < 0 )
if ( rank < 0 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " has negative rank " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has negative rank " ) ;
}
if ( mFactions . searchId ( npc . mFaction ) = = - 1 )
if ( mFactions . searchId ( npc . mFaction ) = = - 1 )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " has invalid faction " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has invalid faction " ) ;
}
}
}
if ( npc . mHead . empty ( ) )
if ( npc . mHead . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " has no head " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has no head " ) ;
}
if ( npc . mHair . empty ( ) )
if ( npc . mHair . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , npc . mId + " has no hair " ) ) ;
messages . push_back ( id . toString ( ) + " | " + npc . mId + " has no hair " ) ;
}
//TODO: reputation, Disposition, rank, everything else
//TODO: reputation, Disposition, rank, everything else
}
}
void CSMTools : : ReferenceableCheckStage : : weaponCheck (
void CSMTools : : ReferenceableCheckStage : : weaponCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : Weapon > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Weapon > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : Weapon & weapon = ( dynamic_cast < const CSMWorld : : Record < ESM : : Weapon > & > ( baseRecord ) ) . get ( ) ;
const ESM : : Weapon & weapon = ( dynamic_cast < const CSMWorld : : Record < ESM : : Weapon > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Weapon , weapon . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Weapon , weapon . mId ) ;
//TODO, It seems that this stuff for spellcasting is obligatory and In fact We should check if records are present
//TODO, It seems that this stuff for spellcasting is obligatory and In fact We should check if records are present
if
if
@ -860,20 +755,17 @@ void CSMTools::ReferenceableCheckStage::weaponCheck(
weapon . mData . mType = = ESM : : Weapon : : Bolt ) )
weapon . mData . mType = = ESM : : Weapon : : Bolt ) )
{
{
if ( weapon . mData . mSlash [ 0 ] > weapon . mData . mSlash [ 1 ] )
if ( weapon . mData . mSlash [ 0 ] > weapon . mData . mSlash [ 1 ] )
{
messages . push_back ( std : : make_pair ( id ,
messages . push_back ( id . toString ( ) + " | " + weapon . mId + " has minimum slash damage higher than maximum " ) ;
weapon . mId + " has minimum slash damage higher than maximum " ) ) ;
}
if ( weapon . mData . mThrust [ 0 ] > weapon . mData . mThrust [ 1 ] )
if ( weapon . mData . mThrust [ 0 ] > weapon . mData . mThrust [ 1 ] )
{
messages . push_back ( std : : make_pair ( id ,
messages . push_back ( id . toString ( ) + " | " + weapon . mId + " has minimum thrust damage higher than maximum " ) ;
weapon . mId + " has minimum thrust damage higher than maximum " ) ) ;
}
}
}
if ( weapon . mData . mChop [ 0 ] > weapon . mData . mChop [ 1 ] )
if ( weapon . mData . mChop [ 0 ] > weapon . mData . mChop [ 1 ] )
{
messages . push_back ( std : : make_pair ( id ,
messages . push_back ( id . toString ( ) + " | " + weapon . mId + " has minimum chop damage higher than maximum " ) ;
weapon . mId + " has minimum chop damage higher than maximum " ) ) ;
}
if ( ! ( weapon . mData . mType = = ESM : : Weapon : : Arrow | |
if ( ! ( weapon . mData . mType = = ESM : : Weapon : : Arrow | |
weapon . mData . mType = = ESM : : Weapon : : Bolt | |
weapon . mData . mType = = ESM : : Weapon : : Bolt | |
@ -881,14 +773,10 @@ void CSMTools::ReferenceableCheckStage::weaponCheck(
{
{
//checking of health
//checking of health
if ( weapon . mData . mHealth < = 0 )
if ( weapon . mData . mHealth < = 0 )
{
messages . push_back ( std : : make_pair ( id , weapon . mId + " has non-positivie health " ) ) ;
messages . push_back ( id . toString ( ) + " | " + weapon . mId + " has non-positivie health " ) ;
}
if ( weapon . mData . mReach < 0 )
if ( weapon . mData . mReach < 0 )
{
messages . push_back ( std : : make_pair ( id , weapon . mId + " has negative reach " ) ) ;
messages . push_back ( id . toString ( ) + " | " + weapon . mId + " has negative reach " ) ;
}
}
}
}
}
}
}
@ -896,7 +784,7 @@ void CSMTools::ReferenceableCheckStage::weaponCheck(
void CSMTools : : ReferenceableCheckStage : : probeCheck (
void CSMTools : : ReferenceableCheckStage : : probeCheck (
int stage ,
int stage ,
const CSMWorld : : RefIdDataContainer < ESM : : Probe > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Probe > & records ,
std: : vector < std : : string > & messages )
Messages & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
@ -912,184 +800,128 @@ void CSMTools::ReferenceableCheckStage::probeCheck(
toolCheck < ESM : : Probe > ( probe , messages , id . toString ( ) , true ) ;
toolCheck < ESM : : Probe > ( probe , messages , id . toString ( ) , true ) ;
}
}
void CSMTools : : ReferenceableCheckStage : : repairCheck (
void CSMTools : : ReferenceableCheckStage : : repairCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : Repair > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Repair > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : Repair & repair = ( dynamic_cast < const CSMWorld : : Record < ESM : : Repair > & > ( baseRecord ) ) . get ( ) ;
const ESM : : Repair & repair = ( dynamic_cast < const CSMWorld : : Record < ESM : : Repair > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Repair , repair . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Repair , repair . mId ) ;
inventoryItemCheck < ESM : : Repair > ( repair , messages , id . toString ( ) ) ;
inventoryItemCheck < ESM : : Repair > ( repair , messages , id . toString ( ) ) ;
toolCheck < ESM : : Repair > ( repair , messages , id . toString ( ) , true ) ;
toolCheck < ESM : : Repair > ( repair , messages , id . toString ( ) , true ) ;
}
}
void CSMTools : : ReferenceableCheckStage : : staticCheck (
void CSMTools : : ReferenceableCheckStage : : staticCheck (
int stage ,
int stage , const CSMWorld : : RefIdDataContainer < ESM : : Static > & records ,
const CSMWorld : : RefIdDataContainer < ESM : : Static > & records ,
Messages & messages )
std : : vector < std : : string > & messages )
{
{
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
const CSMWorld : : RecordBase & baseRecord = records . getRecord ( stage ) ;
if ( baseRecord . isDeleted ( ) )
if ( baseRecord . isDeleted ( ) )
{
return ;
return ;
}
const ESM : : Static & staticElement = ( dynamic_cast < const CSMWorld : : Record < ESM : : Static > & > ( baseRecord ) ) . get ( ) ;
const ESM : : Static & staticElement = ( dynamic_cast < const CSMWorld : : Record < ESM : : Static > & > ( baseRecord ) ) . get ( ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Static , staticElement . mId ) ;
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Static , staticElement . mId ) ;
if ( staticElement . mModel . empty ( ) )
if ( staticElement . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( id , staticElement . mId + " has no model " ) ) ;
messages . push_back ( id . toString ( ) + " | " + staticElement . mId + " has no model " ) ;
}
}
}
//final check
//final check
void CSMTools : : ReferenceableCheckStage : : finalCheck ( std : : vector < std : : string > & messages )
void CSMTools : : ReferenceableCheckStage : : finalCheck ( Messages & messages )
{
{
if ( ! mPlayerPresent )
if ( ! mPlayerPresent )
{
messages . push_back ( std : : make_pair ( CSMWorld : : UniversalId : : Type_Referenceables ,
CSMWorld : : UniversalId id ( CSMWorld : : UniversalId : : Type_Npc ) ;
" There is no player record " ) ) ;
messages . push_back ( id . toString ( ) + " | There is no player record " ) ;
}
}
}
//Templates begins here
//Templates begins here
template < typename ITEM > void CSMTools : : ReferenceableCheckStage : : inventoryItemCheck (
template < typename Item > void CSMTools : : ReferenceableCheckStage : : inventoryItemCheck (
const ITEM & someItem ,
const Item & someItem , Messages & messages , const std : : string & someID , bool enchantable )
std : : vector < std : : string > & messages ,
const std : : string & someID , bool enchantable )
{
{
if ( someItem . mName . empty ( ) )
if ( someItem . mName . empty ( ) )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has an empty name " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has an empty name " ) ;
}
//Checking for weight
//Checking for weight
if ( someItem . mData . mWeight < 0 )
if ( someItem . mData . mWeight < 0 )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has negative weight " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has negative weight " ) ;
}
//Checking for value
//Checking for value
if ( someItem . mData . mValue < 0 )
if ( someItem . mData . mValue < 0 )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has negative value " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has negative value " ) ;
}
//checking for model
//checking for model
if ( someItem . mModel . empty ( ) )
if ( someItem . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has no model " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has no model " ) ;
}
//checking for icon
//checking for icon
if ( someItem . mIcon . empty ( ) )
if ( someItem . mIcon . empty ( ) )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has no icon " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has no icon " ) ;
}
if ( enchantable )
if ( enchantable & & someItem . mData . mEnchant < 0 )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has negative enchantment " ) ) ;
if ( someItem . mData . mEnchant < 0 )
{
messages . push_back ( someID + " | " + someItem . mId + " has negative enchantment " ) ;
}
}
}
}
template < typename ITEM > void CSMTools : : ReferenceableCheckStage : : inventoryItemCheck (
template < typename Item > void CSMTools : : ReferenceableCheckStage : : inventoryItemCheck (
const ITEM & someItem ,
const Item & someItem , Messages & messages , const std : : string & someID )
std : : vector < std : : string > & messages ,
const std : : string & someID )
{
{
if ( someItem . mName . empty ( ) )
if ( someItem . mName . empty ( ) )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has an empty name " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has an empty name " ) ;
}
//Checking for weight
//Checking for weight
if ( someItem . mData . mWeight < 0 )
if ( someItem . mData . mWeight < 0 )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has negative weight " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has negative weight " ) ;
}
//Checking for value
//Checking for value
if ( someItem . mData . mValue < 0 )
if ( someItem . mData . mValue < 0 )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has negative value " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has negative value " ) ;
}
//checking for model
//checking for model
if ( someItem . mModel . empty ( ) )
if ( someItem . mModel . empty ( ) )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has no model " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has no model " ) ;
}
//checking for icon
//checking for icon
if ( someItem . mIcon . empty ( ) )
if ( someItem . mIcon . empty ( ) )
{
messages . push_back ( std : : make_pair ( someID , someItem . mId + " has no icon " ) ) ;
messages . push_back ( someID + " | " + someItem . mId + " has no icon " ) ;
}
}
}
template < typename TOOL > void CSMTools : : ReferenceableCheckStage : : toolCheck (
template < typename Tool > void CSMTools : : ReferenceableCheckStage : : toolCheck (
const TOOL & someTool ,
const Tool & someTool , Messages & messages , const std : : string & someID , bool canBeBroken )
std : : vector < std : : string > & messages ,
const std : : string & someID , bool canBeBroken )
{
{
if ( someTool . mData . mQuality < = 0 )
if ( someTool . mData . mQuality < = 0 )
{
messages . push_back ( std : : make_pair ( someID , someTool . mId + " has non-positive quality " ) ) ;
messages . push_back ( someID + " | " + someTool . mId + " has non-positive quality " ) ;
}
if ( canBeBroken )
if ( canBeBroken & & someTool . mData . mUses < = 0 )
{
messages . push_back ( std : : make_pair ( someID ,
if ( someTool . mData . mUses < = 0 )
someTool . mId + " has non-positive uses count " ) ) ;
{
messages . push_back ( someID + " | " + someTool . mId + " has non-positive uses count " ) ;
}
}
}
}
template < typename TOOL > void CSMTools : : ReferenceableCheckStage : : toolCheck (
template < typename Tool > void CSMTools : : ReferenceableCheckStage : : toolCheck (
const TOOL & someTool ,
const Tool & someTool , Messages & messages , const std : : string & someID )
std : : vector < std : : string > & messages ,
const std : : string & someID )
{
{
if ( someTool . mData . mQuality < = 0 )
if ( someTool . mData . mQuality < = 0 )
{
messages . push_back ( std : : make_pair ( someID , someTool . mId + " has non-positive quality " ) ) ;
messages . push_back ( someID + " | " + someTool . mId + " has non-positive quality " ) ;
}
}
}
template < typename LIST > void CSMTools : : ReferenceableCheckStage : : listCheck (
template < typename List > void CSMTools : : ReferenceableCheckStage : : listCheck (
const LIST & someList ,
const List & someList , Messages & messages , const std : : string & someID )
std : : vector < std : : string > & messages ,
const std : : string & someID )
{
{
for ( unsigned i = 0 ; i < someList . mList . size ( ) ; + + i )
for ( unsigned i = 0 ; i < someList . mList . size ( ) ; + + i )
{
{
if ( mReferencables . searchId ( someList . mList [ i ] . mId ) . first = = - 1 )
if ( mReferencables . searchId ( someList . mList [ i ] . mId ) . first = = - 1 )
{
messages . push_back ( std : : make_pair ( someID ,
messages . push_back ( someID + " | " + someList . mId + " contains item without referencable " ) ;
someList . mId + " contains item without referencable " ) ) ;
}
if ( someList . mList [ i ] . mLevel < 1 )
if ( someList . mList [ i ] . mLevel < 1 )
{
messages . push_back ( std : : make_pair ( someID ,
messages . push_back ( someID + " | " + someList . mId + " contains item with non-positive level " ) ;
someList . mId + " contains item with non-positive level " ) ) ;
}
}
}
}
}
// kate: indent-mode cstyle; indent-width 4; replace-tabs on;