|
|
@ -40,6 +40,13 @@ namespace CSMWorld
|
|
|
|
ESXRecordT mBase;
|
|
|
|
ESXRecordT mBase;
|
|
|
|
ESXRecordT mModified;
|
|
|
|
ESXRecordT mModified;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Record() = default;
|
|
|
|
|
|
|
|
Record(const Record&) = default;
|
|
|
|
|
|
|
|
Record& operator= (const Record&) = default;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Record(State state,
|
|
|
|
|
|
|
|
const ESXRecordT *base = 0, const ESXRecordT *modified = 0);
|
|
|
|
|
|
|
|
|
|
|
|
virtual RecordBase *clone() const;
|
|
|
|
virtual RecordBase *clone() const;
|
|
|
|
|
|
|
|
|
|
|
|
virtual RecordBase *modifiedCopy() const;
|
|
|
|
virtual RecordBase *modifiedCopy() const;
|
|
|
@ -62,14 +69,22 @@ namespace CSMWorld
|
|
|
|
///< Merge modified into base.
|
|
|
|
///< Merge modified into base.
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
|
|
|
|
Record<ESXRecordT>::Record(State state, const ESXRecordT *base, const ESXRecordT *modified)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(base)
|
|
|
|
|
|
|
|
mBase = *base;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(modified)
|
|
|
|
|
|
|
|
mModified = *modified;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
this->mState = state;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
RecordBase *Record<ESXRecordT>::modifiedCopy() const
|
|
|
|
RecordBase *Record<ESXRecordT>::modifiedCopy() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Record<ESXRecordT> *record = new Record<ESXRecordT> (*this);
|
|
|
|
return new Record<ESXRecordT> (State_ModifiedOnly, 0, &(this->get()));
|
|
|
|
record->mModified = record->mBase;
|
|
|
|
|
|
|
|
record->mBase = ESXRecordT();
|
|
|
|
|
|
|
|
record->mState = RecordBase::State_ModifiedOnly;
|
|
|
|
|
|
|
|
return record;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <typename ESXRecordT>
|
|
|
|
template <typename ESXRecordT>
|
|
|
|