From 7fc6063914432d58d86cfcbd728d967e7c86ebfd Mon Sep 17 00:00:00 2001 From: Noel Grandin Date: Thu, 17 Aug 2023 15:42:01 +0200 Subject: use more Reference::query instead of UNO_QUERY_THROW since querying with exceptions is consideably more expensive Change-Id: I968a9a40766b2abb0d3058549b0ed44011fd5716 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/155791 Tested-by: Jenkins Reviewed-by: Noel Grandin --- embedserv/source/embed/docholder.cxx | 31 ++++--------------------------- 1 file changed, 4 insertions(+), 27 deletions(-) (limited to 'embedserv/source/embed') diff --git a/embedserv/source/embed/docholder.cxx b/embedserv/source/embed/docholder.cxx index 12300b856517..a70483e0de80 100644 --- a/embedserv/source/embed/docholder.cxx +++ b/embedserv/source/embed/docholder.cxx @@ -603,31 +603,14 @@ void DocumentHolder::FreeOffice() void DocumentHolder::DisconnectFrameDocument( bool bComplete ) { - try - { - uno::Reference< util::XModifyBroadcaster > xModifiable( m_xDocument, uno::UNO_QUERY_THROW ); + if (auto xModifiable = m_xDocument.query() ) xModifiable->removeModifyListener( static_cast(this) ); - } - catch( const uno::Exception& ) - {} - try - { - uno::Reference< util::XCloseBroadcaster > xBroadcaster( - m_xDocument, uno::UNO_QUERY_THROW ); + if (auto xBroadcaster = m_xDocument.query() ) xBroadcaster->removeCloseListener( static_cast(this) ); - } - catch( const uno::Exception& ) - {} - try - { - uno::Reference< util::XCloseBroadcaster > xBroadcaster( - m_xFrame, uno::UNO_QUERY_THROW ); + if (auto xBroadcaster = m_xFrame.query() ) xBroadcaster->removeCloseListener( static_cast(this) ); - } - catch( const uno::Exception& ) - {} if ( bComplete ) { @@ -661,14 +644,8 @@ void DocumentHolder::CloseDocument() void DocumentHolder::CloseFrame() { - try - { - uno::Reference< util::XCloseBroadcaster > xBroadcaster( - m_xFrame, uno::UNO_QUERY_THROW ); + if (auto xBroadcaster = m_xFrame.query() ) xBroadcaster->removeCloseListener( static_cast(this) ); - } - catch( const uno::Exception& ) - {} uno::Reference xCloseable( m_xFrame,uno::UNO_QUERY); -- cgit