Files
@ r23438:07a061c5b9ef
Branch filter:
Location: cpp/openttd-patchpack/source/src/thread/thread.h - annotation
r23438:07a061c5b9ef
3.6 KiB
text/x-c
Fix: [AzurePipelines] don't assume master as target branch when rebasing PRs
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 | r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r17624:f2c5f47dceaa r12839:daeca5b0e6db r12839:daeca5b0e6db r17624:f2c5f47dceaa r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r19944:25a78576fb5e r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r22463:71520ac0d007 r12839:daeca5b0e6db r12839:daeca5b0e6db r22463:71520ac0d007 r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r17624:f2c5f47dceaa r17624:f2c5f47dceaa r17624:f2c5f47dceaa r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r21261:35860f07395a r21261:35860f07395a r21261:35860f07395a r12839:daeca5b0e6db r21261:35860f07395a r12839:daeca5b0e6db r12839:daeca5b0e6db r12839:daeca5b0e6db r21261:35860f07395a r21261:35860f07395a r21261:35860f07395a r12839:daeca5b0e6db r21261:35860f07395a r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r13257:4c5b8120be59 r12839:daeca5b0e6db r12839:daeca5b0e6db r18624:af0d406ed005 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r21254:27c879c32e92 r18624:af0d406ed005 r18624:af0d406ed005 r18624:af0d406ed005 r18624:af0d406ed005 r18624:af0d406ed005 r12839:daeca5b0e6db | /* $Id$ */
/*
* This file is part of OpenTTD.
* OpenTTD 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, version 2.
* OpenTTD 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 OpenTTD. If not, see <http://www.gnu.org/licenses/>.
*/
/** @file thread.h Base of all threads. */
#ifndef THREAD_H
#define THREAD_H
/** Definition of all thread entry functions. */
typedef void (*OTTDThreadFunc)(void *);
/** Signal used for signalling we knowingly want to end the thread. */
class OTTDThreadExitSignal { };
/**
* A Thread Object which works on all our supported OSes.
*/
class ThreadObject {
public:
/**
* Virtual destructor to allow 'delete' operator to work properly.
*/
virtual ~ThreadObject() {};
/**
* Exit this thread.
*/
virtual bool Exit() = 0;
/**
* Join this thread.
*/
virtual void Join() = 0;
/**
* Create a thread; proc will be called as first function inside the thread,
* with optional params.
* @param proc The procedure to call inside the thread.
* @param param The params to give with 'proc'.
* @param thread Place to store a pointer to the thread in. May be NULL.
* @param name A name for the thread. May be NULL.
* @return True if the thread was started correctly.
*/
static bool New(OTTDThreadFunc proc, void *param, ThreadObject **thread = NULL, const char *name = NULL);
};
/**
* Cross-platform Mutex
*/
class ThreadMutex {
public:
/**
* Create a new mutex.
*/
static ThreadMutex *New();
/**
* Virtual Destructor to avoid compiler warnings.
*/
virtual ~ThreadMutex() {};
/**
* Begin the critical section
* @param allow_recursive Whether recursive locking is intentional.
* If false, NOT_REACHED() will be called when the mutex is already locked
* by the current thread.
*/
virtual void BeginCritical(bool allow_recursive = false) = 0;
/**
* End of the critical section
* @param allow_recursive Whether recursive unlocking is intentional.
* If false, NOT_REACHED() will be called when the mutex was locked more
* than once by the current thread.
*/
virtual void EndCritical(bool allow_recursive = false) = 0;
/**
* Wait for a signal to be send.
* @pre You must be in the critical section.
* @note While waiting the critical section is left.
* @post You will be in the critical section.
*/
virtual void WaitForSignal() = 0;
/**
* Send a signal and wake the 'thread' that was waiting for it.
*/
virtual void SendSignal() = 0;
};
/**
* Simple mutex locker to keep a mutex locked until the locker goes out of scope.
*/
class ThreadMutexLocker {
public:
/**
* Lock the mutex and keep it locked for the life time of this object.
* @param mutex Mutex to be locked.
*/
ThreadMutexLocker(ThreadMutex *mutex) : mutex(mutex) { mutex->BeginCritical(); }
/**
* Unlock the mutex.
*/
~ThreadMutexLocker() { this->mutex->EndCritical(); }
private:
ThreadMutexLocker(const ThreadMutexLocker &) { NOT_REACHED(); }
ThreadMutexLocker &operator=(const ThreadMutexLocker &) { NOT_REACHED(); return *this; }
ThreadMutex *mutex;
};
/**
* Get number of processor cores in the system, including HyperThreading or similar.
* @return Total number of processor cores.
*/
uint GetCPUCoreCount();
#endif /* THREAD_H */
|