|
|
@ -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());
|
|
|
@ -206,11 +208,11 @@ void CSMTools::ReferenceableCheckStage::perform(int stage, std::vector< std::str
|
|
|
|
staticCheck(stage, mReferencables.getStatics(), messages);
|
|
|
|
staticCheck(stage, mReferencables.getStatics(), messages);
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
stage -= staticSize;
|
|
|
|
stage -= staticSize;
|
|
|
|
|
|
|
|
|
|
|
|
const int creatureSize(mReferencables.getCreatures().getSize());
|
|
|
|
const int creatureSize(mReferencables.getCreatures().getSize());
|
|
|
|
|
|
|
|
|
|
|
|
if (stage < creatureSize)
|
|
|
|
if (stage < creatureSize)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
creatureCheck(stage, mReferencables.getCreatures(), messages);
|
|
|
|
creatureCheck(stage, mReferencables.getCreatures(), messages);
|
|
|
@ -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;
|
|
|
|
|
|
|
|