|
|
@ -2,6 +2,7 @@
|
|
|
|
#define CSM_WOLRD_REFIDADAPTERIMP_H
|
|
|
|
#define CSM_WOLRD_REFIDADAPTERIMP_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
|
|
|
|
#include <QVariant>
|
|
|
|
#include <QVariant>
|
|
|
|
|
|
|
|
|
|
|
@ -1829,10 +1830,10 @@ namespace CSMWorld
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// for non-tables
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
class NestedListLevListRefIdAdapter : public NestedRefIdAdapterBase
|
|
|
|
class NestedListLevListRefIdAdapter : public NestedRefIdAdapterBase
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
UniversalId::Type mType;
|
|
|
|
UniversalId::Type mType;
|
|
|
|
|
|
|
|
|
|
|
|
// not implemented
|
|
|
|
// not implemented
|
|
|
@ -1876,31 +1877,27 @@ namespace CSMWorld
|
|
|
|
const Record<ESXRecordT>& record =
|
|
|
|
const Record<ESXRecordT>& record =
|
|
|
|
static_cast<const Record<ESXRecordT>&> (data.getRecord (RefIdData::LocalIndex (index, mType)));
|
|
|
|
static_cast<const Record<ESXRecordT>&> (data.getRecord (RefIdData::LocalIndex (index, mType)));
|
|
|
|
|
|
|
|
|
|
|
|
switch (subColIndex)
|
|
|
|
if (mType == UniversalId::Type_CreatureLevelledList)
|
|
|
|
{
|
|
|
|
|
|
|
|
case 0:
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (mType == CSMWorld::UniversalId::Type_CreatureLevelledList &&
|
|
|
|
|
|
|
|
record.get().mFlags == 0x01)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return QString("All Levels");
|
|
|
|
switch (subColIndex)
|
|
|
|
}
|
|
|
|
|
|
|
|
else if(mType == CSMWorld::UniversalId::Type_ItemLevelledList &&
|
|
|
|
|
|
|
|
record.get().mFlags == 0x01)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return QString("Each");
|
|
|
|
case 0: return QVariant(); // don't allow checkbox editor to be created
|
|
|
|
|
|
|
|
case 1: return record.get().mFlags & ESM::CreatureLevList::AllLevels;
|
|
|
|
|
|
|
|
case 2: return static_cast<int> (record.get().mChanceNone);
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
throw std::runtime_error("Trying to access non-existing column in levelled creatues!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(mType == CSMWorld::UniversalId::Type_ItemLevelledList &&
|
|
|
|
|
|
|
|
record.get().mFlags == 0x02)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return QString("All Levels");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
throw std::runtime_error("unknown leveled list type");
|
|
|
|
{
|
|
|
|
}
|
|
|
|
switch (subColIndex)
|
|
|
|
case 1: return static_cast<int> (record.get().mChanceNone);
|
|
|
|
{
|
|
|
|
|
|
|
|
case 0: return record.get().mFlags & ESM::ItemLevList::Each;
|
|
|
|
|
|
|
|
case 1: return record.get().mFlags & ESM::ItemLevList::AllLevels;
|
|
|
|
|
|
|
|
case 2: return static_cast<int> (record.get().mChanceNone);
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
throw std::runtime_error("Trying to access non-existing column in the nested table!");
|
|
|
|
throw std::runtime_error("Trying to access non-existing column in levelled items!");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1911,34 +1908,63 @@ namespace CSMWorld
|
|
|
|
static_cast<Record<ESXRecordT>&> (data.getRecord (RefIdData::LocalIndex (row, mType)));
|
|
|
|
static_cast<Record<ESXRecordT>&> (data.getRecord (RefIdData::LocalIndex (row, mType)));
|
|
|
|
ESXRecordT leveled = record.get();
|
|
|
|
ESXRecordT leveled = record.get();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (mType == UniversalId::Type_CreatureLevelledList)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
switch(subColIndex)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
case 0: return; // return without saving
|
|
|
|
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(value.toBool())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
leveled.mFlags |= ESM::CreatureLevList::AllLevels;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
leveled.mFlags &= ~ESM::CreatureLevList::AllLevels;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case 2: leveled.mChanceNone = static_cast<unsigned char>(value.toInt()); break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
throw std::runtime_error("Trying to set non-existing column in levelled creatures!");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
switch(subColIndex)
|
|
|
|
switch(subColIndex)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
case 0:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (mType == CSMWorld::UniversalId::Type_CreatureLevelledList &&
|
|
|
|
if(value.toBool())
|
|
|
|
value.toString().toStdString() == "All Levels")
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
leveled.mFlags = 0x01;
|
|
|
|
leveled.mFlags |= ESM::ItemLevList::Each;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(mType == CSMWorld::UniversalId::Type_ItemLevelledList &&
|
|
|
|
else
|
|
|
|
value.toString().toStdString() == "Each")
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
leveled.mFlags = 0x01;
|
|
|
|
leveled.mFlags &= ~ESM::ItemLevList::Each;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(mType == CSMWorld::UniversalId::Type_ItemLevelledList &&
|
|
|
|
}
|
|
|
|
value.toString().toStdString() == "All Levels")
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(value.toBool())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
leveled.mFlags = 0x02;
|
|
|
|
leveled.mFlags |= ESM::ItemLevList::AllLevels;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return; // return without saving
|
|
|
|
{
|
|
|
|
|
|
|
|
leveled.mFlags &= ~ESM::ItemLevList::AllLevels;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case 1: leveled.mChanceNone = static_cast<unsigned char>(value.toInt()); break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case 2: leveled.mChanceNone = static_cast<unsigned char>(value.toInt()); break;
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
throw std::runtime_error("Trying to access non-existing column in the nested table!");
|
|
|
|
throw std::runtime_error("Trying to set non-existing column in levelled items!");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
record.setModified (leveled);
|
|
|
|
record.setModified (leveled);
|
|
|
@ -1946,7 +1972,7 @@ namespace CSMWorld
|
|
|
|
|
|
|
|
|
|
|
|
virtual int getNestedColumnsCount(const RefIdColumn *column, const RefIdData& data) const
|
|
|
|
virtual int getNestedColumnsCount(const RefIdColumn *column, const RefIdData& data) const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return 2;
|
|
|
|
return 3;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
virtual int getNestedRowsCount(const RefIdColumn *column, const RefIdData& data, int index) const
|
|
|
|
virtual int getNestedRowsCount(const RefIdColumn *column, const RefIdData& data, int index) const
|
|
|
@ -1955,6 +1981,7 @@ namespace CSMWorld
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// for tables
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
class NestedLevListRefIdAdapter : public NestedRefIdAdapterBase
|
|
|
|
class NestedLevListRefIdAdapter : public NestedRefIdAdapterBase
|
|
|
|
{
|
|
|
|
{
|
|
|
|