1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 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.
*/
virtual ~PLT_ThreadTask();
private:
NPT_Result StartThread();
// NPT_Thread methods
void Run();
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_ */
|