summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--salhelper/source/timer.cxx98
1 files changed, 41 insertions, 57 deletions
diff --git a/salhelper/source/timer.cxx b/salhelper/source/timer.cxx
index a43078dade97..3757ea9a2cdc 100644
--- a/salhelper/source/timer.cxx
+++ b/salhelper/source/timer.cxx
@@ -17,9 +17,9 @@
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include <salhelper/timer.hxx>
+#include <salhelper/simplereferenceobject.hxx>
#include <osl/diagnose.h>
-#include <salhelper/simplereferenceobject.hxx>
#include <osl/thread.hxx>
#include <osl/conditn.hxx>
#include <osl/mutex.hxx>
@@ -29,13 +29,9 @@ using namespace salhelper;
class salhelper::TimerManager : public osl::Thread
{
-
public:
-
-
TimerManager();
-
virtual ~TimerManager() override;
/// register timer
@@ -50,55 +46,49 @@ public:
/// retrieves the "Singleton" TimerManager Instance
static TimerManager* SAL_CALL getTimerManager();
-
protected:
-
/// worker-function of thread
virtual void SAL_CALL run() override;
- // Checking and triggering of a timer event
+ /// Checking and triggering of a timer event
void SAL_CALL checkForTimeout();
- // cleanup Method
+ /// cleanup Method
virtual void SAL_CALL onTerminated() override;
- // sorted-queue data
+ /// sorted-queue data
salhelper::Timer* m_pHead;
- // List Protection
+ /// List Protection
osl::Mutex m_Lock;
- // Signal the insertion of a timer
+ /// Signal the insertion of a timer
osl::Condition m_notEmpty;
- // "Singleton Pattern"
+ /// "Singleton Pattern"
static salhelper::TimerManager* m_pManager;
};
-
-// Timer class
-
-
Timer::Timer()
- : m_aTimeOut( 0 ),
- m_aExpired( 0 ),
- m_aRepeatDelta( 0 ),
- m_pNext( nullptr )
+ : m_aTimeOut(0),
+ m_aExpired(0),
+ m_aRepeatDelta(0),
+ m_pNext(nullptr)
{
}
-Timer::Timer( const TTimeValue& rTime )
- : m_aTimeOut( rTime ),
- m_aExpired( 0 ),
- m_aRepeatDelta( 0 ),
- m_pNext( nullptr )
+Timer::Timer(const TTimeValue& rTime)
+ : m_aTimeOut(rTime),
+ m_aExpired(0),
+ m_aRepeatDelta(0),
+ m_pNext(nullptr)
{
}
-Timer::Timer( const TTimeValue& rTime, const TTimeValue& Repeat )
- : m_aTimeOut( rTime ),
- m_aExpired( 0 ),
- m_aRepeatDelta( Repeat ),
- m_pNext( nullptr )
+Timer::Timer(const TTimeValue& rTime, const TTimeValue& Repeat)
+ : m_aTimeOut(rTime),
+ m_aExpired(0),
+ m_aRepeatDelta(Repeat),
+ m_pNext(nullptr)
{
}
@@ -109,16 +99,16 @@ Timer::~Timer()
void Timer::start()
{
- if (! isTicking())
+ if (!isTicking())
{
- if (! m_aTimeOut.isEmpty())
+ if (!m_aTimeOut.isEmpty())
setRemainingTime(m_aTimeOut);
TimerManager *pManager = TimerManager::getTimerManager();
OSL_ASSERT(pManager);
- if ( pManager != nullptr )
+ if (pManager != nullptr)
{
pManager->registerTimer(this);
}
@@ -131,7 +121,7 @@ void Timer::stop()
OSL_ASSERT(pManager);
- if ( pManager != nullptr )
+ if (pManager != nullptr)
{
pManager->unregisterTimer(this);
}
@@ -163,7 +153,7 @@ sal_Bool Timer::expiresBefore(const Timer* pTimer) const
{
OSL_ASSERT(pTimer);
- if ( pTimer != nullptr )
+ if (pTimer != nullptr)
{
return m_aExpired < pTimer->m_aExpired;
}
@@ -175,8 +165,8 @@ sal_Bool Timer::expiresBefore(const Timer* pTimer) const
void Timer::setAbsoluteTime(const TTimeValue& Time)
{
- m_aTimeOut = 0;
- m_aExpired = Time;
+ m_aTimeOut = 0;
+ m_aExpired = Time;
m_aRepeatDelta = 0;
m_aExpired.normalize();
@@ -230,9 +220,6 @@ TTimeValue Timer::getRemainingTime() const
return TTimeValue(secs, nsecs);
}
-
-// Timer manager
-
namespace
{
// Synchronize access to TimerManager
@@ -241,6 +228,16 @@ namespace
TimerManager* salhelper::TimerManager::m_pManager = nullptr;
+/** The timer manager cleanup has been removed (no thread is killed anymore),
+ so the thread leaks.
+
+ This will result in a GPF in case the salhelper-library gets unloaded before
+ process termination.
+
+ @TODO : rewrite this file, so that the timerManager thread gets destroyed,
+ when there are no timers anymore !
+**/
+
TimerManager::TimerManager()
{
osl::MutexGuard Guard(theTimerManagerMutex::get());
@@ -267,7 +264,7 @@ TimerManager::~TimerManager()
void TimerManager::onTerminated()
{
- delete this; // mfe: AAARRRGGGHHH!!!
+ delete this; // FIXME
}
TimerManager* TimerManager::getTimerManager()
@@ -423,9 +420,8 @@ void TimerManager::run()
while (schedule())
{
- TTimeValue delay;
- TTimeValue* pDelay=nullptr;
-
+ TTimeValue delay;
+ TTimeValue* pDelay=nullptr;
m_Lock.acquire();
@@ -452,16 +448,4 @@ void TimerManager::run()
}
-
-// Timer manager cleanup
-
-
-// jbu:
-// The timer manager cleanup has been removed (no thread is killed anymore).
-// So the thread leaks.
-// This will result in a GPF in case the salhelper-library gets unloaded before
-// process termination.
-// -> TODO : rewrite this file, so that the timerManager thread gets destroyed,
-// when there are no timers anymore !
-
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */