diff options
Diffstat (limited to 'sd')
-rw-r--r-- | sd/inc/OutlinerIterator.hxx | 2 | ||||
-rw-r--r-- | sd/source/ui/view/OutlinerIterator.cxx | 31 |
2 files changed, 15 insertions, 18 deletions
diff --git a/sd/inc/OutlinerIterator.hxx b/sd/inc/OutlinerIterator.hxx index b261ed4e5997..2fc5a6cd9647 100644 --- a/sd/inc/OutlinerIterator.hxx +++ b/sd/inc/OutlinerIterator.hxx @@ -135,7 +135,7 @@ public: private: /// The implementation object to which most of the methods are forwarded. - IteratorImplBase* mpIterator; + std::unique_ptr<IteratorImplBase> mxIterator; }; /** This class wraps the <type>Outliner</type> class and represents it as diff --git a/sd/source/ui/view/OutlinerIterator.cxx b/sd/source/ui/view/OutlinerIterator.cxx index 65e3fd11ef30..4fd8df0e85ce 100644 --- a/sd/source/ui/view/OutlinerIterator.cxx +++ b/sd/source/ui/view/OutlinerIterator.cxx @@ -66,56 +66,53 @@ bool IteratorPosition::operator== (const IteratorPosition& aPosition) const Iterator::Iterator() { - mpIterator = nullptr; } Iterator::Iterator (const Iterator& rIterator) + : mxIterator(rIterator.mxIterator ? rIterator.mxIterator->Clone() : nullptr) { - mpIterator = rIterator.mpIterator ? rIterator.mpIterator->Clone() : nullptr; } Iterator::Iterator (IteratorImplBase* pObject) + : mxIterator(pObject) { - mpIterator = pObject; } Iterator::~Iterator() { - delete mpIterator; } Iterator& Iterator::operator= (const Iterator& rIterator) { if (this != &rIterator) { - delete mpIterator; - if (rIterator.mpIterator != nullptr) - mpIterator = rIterator.mpIterator->Clone(); + if (rIterator.mxIterator) + mxIterator.reset(rIterator.mxIterator->Clone()); else - mpIterator = nullptr; + mxIterator.reset(); } return *this; } const IteratorPosition& Iterator::operator* () const { - DBG_ASSERT (mpIterator!=nullptr, "::sd::outliner::Iterator::operator* : missing implementation object"); - return mpIterator->GetPosition(); + DBG_ASSERT (mxIterator, "::sd::outliner::Iterator::operator* : missing implementation object"); + return mxIterator->GetPosition(); } Iterator& Iterator::operator++ () { - if (mpIterator!=nullptr) - mpIterator->GotoNextText(); + if (mxIterator) + mxIterator->GotoNextText(); return *this; } bool Iterator::operator== (const Iterator& rIterator) { - if (mpIterator == nullptr || rIterator.mpIterator==nullptr) - return mpIterator == rIterator.mpIterator; + if (!mxIterator || !rIterator.mxIterator) + return mxIterator.get() == rIterator.mxIterator.get(); else - return *mpIterator == *rIterator.mpIterator; + return *mxIterator == *rIterator.mxIterator; } bool Iterator::operator!= (const Iterator& rIterator) @@ -125,8 +122,8 @@ bool Iterator::operator!= (const Iterator& rIterator) void Iterator::Reverse() { - if (mpIterator != nullptr) - mpIterator->Reverse(); + if (mxIterator) + mxIterator->Reverse(); } //===== IteratorFactory ======================================================= |