summaryrefslogtreecommitdiff
path: root/reportdesign
diff options
context:
space:
mode:
authorJulien Nabet <serval2412@yahoo.fr>2016-12-09 00:28:46 +0100
committerJulien Nabet <serval2412@yahoo.fr>2016-12-09 06:09:33 +0000
commit73131fc3806ce2a7da61c93590e467e5b044c341 (patch)
tree2c2e5b8e71dee54ff21b6b605afee77716a24fbd /reportdesign
parentcb598029835477326b190bc99abd31a487cc5a91 (diff)
tdf#104105: fix Vcl lifecycle in CondFormat (reportdesign)
Avoid this error: Window ( 7VclVBox()) with live children destroyed: N5rptui9ConditionE() * n by calling disposeAndClear on each element of m_aConditions m_aConditions is Conditions type Conditions type is ::std::vector< VclPtr<Condition> > See http://opengrok.libreoffice.org/xref/core/reportdesign/source/ui/inc/CondFormat.hxx#70 Change-Id: Ie99f8cdb5acd787892237787525d79f3231689db Reviewed-on: https://gerrit.libreoffice.org/31775 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Julien Nabet <serval2412@yahoo.fr>
Diffstat (limited to 'reportdesign')
-rw-r--r--reportdesign/source/ui/dlg/CondFormat.cxx7
1 files changed, 6 insertions, 1 deletions
diff --git a/reportdesign/source/ui/dlg/CondFormat.cxx b/reportdesign/source/ui/dlg/CondFormat.cxx
index 84dd2b9b336c..32d81f7fa689 100644
--- a/reportdesign/source/ui/dlg/CondFormat.cxx
+++ b/reportdesign/source/ui/dlg/CondFormat.cxx
@@ -134,6 +134,12 @@ namespace rptui
void ConditionalFormattingDialog::dispose()
{
+
+ for (auto i = m_aConditions.begin(); i != m_aConditions.end(); ++i)
+ {
+ i->disposeAndClear();
+ }
+
m_aConditions.clear();
m_pConditionPlayground.clear();
m_pScrollWindow.clear();
@@ -190,7 +196,6 @@ namespace rptui
Reference< XFormatCondition > xCond = m_xCopy->createFormatCondition();
::comphelper::copyProperties(m_xCopy.get(),xCond.get());
m_xCopy->insertByIndex( _nNewCondIndex, makeAny( xCond ) );
-
VclPtrInstance<Condition> pCon( m_pConditionPlayground, *this, m_rController );
pCon->setCondition( xCond );
pCon->reorderWithinParent(_nNewCondIndex);