mirror of
https://github.com/TES3MP/TES3MP.git
synced 2025-09-27 06:55:54 -04:00
added verifier for race record
This commit is contained in:
parent
35fe828108
commit
0fb583e065
@ -35,7 +35,7 @@ opencs_units (model/tools
|
|||||||
)
|
)
|
||||||
|
|
||||||
opencs_units_noqt (model/tools
|
opencs_units_noqt (model/tools
|
||||||
stage verifier mandatoryid skillcheck classcheck factioncheck
|
stage verifier mandatoryid skillcheck classcheck factioncheck racecheck
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
47
apps/opencs/model/tools/racecheck.cpp
Normal file
47
apps/opencs/model/tools/racecheck.cpp
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
|
||||||
|
#include "racecheck.hpp"
|
||||||
|
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
#include <components/esm/loadrace.hpp>
|
||||||
|
|
||||||
|
#include "../world/universalid.hpp"
|
||||||
|
|
||||||
|
CSMTools::RaceCheckStage::RaceCheckStage (const CSMWorld::IdCollection<ESM::Race>& races)
|
||||||
|
: mRaces (races)
|
||||||
|
{}
|
||||||
|
|
||||||
|
int CSMTools::RaceCheckStage::setup()
|
||||||
|
{
|
||||||
|
return mRaces.getSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CSMTools::RaceCheckStage::perform (int stage, std::vector<std::string>& messages)
|
||||||
|
{
|
||||||
|
const ESM::Race& race = mRaces.getRecord (stage).get();
|
||||||
|
|
||||||
|
CSMWorld::UniversalId id (CSMWorld::UniversalId::Type_Race, race.mId);
|
||||||
|
|
||||||
|
// test for empty name and description
|
||||||
|
if (race.mName.empty())
|
||||||
|
messages.push_back (id.toString() + "|" + race.mId + " has an empty name");
|
||||||
|
|
||||||
|
if (race.mDescription.empty())
|
||||||
|
messages.push_back (id.toString() + "|" + race.mId + " has an empty description");
|
||||||
|
|
||||||
|
// test for positive height
|
||||||
|
if (race.mData.mHeight.mMale<=0)
|
||||||
|
messages.push_back (id.toString() + "|male " + race.mId + " has non-positive height");
|
||||||
|
|
||||||
|
if (race.mData.mHeight.mFemale<=0)
|
||||||
|
messages.push_back (id.toString() + "|female " + race.mId + " has non-positive height");
|
||||||
|
|
||||||
|
// test for non-negative weight
|
||||||
|
if (race.mData.mWeight.mMale<0)
|
||||||
|
messages.push_back (id.toString() + "|male " + race.mId + " has negative weight");
|
||||||
|
|
||||||
|
if (race.mData.mWeight.mFemale<0)
|
||||||
|
messages.push_back (id.toString() + "|female " + race.mId + " has negative weight");
|
||||||
|
|
||||||
|
/// \todo check data members that can't be edited in the table view
|
||||||
|
}
|
29
apps/opencs/model/tools/racecheck.hpp
Normal file
29
apps/opencs/model/tools/racecheck.hpp
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#ifndef CSM_TOOLS_RACECHECK_H
|
||||||
|
#define CSM_TOOLS_RACECHECK_H
|
||||||
|
|
||||||
|
#include <components/esm/loadrace.hpp>
|
||||||
|
|
||||||
|
#include "../world/idcollection.hpp"
|
||||||
|
|
||||||
|
#include "stage.hpp"
|
||||||
|
|
||||||
|
namespace CSMTools
|
||||||
|
{
|
||||||
|
/// \brief VerifyStage: make sure that race records are internally consistent
|
||||||
|
class RaceCheckStage : public Stage
|
||||||
|
{
|
||||||
|
const CSMWorld::IdCollection<ESM::Race>& mRaces;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
RaceCheckStage (const CSMWorld::IdCollection<ESM::Race>& races);
|
||||||
|
|
||||||
|
virtual int setup();
|
||||||
|
///< \return number of steps
|
||||||
|
|
||||||
|
virtual void perform (int stage, std::vector<std::string>& messages);
|
||||||
|
///< Messages resulting from this tage will be appended to \a messages.
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
@ -15,6 +15,7 @@
|
|||||||
#include "skillcheck.hpp"
|
#include "skillcheck.hpp"
|
||||||
#include "classcheck.hpp"
|
#include "classcheck.hpp"
|
||||||
#include "factioncheck.hpp"
|
#include "factioncheck.hpp"
|
||||||
|
#include "racecheck.hpp"
|
||||||
|
|
||||||
CSMTools::Operation *CSMTools::Tools::get (int type)
|
CSMTools::Operation *CSMTools::Tools::get (int type)
|
||||||
{
|
{
|
||||||
@ -60,6 +61,8 @@ CSMTools::Verifier *CSMTools::Tools::getVerifier()
|
|||||||
mVerifier->appendStage (new ClassCheckStage (mData.getClasses()));
|
mVerifier->appendStage (new ClassCheckStage (mData.getClasses()));
|
||||||
|
|
||||||
mVerifier->appendStage (new FactionCheckStage (mData.getFactions()));
|
mVerifier->appendStage (new FactionCheckStage (mData.getFactions()));
|
||||||
|
|
||||||
|
mVerifier->appendStage (new RaceCheckStage (mData.getRaces()));
|
||||||
}
|
}
|
||||||
|
|
||||||
return mVerifier;
|
return mVerifier;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user