diff options
author | Jan-Marek Glogowski <glogow@fbihome.de> | 2018-08-28 15:24:26 +0000 |
---|---|---|
committer | Jan-Marek Glogowski <glogow@fbihome.de> | 2018-08-29 10:10:14 +0200 |
commit | 3bd8316718fdfed454c01a9c4ae6af6beb34437d (patch) | |
tree | c5057b2633582bb4b076795fcda534b4497ee6e3 /sw | |
parent | b406744b8f2af5ea4e2440df62caa0f896efa2f4 (diff) |
tdf#119458 just wakeup Scheduler on active Idle
So this almost returns the code to the original state, before I
started fixing tdf#116370... a long way. This introduces the new
Scheduler::Wakeup() function, which will just queue a Scheduler
event in the System event queue unconditionally.
This should prevent fdo#73165, which I couldn't reproduce, but
just to be sure.
More importantly this patch resets the m_bStartOnUnblock when
the Idle job actually runs. This run should already determinates
if more Idle work needs to be done, and others can still call
BeginIdling() to ensure further processing.
This also drops the IsBusyDoc() test from UnblockIdling(). We
can't really know, if the document is still busy when the
Scheduler is finally running, be it by the system timer or
Application::Reschedule().
Change-Id: I6cc4a3c48dcaf62b6985c7bc1c95c96697443f3b
Reviewed-on: https://gerrit.libreoffice.org/59730
Tested-by: Jenkins
Reviewed-by: Jan-Marek Glogowski <glogow@fbihome.de>
Diffstat (limited to 'sw')
-rw-r--r-- | sw/source/core/doc/DocumentTimerManager.cxx | 25 |
1 files changed, 13 insertions, 12 deletions
diff --git a/sw/source/core/doc/DocumentTimerManager.cxx b/sw/source/core/doc/DocumentTimerManager.cxx index 81c46b125840..7bd2e505a3a4 100644 --- a/sw/source/core/doc/DocumentTimerManager.cxx +++ b/sw/source/core/doc/DocumentTimerManager.cxx @@ -33,6 +33,7 @@ #include <docsh.hxx> #include <docfld.hxx> #include <fldbas.hxx> +#include <vcl/scheduler.hxx> namespace sw { @@ -49,10 +50,14 @@ DocumentTimerManager::DocumentTimerManager( SwDoc& i_rSwdoc ) : m_rDoc( i_rSwdoc void DocumentTimerManager::StartIdling() { - if (m_nIdleBlockCount > 0) - m_bStartOnUnblock = true; - else if (!m_aDocIdle.IsActive()) - m_aDocIdle.Start(); + m_bStartOnUnblock = true; + if (0 == m_nIdleBlockCount) + { + if (!m_aDocIdle.IsActive()) + m_aDocIdle.Start(); + else + Scheduler::Wakeup(); + } } void DocumentTimerManager::StopIdling() @@ -64,11 +69,6 @@ void DocumentTimerManager::StopIdling() void DocumentTimerManager::BlockIdling() { assert(SAL_MAX_UINT32 != m_nIdleBlockCount); - if (0 == m_nIdleBlockCount) - { - assert(!m_bStartOnUnblock); - m_bStartOnUnblock = false; - } ++m_nIdleBlockCount; } @@ -79,10 +79,10 @@ void DocumentTimerManager::UnblockIdling() if ((0 == m_nIdleBlockCount) && m_bStartOnUnblock) { - m_bStartOnUnblock = false; - // kick the active idle, if it's not anymore blocked by IsDocIdle() - if (IsDocIdle()) + if (!m_aDocIdle.IsActive()) m_aDocIdle.Start(); + else + Scheduler::Wakeup(); } } @@ -137,6 +137,7 @@ IMPL_LINK_NOARG( DocumentTimerManager, DoIdleJobs, Timer*, void ) pModLogFile = new ::rtl::Logfile( "First DoIdleJobs" ); #endif BlockIdling(); + StopIdling(); IdleJob eJob = GetNextIdleJob(); |