diff options
author | Michael Meeks <michael.meeks@suse.com> | 2013-01-28 20:03:20 +1100 |
---|---|---|
committer | Michael Meeks <michael.meeks@suse.com> | 2013-01-28 21:25:44 +1100 |
commit | 58b05ce98e72fe47bdca02d2dabea20c36a494bf (patch) | |
tree | 8ec43554d84030f893fee91d8335e9cbc05e90aa /slideshow | |
parent | f99e540897103b6af3bb6b6c5a36e0a77f35b706 (diff) |
fdo#59881 - sdremote: give up on threaded / UNO usage.
Process incoming commands in the main thread in a Timeout, build
thumbnail / previews there too - to avoid the deadlocks mentioned
in the bug.
Change-Id: I5f5e8d6fbc2e059d4194f72f3e086e1aa87ab2cc
Diffstat (limited to 'slideshow')
-rw-r--r-- | slideshow/source/engine/slideshowimpl.cxx | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/slideshow/source/engine/slideshowimpl.cxx b/slideshow/source/engine/slideshowimpl.cxx index cf672ae296ac..d3cdbbea6ae7 100644 --- a/slideshow/source/engine/slideshowimpl.cxx +++ b/slideshow/source/engine/slideshowimpl.cxx @@ -2131,7 +2131,7 @@ sal_Bool SlideShowImpl::update( double & nNextTimeout ) void SlideShowImpl::notifySlideTransitionEnded( bool bPaintSlide ) { - osl::MutexGuard const guard( m_aMutex ); + osl::ResettableMutexGuard guard( m_aMutex ); OSL_ENSURE( !isDisposed(), "### already disposed!" ); OSL_ENSURE( mpCurrentSlide, @@ -2144,6 +2144,10 @@ void SlideShowImpl::notifySlideTransitionEnded( bool bPaintSlide ) // the chance to register SlideStartEvents const bool bBackgroundLayerRendered( !bPaintSlide ); mpCurrentSlide->show( bBackgroundLayerRendered ); + + uno::Reference<presentation::XSlideShow> xThis( + static_cast< presentation::XSlideShow * >( this ), uno::UNO_QUERY_THROW ); + guard.reset(); // unlock maEventMultiplexer.notifySlideStartEvent(); } } |