summaryrefslogtreecommitdiffstats
path: root/lib/libUPnP/Platinum/Source/Core/PltThreadTask.h
blob: 49bda3d24d7be4e092c9bcb447a64ab06d4dedd2 (plain)
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.
     */
    ~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_ */