Added armor check and related stuff.

This commit is contained in:
Marek Kochanowicz 2013-12-22 14:32:42 +01:00
parent 97fc8acbdb
commit bbcaef8e42
4 changed files with 75 additions and 8 deletions

View file

@ -14,7 +14,8 @@ CSMTools::ReferenceableCheckStage::ReferenceableCheckStage(const CSMWorld::RefId
mActivatorsSize(0), mActivatorsSize(0),
mPotionsSize(0), mPotionsSize(0),
mApparatiSize(0), mApparatiSize(0),
mArmorsSzie(0) mArmorsSzie(0),
mClothingSize(0)
{ {
setSizeVariables(); setSizeVariables();
} }
@ -26,6 +27,7 @@ void CSMTools::ReferenceableCheckStage::setSizeVariables()
mPotionsSize = mReferencables.getPotions().getSize(); mPotionsSize = mReferencables.getPotions().getSize();
mApparatiSize = mReferencables.getApparati().getSize(); mApparatiSize = mReferencables.getApparati().getSize();
mArmorsSzie = mReferencables.getArmors().getSize(); mArmorsSzie = mReferencables.getArmors().getSize();
mClothingSize = mReferencables.getClothing().getSize();
} }
void CSMTools::ReferenceableCheckStage::perform(int stage, std::vector< std::string >& messages) void CSMTools::ReferenceableCheckStage::perform(int stage, std::vector< std::string >& messages)
@ -68,8 +70,16 @@ void CSMTools::ReferenceableCheckStage::perform(int stage, std::vector< std::str
armorCheck(stage, mReferencables.getArmors(), messages); armorCheck(stage, mReferencables.getArmors(), messages);
return; return;
} }
stage -= mArmorsSzie; stage -= mArmorsSzie;
if (stage < mClothingSize)
{
clothingCheck(stage, mReferencables.getClothing(), messages);
return;
}
stage -= mClothingSize;
} }
int CSMTools::ReferenceableCheckStage::setup() int CSMTools::ReferenceableCheckStage::setup()
@ -281,22 +291,71 @@ void CSMTools::ReferenceableCheckStage::armorCheck(int stage, const CSMWorld::Re
{ {
messages.push_back(id.toString() + "|" + Armor.mId + " has no icon"); messages.push_back(id.toString() + "|" + Armor.mId + " has no icon");
} }
//checking for enchantment points //checking for enchantment points
if (Armor.mData.mEnchant < 0) if (Armor.mData.mEnchant < 0)
{ {
messages.push_back(id.toString() + "|" + Armor.mId + " has negative enchantment"); messages.push_back(id.toString() + "|" + Armor.mId + " has negative enchantment");
} }
//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(id.toString() + "|" + 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, and 0 is illegal //checking for health. Only positive numbers are allowed, and 0 is illegal
if (Armor.mData.mHealth <= 0) if (Armor.mData.mHealth <= 0)
{ {
messages.push_back(id.toString() + "|" + Armor.mId + " has non positive health"); messages.push_back(id.toString() + "|" + Armor.mId + " has non positive health");
}
}
void CSMTools::ReferenceableCheckStage::clothingCheck(int stage, const CSMWorld::RefIdDataContainer< ESM::Clothing >& records, std::vector< std::string >& messages)
{
const CSMWorld::RecordBase& baserecord = records.getRecord(stage);
if (baserecord.isDeleted())
{
return;
}
const ESM::Clothing& Clothing = (static_cast<const CSMWorld::Record<ESM::Clothing>& >(baserecord)).get();
CSMWorld::UniversalId id(CSMWorld::UniversalId::Type_Clothing, Clothing.mId);
//Checking for name
if (Clothing.mName.empty())
{
messages.push_back(id.toString() + "|" + Clothing.mId + " has an empty name");
}
//Checking for weight
if (Clothing.mData.mWeight < 0)
{
messages.push_back(id.toString() + "|" + Clothing.mId + " has negative weight");
}
//Checking for value
if (Clothing.mData.mValue < 0)
{
messages.push_back(id.toString() + "|" + Clothing.mId + " has negative value");
}
//checking for model
if (Clothing.mModel.empty())
{
messages.push_back(id.toString() + "|" + Clothing.mId + " has no model");
}
//checking for icon
if (Clothing.mIcon.empty())
{
messages.push_back(id.toString() + "|" + Clothing.mId + " has no icon");
}
//checking for enchantment points
if (Clothing.mData.mEnchant < 0)
{
messages.push_back(id.toString() + "|" + Clothing.mId + " has negative enchantment");
} }
} }

View file

@ -22,6 +22,7 @@ namespace CSMTools
void potionCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Potion>& records, std::vector<std::string>& messages); void potionCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Potion>& records, std::vector<std::string>& messages);
void apparatusCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Apparatus>& records, std::vector<std::string>& messages); void apparatusCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Apparatus>& records, std::vector<std::string>& messages);
void armorCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Armor>& records, std::vector<std::string>& messages); void armorCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Armor>& records, std::vector<std::string>& messages);
void clothingCheck(int stage, const CSMWorld::RefIdDataContainer<ESM::Clothing>& records, std::vector<std::string>& messages);
void setSizeVariables(); void setSizeVariables();
@ -33,6 +34,7 @@ namespace CSMTools
int mPotionsSize; int mPotionsSize;
int mApparatiSize; int mApparatiSize;
int mArmorsSzie; int mArmorsSzie;
int mClothingSize;
}; };
} }
#endif // REFERENCEABLECHECKSTAGE_H #endif // REFERENCEABLECHECKSTAGE_H

View file

@ -256,3 +256,8 @@ const CSMWorld::RefIdDataContainer< ESM::Armor >& CSMWorld::RefIdData::getArmors
{ {
return mArmors; return mArmors;
} }
const CSMWorld::RefIdDataContainer< ESM::Clothing >& CSMWorld::RefIdData::getClothing() const
{
return mClothing;
}

View file

@ -226,6 +226,7 @@ namespace CSMWorld
const RefIdDataContainer<ESM::Potion>& getPotions() const; const RefIdDataContainer<ESM::Potion>& getPotions() const;
const RefIdDataContainer<ESM::Apparatus>& getApparati() const; const RefIdDataContainer<ESM::Apparatus>& getApparati() const;
const RefIdDataContainer<ESM::Armor>& getArmors() const; const RefIdDataContainer<ESM::Armor>& getArmors() const;
const RefIdDataContainer<ESM::Clothing>& getClothing() const;
}; };
} }