summaryrefslogtreecommitdiffstats
path: root/lib/libUPnP/Platinum/Source/Core/PltThreadTask.h
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libUPnP/Platinum/Source/Core/PltThreadTask.h')
-rw-r--r--lib/libUPnP/Platinum/Source/Core/PltThreadTask.h140
1 files changed, 140 insertions, 0 deletions
diff --git a/lib/libUPnP/Platinum/Source/Core/PltThreadTask.h b/lib/libUPnP/Platinum/Source/Core/PltThreadTask.h
new file mode 100644
index 0000000..49bda3d
--- /dev/null
+++ b/lib/libUPnP/Platinum/Source/Core/PltThreadTask.h
@@ -0,0 +1,140 @@
+/*****************************************************************
+|
+| Platinum - Thread Tasks
+|
+| Copyright (c) 2004-2010, Plutinosoft, LLC.
+| All rights reserved.
+| http://www.plutinosoft.com
+|
+| This program is free software; you can redistribute it and/or
+| modify it under the terms of the GNU General Public License
+| as published by the Free Software Foundation; either version 2
+| of the License, or (at your option) any later version.
+|
+| OEMs, ISVs, VARs and other distributors that combine and
+| distribute commercially licensed software with Platinum software
+| and do not wish to distribute the source code for the commercially
+| licensed software under version 2, or (at your option) any later
+| version, of the GNU General Public License (the "GPL") must enter
+| into a commercial license agreement with Plutinosoft, LLC.
+| licensing@plutinosoft.com
+|
+| This program is distributed in the hope that it will be useful,
+| but WITHOUT ANY WARRANTY; without even the implied warranty of
+| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+| GNU General Public License for more details.
+|
+| You should have received a copy of the GNU General Public License
+| along with this program; see the file LICENSE.txt. If not, write to
+| the Free Software Foundation, Inc.,
+| 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+| http://www.gnu.org/licenses/gpl-2.0.html
+|
+****************************************************************/
+
+/** @file
+ Runnable Task
+ */
+
+#ifndef _PLT_THREADTASK_H_
+#define _PLT_THREADTASK_H_
+
+/*----------------------------------------------------------------------
+| includes
++---------------------------------------------------------------------*/
+#include "Neptune.h"
+#include "PltTaskManager.h"
+
+/*----------------------------------------------------------------------
+| PLT_ThreadTask class
++---------------------------------------------------------------------*/
+/**
+ The PLT_ThreadTask class is a base class for executing a given task in a worker
+ thread. A PLT_ThreadTask is usually always associated to a PLT_TaskManager
+ which maintains a list to stop and destroy tasks when finished.
+ */
+class PLT_ThreadTask : public NPT_Runnable
+{
+public:
+ friend class PLT_TaskManager;
+
+ /**
+ When a task is not managed by a PLT_TaskManager, the owner must call
+ this to stop and destroy it.
+ */
+ NPT_Result Kill();
+
+protected:
+ /**
+ Return whether this task is in the process of stopping.
+ @param timeout number of milliseconds to wait
+ @return boolean indicating if the task is stopping
+ */
+ virtual bool IsAborting(NPT_Timeout timeout) {
+ return NPT_SUCCEEDED(m_Abort.WaitUntilEquals(1, timeout));
+ }
+
+ /**
+ Start a task by associating it with a task manager.
+ @param task_manager PLT_TaskManager pointer
+ @param delay optional time interval to wait before launching the new task
+ @param auto_destroy a flag to indicate if the task is owned by someone else
+ and thus should not destroy itself when done.
+ */
+ NPT_Result Start(PLT_TaskManager* task_manager = NULL,
+ NPT_TimeInterval* delay = NULL,
+ bool auto_destroy = true);
+ /**
+ Stop the task. This is either called by a task manager or the Kill method.
+ @param blocking Whether the method should block until the task has finished.
+ */
+ NPT_Result Stop(bool blocking = true);
+
+ /**
+ This method to override in derived classes is called when the task is about
+ to start.
+ */
+ virtual void DoInit() {}
+
+ /**
+ This method to override in derived classes is called when the task is about
+ to stop.
+ */
+ virtual void DoAbort() {}
+
+ /**
+ This method to override in derived classes is the main task loop.
+ */
+ virtual void DoRun() {}
+
+ /**
+ A PLT_ThreadTask base class is never instantiated directly.
+ */
+ PLT_ThreadTask();
+
+ /**
+ The task manager will destroy the task when finished if m_AutoDestroy is
+ true otherwise the owner of this task must use the Kill method.
+ */
+ ~PLT_ThreadTask() override;
+
+private:
+ NPT_Result StartThread();
+
+ // NPT_Thread methods
+ void Run() override;
+
+protected:
+ // members
+ PLT_TaskManager* m_TaskManager;
+
+private:
+ // members
+ NPT_SharedVariable m_Started;
+ NPT_SharedVariable m_Abort;
+ NPT_Thread* m_Thread;
+ bool m_AutoDestroy;
+ NPT_TimeInterval m_Delay;
+};
+
+#endif /* _PLT_THREADTASK_H_ */