1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <tools/TimerBasedTaskExecution.hxx>
21 #include <tools/AsynchronousTask.hxx>
22 #include <tools/time.hxx>
23 #include <sal/log.hxx>
29 /** Used by the shared_ptr instead of the private destructor.
31 class TimerBasedTaskExecution::Deleter
34 void operator() (TimerBasedTaskExecution
* pObject
)
40 std::shared_ptr
<TimerBasedTaskExecution
> TimerBasedTaskExecution::Create (
41 const std::shared_ptr
<AsynchronousTask
>& rpTask
,
42 sal_uInt32 nMillisecondsBetweenSteps
,
43 sal_uInt32 nMaxTimePerStep
)
45 std::shared_ptr
<TimerBasedTaskExecution
> pExecution(
46 new TimerBasedTaskExecution(rpTask
,nMillisecondsBetweenSteps
,nMaxTimePerStep
),
48 // Let the new object have a shared_ptr to itself, so that it can
49 // release itself when the AsynchronousTask has been executed
51 if (pExecution
->mpTask
!= nullptr)
52 pExecution
->mpSelf
= pExecution
;
56 void TimerBasedTaskExecution::Release()
63 void TimerBasedTaskExecution::ReleaseTask (
64 const std::weak_ptr
<TimerBasedTaskExecution
>& rpExecution
)
66 if ( rpExecution
.expired())
71 std::shared_ptr
<tools::TimerBasedTaskExecution
> pExecution (rpExecution
);
72 pExecution
->Release();
74 catch (const std::bad_weak_ptr
&)
76 // When a bad_weak_ptr has been thrown then the object pointed
77 // to by rpTask has been released right after we checked that it
78 // still existed. Too bad, but that means, that we have nothing
83 TimerBasedTaskExecution::TimerBasedTaskExecution (
84 std::shared_ptr
<AsynchronousTask
> pTask
,
85 sal_uInt32 nMillisecondsBetweenSteps
,
86 sal_uInt32 nMaxTimePerStep
)
87 : mpTask(std::move(pTask
)),
88 maTimer("sd TimerBasedTaskExecution maTimer"),
89 mnMaxTimePerStep(nMaxTimePerStep
)
91 maTimer
.SetInvokeHandler( LINK(this,TimerBasedTaskExecution
,TimerCallback
) );
92 maTimer
.SetTimeout(nMillisecondsBetweenSteps
);
96 TimerBasedTaskExecution::~TimerBasedTaskExecution()
101 IMPL_LINK_NOARG(TimerBasedTaskExecution
, TimerCallback
, Timer
*, void)
103 if (mpTask
== nullptr)
106 if (mpTask
->HasNextStep())
108 // Execute as many steps as fit into the time span of length
109 // mnMaxTimePerStep. Note that the last step may take longer
111 sal_uInt32
nStartTime (::tools::Time( ::tools::Time::SYSTEM
).GetMSFromTime());
112 SAL_INFO("sd.tools", __func__
<< ": starting TimerBasedTaskExecution at " << nStartTime
);
115 mpTask
->RunNextStep();
116 sal_uInt32
nDuration (::tools::Time( ::tools::Time::SYSTEM
).GetMSFromTime()-nStartTime
);
117 SAL_INFO("sd.tools", __func__
<< ": executed step in " << nDuration
);
118 if (nDuration
> mnMaxTimePerStep
)
121 while (mpTask
->HasNextStep());
122 SAL_INFO("sd.tools", __func__
<< ": TimerBasedTaskExecution sleeping");
129 } // end of namespace ::sd::tools
131 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */