forked from mirror/openmw-tes3mp
Added armor check and related stuff.
This commit is contained in:
parent
97fc8acbdb
commit
bbcaef8e42
4 changed files with 75 additions and 8 deletions
|
@ -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");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
|
@ -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;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue