[Libreoffice-commits] core.git: package/source

Szymon Kłos szymon.klos at collabora.com
Thu Sep 7 09:52:59 UTC 2017


 package/source/xstor/xstorage.cxx |    2 ++
 1 file changed, 2 insertions(+)

New commits:
commit 26957fc325c27cf61e8ef5555b380d627def4931
Author: Szymon Kłos <szymon.klos at collabora.com>
Date:   Wed Sep 6 10:54:50 2017 +0200

    tdf#108572 let remove storage element
    
    void OStorage_Impl::RemoveElement( SotElement_Impl* pElement )
    expects that m_pAntiImpl will be nullptr, if not throws an exception.
    This caused that in case of deleting embedded database used for
    mail merge it wasn't fully removed and it was impossible to import
    the same datasource second time.
    
    Change-Id: I0310fde2ad819c96474a857f37ee42d052fad266
    Reviewed-on: https://gerrit.libreoffice.org/42028
    Tested-by: Jenkins <ci at libreoffice.org>
    Reviewed-by: Szymon Kłos <szymon.klos at collabora.com>

diff --git a/package/source/xstor/xstorage.cxx b/package/source/xstor/xstorage.cxx
index 2edbfcbc1873..79b239588c77 100644
--- a/package/source/xstor/xstorage.cxx
+++ b/package/source/xstor/xstorage.cxx
@@ -2816,6 +2816,8 @@ void SAL_CALL OStorage::removeElement( const OUString& aElementName )
         if ( !pElement )
             throw container::NoSuchElementException( THROW_WHERE ); //???
 
+        if ( pElement->m_xStorage )
+            pElement->m_xStorage->m_pAntiImpl = nullptr;
         m_pImpl->RemoveElement( pElement );
 
         m_pImpl->m_bIsModified = true;


More information about the Libreoffice-commits mailing list