comphelper/source/xml/attributelist.cxx | 18 +++++++++++++++--- include/comphelper/attributelist.hxx | 10 ++++++++-- 2 files changed, 23 insertions(+), 5 deletions(-)
New commits: commit 66fee51115a2174bde47c3af01a7d1fdcf1ef602 Author: Caolán McNamara <caol...@redhat.com> Date: Fri Mar 11 09:45:39 2016 +0000 Resolves: tdf#98418 AttributeList must support XCloneable regression from commit 8998768a34751d35403678a81464a26835b2230e Date: Sat Feb 6 18:38:32 2016 +0100 Change-Id: I217fb66621505b77b6102954c07ef513e2d4b25e diff --git a/comphelper/source/xml/attributelist.cxx b/comphelper/source/xml/attributelist.cxx index f196b48..cefede8 100644 --- a/comphelper/source/xml/attributelist.cxx +++ b/comphelper/source/xml/attributelist.cxx @@ -100,15 +100,20 @@ OUString SAL_CALL AttributeList::getValueByName(const OUString& sName) throw( cs return OUString(); } - AttributeList::AttributeList() + : m_pImpl(new AttributeList_Impl) +{ +} + +AttributeList::AttributeList(const AttributeList &r) + : cppu::WeakImplHelper<XAttributeList, XCloneable>() + , m_pImpl(new AttributeList_Impl) { - m_pImpl = new AttributeList_Impl; + *m_pImpl = *(r.m_pImpl); } AttributeList::~AttributeList() { - delete m_pImpl; } void AttributeList::AddAttribute(const OUString &sName, @@ -122,6 +127,13 @@ void AttributeList::Clear() m_pImpl->vecAttribute.clear(); } +css::uno::Reference< css::util::XCloneable > AttributeList::createClone() throw (css::uno::RuntimeException, std::exception) + +{ + AttributeList *p = new AttributeList( *this ); + return css::uno::Reference< css::util::XCloneable > ( static_cast<css::util::XCloneable *>(p) ); +} + } // namespace comphelper /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/include/comphelper/attributelist.hxx b/include/comphelper/attributelist.hxx index 18aaa50..9a6f535 100644 --- a/include/comphelper/attributelist.hxx +++ b/include/comphelper/attributelist.hxx @@ -20,6 +20,7 @@ #ifndef INCLUDED_COMPHELPER_ATTRIBUTELIST_HXX #define INCLUDED_COMPHELPER_ATTRIBUTELIST_HXX +#include <com/sun/star/util/XCloneable.hpp> #include <com/sun/star/xml/sax/XAttributeList.hpp> #include <cppuhelper/implbase.hxx> #include <comphelper/comphelperdllapi.h> @@ -31,11 +32,13 @@ namespace comphelper struct AttributeList_Impl; class COMPHELPER_DLLPUBLIC AttributeList : - public ::cppu::WeakImplHelper<css::xml::sax::XAttributeList> + public ::cppu::WeakImplHelper<css::xml::sax::XAttributeList, css::util::XCloneable> { - AttributeList_Impl *m_pImpl; + std::unique_ptr<AttributeList_Impl> m_pImpl; public: AttributeList(); + AttributeList(const AttributeList &r); + virtual ~AttributeList(); // methods that are not contained in any interface @@ -56,6 +59,9 @@ public: virtual OUString SAL_CALL getValueByName(const OUString& aName) throw( css::uno::RuntimeException, std::exception ) override; + // css::util::XCloneable + virtual css::uno::Reference< XCloneable > SAL_CALL + createClone() throw(css::uno::RuntimeException, std::exception) override; }; } // namespace comphelper
_______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits