diff options
author | Noel Grandin <noel.grandin@collabora.co.uk> | 2023-10-26 11:40:24 +0200 |
---|---|---|
committer | Noel Grandin <noel.grandin@collabora.co.uk> | 2023-10-26 16:10:29 +0200 |
commit | 0446f73d27a0c43de1a2d5e07c9510a287be6af2 (patch) | |
tree | ce2ff16f0809c5e3aec25c1d177e45156d784b31 /test | |
parent | 455a1775ccef305cfb96cc5f67c8ee47b7f3a2ae (diff) |
tdf#153519 use new IdleTask::waitUntilIdleDispatched
to wait until the Idle inside sw/ has done populating the navigator
tree.
Which required
(*) moving the code down from test/ to vcl/ to avoid circular dependency
issues.
(*) adding a call SolarMutexGuard before Application::Yield inside
IdleTask::waitUntilIdleDispatched
(*) exposing the function to python by adding a method to the
XToolkitExperimental UNO API
Change-Id: Iee418f7a0beb1f5b53addb7fe25823d61720eb3a
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/158495
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Diffstat (limited to 'test')
-rw-r--r-- | test/Library_test.mk | 1 | ||||
-rw-r--r-- | test/source/idletask.cxx | 50 |
2 files changed, 0 insertions, 51 deletions
diff --git a/test/Library_test.mk b/test/Library_test.mk index 951ddf6edab2..268a68744eaf 100644 --- a/test/Library_test.mk +++ b/test/Library_test.mk @@ -50,7 +50,6 @@ $(eval $(call gb_Library_add_exception_objects,test,\ test/source/callgrind \ test/source/xmltesttools \ test/source/htmltesttools \ - test/source/idletask \ test/source/screenshot_test \ test/source/unoapi_property_testers \ test/source/lokcallback \ diff --git a/test/source/idletask.cxx b/test/source/idletask.cxx deleted file mode 100644 index 904d98eb1e24..000000000000 --- a/test/source/idletask.cxx +++ /dev/null @@ -1,50 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ - -#include <test/idletask.hxx> -#include <vcl/svapp.hxx> - -//constructor of IdleTask Class -IdleTask::IdleTask() - : flag(false) -{ - //setting the Priority of Idle task to LOW, LOWEST - maIdle.SetPriority(TaskPriority::LOWEST); - //set idle for callback - maIdle.SetInvokeHandler(LINK(this, IdleTask, FlipFlag)); - //starting the idle - maIdle.Start(); -} - -//GetFlag() of IdleTask Class -bool IdleTask::GetFlag() const -{ - //returning the status of current flag - return flag; -} - -//Callback function of IdleTask Class -IMPL_LINK(IdleTask, FlipFlag, Timer*, , void) -{ - //setting the flag to make sure that low priority idle task has been dispatched - flag = true; -} - -void IdleTask::waitUntilIdleDispatched() -{ - //creating instance of IdleTask Class - IdleTask idleTask; - while (!idleTask.GetFlag()) - { - //dispatching all the events via VCL main-loop - Application::Yield(); - } -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */ |