Upstream tarball 20080901
[amule.git] / src / MuleThread.h
blobaf39da532e86df942f7d7bd0d62b82dfaf534f3e
1 //
2 // This file is part of the aMule Project.
3 //
4 // Copyright (c) 2008 aMule Team ( admin@amule.org / http://www.amule.org )
5 //
6 // Any parts of this program derived from the xMule, lMule or eMule project,
7 // or contributed by third-party developers are copyrighted by their
8 // respective authors.
9 //
10 // This program is free software; you can redistribute it and/or modify
11 // it under the terms of the GNU General Public License as published by
12 // the Free Software Foundation; either version 2 of the License, or
13 // (at your option) any later version.
15 // This program is distributed in the hope that it will be useful,
16 // but WITHOUT ANY WARRANTY; without even the implied warranty of
17 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 // GNU General Public License for more details.
19 //
20 // You should have received a copy of the GNU General Public License
21 // along with this program; if not, write to the Free Software
22 // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
25 #ifndef MULETHREAD_H
26 #define MULETHREAD_H
28 #include <wx/thread.h>
31 class CMuleThread : public wxThread
33 public:
34 //! @see wxThread::wxThread
35 CMuleThread(wxThreadKind kind = wxTHREAD_DETACHED);
37 /**
38 * Stops the thread.
40 * For detached threads, this function is equivalent
41 * to Delete, but is also useable for joinable threads,
42 * where Delete should not be used, due to crashes
43 * experienced in that case. In the case of joinable
44 * threads, Wait is called rather than Delete.
46 * @see wxThread::Delete
48 void Stop();
50 //! Returns true if Delete or Stop has been called.
51 virtual bool TestDestroy();
52 private:
53 //! Is set if Stop is called.
54 bool m_stop;
59 ////////////////////////////////////////////////////////////
60 // Implementations
62 inline CMuleThread::CMuleThread(wxThreadKind kind)
63 : wxThread(kind)
64 , m_stop(false)
69 inline void CMuleThread::Stop()
71 m_stop = true;
72 if (IsDetached()) {
73 Delete();
74 } else {
75 Wait();
80 inline bool CMuleThread::TestDestroy()
82 // m_stop is checked last, because some functionality is
83 // dependant upon wxThread::TestDestroy() being called,
84 // for instance Pause().
85 return wxThread::TestDestroy() || m_stop;
88 #endif