Remove potential memory leak.

celladd
cc9cii 10 years ago
parent 43ec933b7b
commit 28259f914c

@ -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>

Loading…
Cancel
Save