mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 07:23:54 +00:00
added missing columns for weapon records
This commit is contained in:
parent
2123900db5
commit
ca33d66ed9
5 changed files with 176 additions and 2 deletions
|
@ -40,7 +40,8 @@ namespace CSMWorld
|
||||||
Display_ApparatusType,
|
Display_ApparatusType,
|
||||||
Display_ArmorType,
|
Display_ArmorType,
|
||||||
Display_ClothingType,
|
Display_ClothingType,
|
||||||
Display_CreatureType
|
Display_CreatureType,
|
||||||
|
Display_WeaponType
|
||||||
};
|
};
|
||||||
|
|
||||||
std::string mTitle;
|
std::string mTitle;
|
||||||
|
|
|
@ -483,4 +483,93 @@ void CSMWorld::NpcRefIdAdapter::setData (const RefIdColumn *column, RefIdData& d
|
||||||
else
|
else
|
||||||
ActorRefIdAdapter<ESM::NPC>::setData (column, data, index, value);
|
ActorRefIdAdapter<ESM::NPC>::setData (column, data, index, value);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CSMWorld::WeaponColumns::WeaponColumns (const EnchantableColumns& columns)
|
||||||
|
: EnchantableColumns (columns) {}
|
||||||
|
|
||||||
|
CSMWorld::WeaponRefIdAdapter::WeaponRefIdAdapter (const WeaponColumns& columns)
|
||||||
|
: EnchantableRefIdAdapter<ESM::Weapon> (UniversalId::Type_Weapon, columns), mColumns (columns)
|
||||||
|
{}
|
||||||
|
|
||||||
|
QVariant CSMWorld::WeaponRefIdAdapter::getData (const RefIdColumn *column, const RefIdData& data,
|
||||||
|
int index) const
|
||||||
|
{
|
||||||
|
const Record<ESM::Weapon>& record = static_cast<const Record<ESM::Weapon>&> (
|
||||||
|
data.getRecord (RefIdData::LocalIndex (index, UniversalId::Type_Weapon)));
|
||||||
|
|
||||||
|
if (column==mColumns.mType)
|
||||||
|
return record.get().mData.mType;
|
||||||
|
|
||||||
|
if (column==mColumns.mHealth)
|
||||||
|
return record.get().mData.mHealth;
|
||||||
|
|
||||||
|
if (column==mColumns.mSpeed)
|
||||||
|
return record.get().mData.mSpeed;
|
||||||
|
|
||||||
|
if (column==mColumns.mReach)
|
||||||
|
return record.get().mData.mReach;
|
||||||
|
|
||||||
|
for (int i=0; i<2; ++i)
|
||||||
|
{
|
||||||
|
if (column==mColumns.mChop[i])
|
||||||
|
return record.get().mData.mChop[i];
|
||||||
|
|
||||||
|
if (column==mColumns.mSlash[i])
|
||||||
|
return record.get().mData.mSlash[i];
|
||||||
|
|
||||||
|
if (column==mColumns.mThrust[i])
|
||||||
|
return record.get().mData.mThrust[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
std::map<const RefIdColumn *, unsigned int>::const_iterator iter =
|
||||||
|
mColumns.mFlags.find (column);
|
||||||
|
|
||||||
|
if (iter!=mColumns.mFlags.end())
|
||||||
|
return (record.get().mData.mFlags & iter->second)!=0;
|
||||||
|
|
||||||
|
return EnchantableRefIdAdapter<ESM::Weapon>::getData (column, data, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CSMWorld::WeaponRefIdAdapter::setData (const RefIdColumn *column, RefIdData& data, int index,
|
||||||
|
const QVariant& value) const
|
||||||
|
{
|
||||||
|
Record<ESM::Weapon>& record = static_cast<Record<ESM::Weapon>&> (
|
||||||
|
data.getRecord (RefIdData::LocalIndex (index, UniversalId::Type_Weapon)));
|
||||||
|
|
||||||
|
if (column==mColumns.mType)
|
||||||
|
record.get().mData.mType = value.toInt();
|
||||||
|
else if (column==mColumns.mHealth)
|
||||||
|
record.get().mData.mHealth = value.toInt();
|
||||||
|
else if (column==mColumns.mSpeed)
|
||||||
|
record.get().mData.mSpeed = value.toFloat();
|
||||||
|
else if (column==mColumns.mReach)
|
||||||
|
record.get().mData.mReach = value.toFloat();
|
||||||
|
else if (column==mColumns.mChop[0])
|
||||||
|
record.get().mData.mChop[0] = value.toInt();
|
||||||
|
else if (column==mColumns.mChop[1])
|
||||||
|
record.get().mData.mChop[1] = value.toInt();
|
||||||
|
else if (column==mColumns.mSlash[0])
|
||||||
|
record.get().mData.mSlash[0] = value.toInt();
|
||||||
|
else if (column==mColumns.mSlash[1])
|
||||||
|
record.get().mData.mSlash[1] = value.toInt();
|
||||||
|
else if (column==mColumns.mThrust[0])
|
||||||
|
record.get().mData.mThrust[0] = value.toInt();
|
||||||
|
else if (column==mColumns.mThrust[1])
|
||||||
|
record.get().mData.mThrust[1] = value.toInt();
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::map<const RefIdColumn *, unsigned int>::const_iterator iter =
|
||||||
|
mColumns.mFlags.find (column);
|
||||||
|
|
||||||
|
if (iter!=mColumns.mFlags.end())
|
||||||
|
{
|
||||||
|
if (value.toInt()!=0)
|
||||||
|
record.get().mData.mFlags |= iter->second;
|
||||||
|
else
|
||||||
|
record.get().mData.mFlags &= ~iter->second;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
EnchantableRefIdAdapter<ESM::Weapon>::setData (column, data, index, value);
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -731,6 +731,36 @@ namespace CSMWorld
|
||||||
const QVariant& value) const;
|
const QVariant& value) const;
|
||||||
///< If the data type does not match an exception is thrown.
|
///< If the data type does not match an exception is thrown.
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct WeaponColumns : public EnchantableColumns
|
||||||
|
{
|
||||||
|
const RefIdColumn *mType;
|
||||||
|
const RefIdColumn *mHealth;
|
||||||
|
const RefIdColumn *mSpeed;
|
||||||
|
const RefIdColumn *mReach;
|
||||||
|
const RefIdColumn *mChop[2];
|
||||||
|
const RefIdColumn *mSlash[2];
|
||||||
|
const RefIdColumn *mThrust[2];
|
||||||
|
std::map<const RefIdColumn *, unsigned int> mFlags;
|
||||||
|
|
||||||
|
WeaponColumns (const EnchantableColumns& columns);
|
||||||
|
};
|
||||||
|
|
||||||
|
class WeaponRefIdAdapter : public EnchantableRefIdAdapter<ESM::Weapon>
|
||||||
|
{
|
||||||
|
WeaponColumns mColumns;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
WeaponRefIdAdapter (const WeaponColumns& columns);
|
||||||
|
|
||||||
|
virtual QVariant getData (const RefIdColumn *column, const RefIdData& data, int index)
|
||||||
|
const;
|
||||||
|
|
||||||
|
virtual void setData (const RefIdColumn *column, RefIdData& data, int index,
|
||||||
|
const QVariant& value) const;
|
||||||
|
///< If the data type does not match an exception is thrown.
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -286,6 +286,50 @@ CSMWorld::RefIdCollection::RefIdCollection()
|
||||||
|
|
||||||
npcColumns.mFlags.insert (std::make_pair (metalBlood, ESM::NPC::Metal));
|
npcColumns.mFlags.insert (std::make_pair (metalBlood, ESM::NPC::Metal));
|
||||||
|
|
||||||
|
WeaponColumns weaponColumns (enchantableColumns);
|
||||||
|
|
||||||
|
mColumns.push_back (RefIdColumn ("Weapon Type", ColumnBase::Display_WeaponType));
|
||||||
|
weaponColumns.mType = &mColumns.back();
|
||||||
|
|
||||||
|
weaponColumns.mHealth = health;
|
||||||
|
|
||||||
|
mColumns.push_back (RefIdColumn ("Weapon Speed", ColumnBase::Display_Float));
|
||||||
|
weaponColumns.mSpeed = &mColumns.back();
|
||||||
|
|
||||||
|
mColumns.push_back (RefIdColumn ("Weapon Reach", ColumnBase::Display_Float));
|
||||||
|
weaponColumns.mReach = &mColumns.back();
|
||||||
|
|
||||||
|
for (int i=0; i<2; ++i)
|
||||||
|
{
|
||||||
|
std::string suffix = i==0 ? "Min " : "Max ";
|
||||||
|
|
||||||
|
mColumns.push_back (RefIdColumn ("Chop" + suffix, ColumnBase::Display_Integer));
|
||||||
|
weaponColumns.mChop[i] = &mColumns.back();
|
||||||
|
|
||||||
|
mColumns.push_back (RefIdColumn ("Slash" + suffix, ColumnBase::Display_Integer));
|
||||||
|
weaponColumns.mSlash[i] = &mColumns.back();
|
||||||
|
|
||||||
|
mColumns.push_back (RefIdColumn ("Thrust" + suffix, ColumnBase::Display_Integer));
|
||||||
|
weaponColumns.mThrust[i] = &mColumns.back();
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct
|
||||||
|
{
|
||||||
|
const char *mName;
|
||||||
|
unsigned int mFlag;
|
||||||
|
} sWeaponFlagTable[] =
|
||||||
|
{
|
||||||
|
{ "Magical", ESM::Weapon::Magical },
|
||||||
|
{ "Silver", ESM::Weapon::Silver },
|
||||||
|
{ 0, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
for (int i=0; sWeaponFlagTable[i].mName; ++i)
|
||||||
|
{
|
||||||
|
mColumns.push_back (RefIdColumn (sWeaponFlagTable[i].mName, ColumnBase::Display_Boolean));
|
||||||
|
weaponColumns.mFlags.insert (std::make_pair (&mColumns.back(), sWeaponFlagTable[i].mFlag));
|
||||||
|
}
|
||||||
|
|
||||||
mAdapters.insert (std::make_pair (UniversalId::Type_Activator,
|
mAdapters.insert (std::make_pair (UniversalId::Type_Activator,
|
||||||
new NameRefIdAdapter<ESM::Activator> (UniversalId::Type_Activator, nameColumns)));
|
new NameRefIdAdapter<ESM::Activator> (UniversalId::Type_Activator, nameColumns)));
|
||||||
mAdapters.insert (std::make_pair (UniversalId::Type_Potion,
|
mAdapters.insert (std::make_pair (UniversalId::Type_Potion,
|
||||||
|
@ -326,7 +370,7 @@ CSMWorld::RefIdCollection::RefIdCollection()
|
||||||
mAdapters.insert (std::make_pair (UniversalId::Type_Static,
|
mAdapters.insert (std::make_pair (UniversalId::Type_Static,
|
||||||
new ModelRefIdAdapter<ESM::Static> (UniversalId::Type_Static, modelColumns)));
|
new ModelRefIdAdapter<ESM::Static> (UniversalId::Type_Static, modelColumns)));
|
||||||
mAdapters.insert (std::make_pair (UniversalId::Type_Weapon,
|
mAdapters.insert (std::make_pair (UniversalId::Type_Weapon,
|
||||||
new EnchantableRefIdAdapter<ESM::Weapon> (UniversalId::Type_Weapon, enchantableColumns)));
|
new WeaponRefIdAdapter (weaponColumns)));
|
||||||
}
|
}
|
||||||
|
|
||||||
CSMWorld::RefIdCollection::~RefIdCollection()
|
CSMWorld::RefIdCollection::~RefIdCollection()
|
||||||
|
|
|
@ -76,6 +76,13 @@ CSVDoc::ViewManager::ViewManager (CSMDoc::DocumentManager& documentManager)
|
||||||
"Creature", "Deadra", "Undead", "Humanoid", 0
|
"Creature", "Deadra", "Undead", "Humanoid", 0
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const char *sWeaponTypes[] =
|
||||||
|
{
|
||||||
|
"Short Blade 1H", "Long Blade 1H", "Long Blade 2H", "Blunt 1H", "Blunt 2H Close",
|
||||||
|
"Blunt 2H Wide", "Spear 2H", "Axe 1H", "Axe 2H", "Bow", "Crossbow", "Thrown", "Arrow",
|
||||||
|
"Bolt", 0
|
||||||
|
};
|
||||||
|
|
||||||
mDelegateFactories = new CSVWorld::CommandDelegateFactoryCollection;
|
mDelegateFactories = new CSVWorld::CommandDelegateFactoryCollection;
|
||||||
|
|
||||||
mDelegateFactories->add (CSMWorld::ColumnBase::Display_GmstVarType,
|
mDelegateFactories->add (CSMWorld::ColumnBase::Display_GmstVarType,
|
||||||
|
@ -104,6 +111,9 @@ CSVDoc::ViewManager::ViewManager (CSMDoc::DocumentManager& documentManager)
|
||||||
|
|
||||||
mDelegateFactories->add (CSMWorld::ColumnBase::Display_CreatureType,
|
mDelegateFactories->add (CSMWorld::ColumnBase::Display_CreatureType,
|
||||||
new CSVWorld::EnumDelegateFactory (sCreatureTypes));
|
new CSVWorld::EnumDelegateFactory (sCreatureTypes));
|
||||||
|
|
||||||
|
mDelegateFactories->add (CSMWorld::ColumnBase::Display_WeaponType,
|
||||||
|
new CSVWorld::EnumDelegateFactory (sWeaponTypes));
|
||||||
}
|
}
|
||||||
|
|
||||||
CSVDoc::ViewManager::~ViewManager()
|
CSVDoc::ViewManager::~ViewManager()
|
||||||
|
|
Loading…
Reference in a new issue