|
|
@ -18,6 +18,8 @@
|
|
|
|
#include <components/esm3/loadskil.hpp>
|
|
|
|
#include <components/esm3/loadskil.hpp>
|
|
|
|
#include <components/esm3/variant.hpp>
|
|
|
|
#include <components/esm3/variant.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <optional>
|
|
|
|
|
|
|
|
|
|
|
|
#include <QString>
|
|
|
|
#include <QString>
|
|
|
|
#include <QVariant>
|
|
|
|
#include <QVariant>
|
|
|
|
#include <QVector>
|
|
|
|
#include <QVector>
|
|
|
@ -31,6 +33,10 @@
|
|
|
|
|
|
|
|
|
|
|
|
namespace CSMWorld
|
|
|
|
namespace CSMWorld
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
std::optional<std::uint32_t> getSkillIndex(std::string_view value);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::string getStringId(ESM::RefId value);
|
|
|
|
|
|
|
|
|
|
|
|
/// \note Shares ID with VarValueColumn. A table can not have both.
|
|
|
|
/// \note Shares ID with VarValueColumn. A table can not have both.
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
struct FloatValueColumn : public Column<ESXRecordT>
|
|
|
|
struct FloatValueColumn : public Column<ESXRecordT>
|
|
|
@ -63,7 +69,7 @@ namespace CSMWorld
|
|
|
|
|
|
|
|
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return QString::fromStdString(record.get().mId.toString());
|
|
|
|
return QString::fromStdString(getStringId(record.get().mId));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool isEditable() const override { return false; }
|
|
|
|
bool isEditable() const override { return false; }
|
|
|
@ -403,25 +409,16 @@ namespace CSMWorld
|
|
|
|
|
|
|
|
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
QVariant get(const Record<ESXRecordT>& record) const override
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int skill = record.get().mData.getSkill(mIndex, mMajor);
|
|
|
|
return QString::fromStdString(ESM::Skill::sSkillNames[record.get().mData.getSkill(mIndex, mMajor)]);
|
|
|
|
|
|
|
|
|
|
|
|
return QString::fromStdString(ESM::Skill::indexToRefId(skill).toString());
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void set(Record<ESXRecordT>& record, const QVariant& data) override
|
|
|
|
void set(Record<ESXRecordT>& record, const QVariant& data) override
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::istringstream stream(data.toString().toUtf8().constData());
|
|
|
|
if (const auto index = getSkillIndex(data.toString().toStdString()))
|
|
|
|
|
|
|
|
|
|
|
|
int index = -1;
|
|
|
|
|
|
|
|
char c;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
stream >> c >> index;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (index != -1)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ESXRecordT record2 = record.get();
|
|
|
|
ESXRecordT record2 = record.get();
|
|
|
|
|
|
|
|
|
|
|
|
record2.mData.getSkill(mIndex, mMajor) = index;
|
|
|
|
record2.mData.getSkill(mIndex, mMajor) = static_cast<int>(*index);
|
|
|
|
|
|
|
|
|
|
|
|
record.setModified(record2);
|
|
|
|
record.setModified(record2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|