From a152b1fe7fc3056ff6444321a1cdf8c24b8c8a2f Mon Sep 17 00:00:00 2001 From: Julien Nabet Date: Wed, 24 Aug 2022 16:42:54 +0200 Subject: tdf#150575: REPORTBUILDER: Crash when closing report when used report navigator 0 0x00007fe062bdda64 in comphelper::OSelectionChangeMultiplexer::disposing(com::sun::star::lang::EventObject const&) (this=0x55fe72b7b680, _rSource=...) at comphelper/source/misc/SelectionMultiplex.cxx:82 1 0x00007fdf90a97a6b in comphelper::OInterfaceContainerHelper3::disposeAndClear(com::sun::star::lang::EventObject const&) (this=0x55fe6c94b6d0, rEvt=...) at include/comphelper/interfacecontainer3.hxx:362 2 0x00007fdf90a6ace4 in rptui::OReportController::disposing() (this=0x55fe6c94b200) at reportdesign/source/ui/report/ReportController.cxx:341 3 0x00007fe062539b5d in cppu::WeakComponentImplHelperBase::dispose() (this=0x55fe6c94b200) at cppuhelper/source/implbase.cxx:104 4 0x00007fe0393b76e5 in cppu::PartialWeakComponentImplHelper::dispose() (this=0x55fe6c94b200) at include/cppuhelper/compbase.hxx:90 5 0x00007fe0393af9d3 in dbaui::OGenericUnoController::dispose() (this=0x55fe6c94b200) at dbaccess/source/ui/browser/genericcontroller.cxx:1207 See full bt here: https://bugs.documentfoundation.org/attachment.cgi?id=181994 "addSelectionChangeListener" is called when "OSelectionChangeMultiplexer" is instantiated in "NavigatorTree" ctr 225 m_pSelectionListener = new OSelectionChangeMultiplexer(this,&m_rController); but "removeSelectionChangeListener" was never called so add the mechanism to call it. Change-Id: I157b147f7a17244dbbfa7d12743fc7d48e7d5f7d Reviewed-on: https://gerrit.libreoffice.org/c/core/+/138773 Reviewed-by: Julien Nabet (cherry picked from commit fb8c86d95a7d1c68b6dc0f5bb2e00db2f40f58ab) Reviewed-on: https://gerrit.libreoffice.org/c/core/+/138551 Tested-by: Jenkins Reviewed-by: Noel Grandin (cherry picked from commit 41d1e848677891d1451b2120763c7c069006b4a5) Reviewed-on: https://gerrit.libreoffice.org/c/core/+/138832 Reviewed-by: Michael Stahl --- reportdesign/source/ui/dlg/Navigator.cxx | 1 + 1 file changed, 1 insertion(+) (limited to 'reportdesign') diff --git a/reportdesign/source/ui/dlg/Navigator.cxx b/reportdesign/source/ui/dlg/Navigator.cxx index 939a6abc8236..d6a5ac60059d 100644 --- a/reportdesign/source/ui/dlg/Navigator.cxx +++ b/reportdesign/source/ui/dlg/Navigator.cxx @@ -238,6 +238,7 @@ NavigatorTree::~NavigatorTree() delete pData; return false; }); + m_pSelectionListener->dispose(); m_pReportListener->dispose(); } -- cgit