mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-26 18:42:41 +01:00 
			
		
		
		
	fix indentation
This commit is contained in:
		| @@ -55,222 +55,222 @@ class Foundation_API Thread: private ThreadImpl | ||||
| /// The name of a thread can be changed at any time. | ||||
| { | ||||
| public: | ||||
|     typedef ThreadImpl::TIDImpl TID; | ||||
| 	typedef ThreadImpl::TIDImpl TID; | ||||
|  | ||||
|     using ThreadImpl::Callable; | ||||
| 	using ThreadImpl::Callable; | ||||
|  | ||||
|     enum Priority | ||||
|     /// Thread priorities. | ||||
|     { | ||||
|         PRIO_LOWEST  = PRIO_LOWEST_IMPL, /// The lowest thread priority. | ||||
|         PRIO_LOW     = PRIO_LOW_IMPL,    /// A lower than normal thread priority. | ||||
|         PRIO_NORMAL  = PRIO_NORMAL_IMPL, /// The normal thread priority. | ||||
|         PRIO_HIGH    = PRIO_HIGH_IMPL,   /// A higher than normal thread priority. | ||||
|         PRIO_HIGHEST = PRIO_HIGHEST_IMPL /// The highest thread priority. | ||||
|     }; | ||||
| 	enum Priority | ||||
| 	/// Thread priorities. | ||||
| 	{ | ||||
| 		PRIO_LOWEST  = PRIO_LOWEST_IMPL, /// The lowest thread priority. | ||||
| 		PRIO_LOW     = PRIO_LOW_IMPL,    /// A lower than normal thread priority. | ||||
| 		PRIO_NORMAL  = PRIO_NORMAL_IMPL, /// The normal thread priority. | ||||
| 		PRIO_HIGH    = PRIO_HIGH_IMPL,   /// A higher than normal thread priority. | ||||
| 		PRIO_HIGHEST = PRIO_HIGHEST_IMPL /// The highest thread priority. | ||||
| 	}; | ||||
|  | ||||
|     enum Policy | ||||
|     { | ||||
|         POLICY_DEFAULT = POLICY_DEFAULT_IMPL | ||||
|     }; | ||||
| 	enum Policy | ||||
| 	{ | ||||
| 		POLICY_DEFAULT = POLICY_DEFAULT_IMPL | ||||
| 	}; | ||||
|  | ||||
|     Thread(); | ||||
|     /// Creates a thread. Call start() to start it. | ||||
| 	Thread(); | ||||
| 	/// Creates a thread. Call start() to start it. | ||||
|  | ||||
|     Thread(const std::string& name); | ||||
|     /// Creates a named thread. Call start() to start it. | ||||
| 	Thread(const std::string& name); | ||||
| 	/// Creates a named thread. Call start() to start it. | ||||
|  | ||||
|     ~Thread(); | ||||
|     /// Destroys the thread. | ||||
| 	~Thread(); | ||||
| 	/// Destroys the thread. | ||||
|  | ||||
|     int id() const; | ||||
|     /// Returns the unique thread ID of the thread. | ||||
| 	int id() const; | ||||
| 	/// Returns the unique thread ID of the thread. | ||||
|  | ||||
|     TID tid() const; | ||||
|     /// Returns the native thread ID of the thread. | ||||
| 	TID tid() const; | ||||
| 	/// Returns the native thread ID of the thread. | ||||
|  | ||||
|     std::string name() const; | ||||
|     /// Returns the name of the thread. | ||||
| 	std::string name() const; | ||||
| 	/// Returns the name of the thread. | ||||
|  | ||||
|     std::string getName() const; | ||||
|     /// Returns the name of the thread. | ||||
| 	std::string getName() const; | ||||
| 	/// Returns the name of the thread. | ||||
|  | ||||
|     void setName(const std::string& name); | ||||
|     /// Sets the name of the thread. | ||||
| 	void setName(const std::string& name); | ||||
| 	/// Sets the name of the thread. | ||||
|  | ||||
|     void setPriority(Priority prio); | ||||
|     /// Sets the thread's priority. | ||||
|     /// | ||||
|     /// Some platform only allow changing a thread's priority | ||||
|     /// if the process has certain privileges. | ||||
| 	void setPriority(Priority prio); | ||||
| 	/// Sets the thread's priority. | ||||
| 	/// | ||||
| 	/// Some platform only allow changing a thread's priority | ||||
| 	/// if the process has certain privileges. | ||||
|  | ||||
|     Priority getPriority() const; | ||||
|     /// Returns the thread's priority. | ||||
| 	Priority getPriority() const; | ||||
| 	/// Returns the thread's priority. | ||||
|  | ||||
|     void setOSPriority(int prio, int policy = POLICY_DEFAULT); | ||||
|     /// Sets the thread's priority, using an operating system specific | ||||
|     /// priority value. Use getMinOSPriority() and getMaxOSPriority() to | ||||
|     /// obtain mininum and maximum priority values. Additionally, | ||||
|     /// a scheduling policy can be specified. The policy is currently | ||||
|     /// only used on POSIX platforms where the values SCHED_OTHER (default), | ||||
|     /// SCHED_FIFO and SCHED_RR are supported. | ||||
| 	void setOSPriority(int prio, int policy = POLICY_DEFAULT); | ||||
| 	/// Sets the thread's priority, using an operating system specific | ||||
| 	/// priority value. Use getMinOSPriority() and getMaxOSPriority() to | ||||
| 	/// obtain mininum and maximum priority values. Additionally, | ||||
| 	/// a scheduling policy can be specified. The policy is currently | ||||
| 	/// only used on POSIX platforms where the values SCHED_OTHER (default), | ||||
| 	/// SCHED_FIFO and SCHED_RR are supported. | ||||
|  | ||||
|     int getOSPriority() const; | ||||
|     /// Returns the thread's priority, expressed as an operating system | ||||
|     /// specific priority value. | ||||
|     /// | ||||
|     /// May return 0 if the priority has not been explicitly set. | ||||
| 	int getOSPriority() const; | ||||
| 	/// Returns the thread's priority, expressed as an operating system | ||||
| 	/// specific priority value. | ||||
| 	/// | ||||
| 	/// May return 0 if the priority has not been explicitly set. | ||||
|  | ||||
|     static int getMinOSPriority(int policy = POLICY_DEFAULT); | ||||
|     /// Returns the minimum operating system-specific priority value, | ||||
|     /// which can be passed to setOSPriority() for the given policy. | ||||
| 	static int getMinOSPriority(int policy = POLICY_DEFAULT); | ||||
| 	/// Returns the minimum operating system-specific priority value, | ||||
| 	/// which can be passed to setOSPriority() for the given policy. | ||||
|  | ||||
|     static int getMaxOSPriority(int policy = POLICY_DEFAULT); | ||||
|     /// Returns the maximum operating system-specific priority value, | ||||
|     /// which can be passed to setOSPriority() for the given policy. | ||||
| 	static int getMaxOSPriority(int policy = POLICY_DEFAULT); | ||||
| 	/// Returns the maximum operating system-specific priority value, | ||||
| 	/// which can be passed to setOSPriority() for the given policy. | ||||
|  | ||||
|     void setStackSize(int size); | ||||
|     /// Sets the thread's stack size in bytes. | ||||
|     /// Setting the stack size to 0 will use the default stack size. | ||||
|     /// Typically, the real stack size is rounded up to the nearest | ||||
|     /// page size multiple. | ||||
| 	void setStackSize(int size); | ||||
| 	/// Sets the thread's stack size in bytes. | ||||
| 	/// Setting the stack size to 0 will use the default stack size. | ||||
| 	/// Typically, the real stack size is rounded up to the nearest | ||||
| 	/// page size multiple. | ||||
|  | ||||
|     void setAffinity(unsigned int cpu); | ||||
|     /// Limit specified thread to run only on the processors "cpu" | ||||
|     /// cpu - processor (core) number | ||||
|     /// Method would Throw SystemException if affinity did not setted | ||||
| 	void setAffinity(unsigned int cpu); | ||||
| 	/// Limit specified thread to run only on the processors "cpu" | ||||
| 	/// cpu - processor (core) number | ||||
| 	/// Method would Throw SystemException if affinity did not setted | ||||
|  | ||||
|     unsigned getAffinity() const; | ||||
|     /// Returns using cpu (core) number | ||||
| 	unsigned getAffinity() const; | ||||
| 	/// Returns using cpu (core) number | ||||
|  | ||||
|     int getStackSize() const; | ||||
|     /// Returns the thread's stack size in bytes. | ||||
|     /// If the default stack size is used, 0 is returned. | ||||
| 	int getStackSize() const; | ||||
| 	/// Returns the thread's stack size in bytes. | ||||
| 	/// If the default stack size is used, 0 is returned. | ||||
|  | ||||
|     void start(Runnable& target); | ||||
|     /// Starts the thread with the given target. | ||||
|     /// | ||||
|     /// Note that the given Runnable object must remain | ||||
|     /// valid during the entire lifetime of the thread, as | ||||
|     /// only a reference to it is stored internally. | ||||
| 	void start(Runnable& target); | ||||
| 	/// Starts the thread with the given target. | ||||
| 	/// | ||||
| 	/// Note that the given Runnable object must remain | ||||
| 	/// valid during the entire lifetime of the thread, as | ||||
| 	/// only a reference to it is stored internally. | ||||
|  | ||||
|     void start(Callable target, void* pData = 0); | ||||
|     /// Starts the thread with the given target and parameter. | ||||
| 	void start(Callable target, void* pData = 0); | ||||
| 	/// Starts the thread with the given target and parameter. | ||||
|  | ||||
|     template <class Functor> | ||||
|     void startFunc(Functor fn) | ||||
|     /// Starts the thread with the given functor object or lambda. | ||||
|     { | ||||
|         startImpl(new FunctorRunnable<Functor>(fn)); | ||||
|     } | ||||
| 	template <class Functor> | ||||
| 	void startFunc(Functor fn) | ||||
| 	/// Starts the thread with the given functor object or lambda. | ||||
| 	{ | ||||
| 		startImpl(new FunctorRunnable<Functor>(fn)); | ||||
| 	} | ||||
|  | ||||
|     void join(); | ||||
|     /// Waits until the thread completes execution. | ||||
|     /// If multiple threads try to join the same | ||||
|     /// thread, the result is undefined. | ||||
| 	void join(); | ||||
| 	/// Waits until the thread completes execution. | ||||
| 	/// If multiple threads try to join the same | ||||
| 	/// thread, the result is undefined. | ||||
|  | ||||
|     void join(long milliseconds); | ||||
|     /// Waits for at most the given interval for the thread | ||||
|     /// to complete. Throws a TimeoutException if the thread | ||||
|     /// does not complete within the specified time interval. | ||||
| 	void join(long milliseconds); | ||||
| 	/// Waits for at most the given interval for the thread | ||||
| 	/// to complete. Throws a TimeoutException if the thread | ||||
| 	/// does not complete within the specified time interval. | ||||
|  | ||||
|     bool tryJoin(long milliseconds); | ||||
|     /// Waits for at most the given interval for the thread | ||||
|     /// to complete. Returns true if the thread has finished, | ||||
|     /// false otherwise. | ||||
| 	bool tryJoin(long milliseconds); | ||||
| 	/// Waits for at most the given interval for the thread | ||||
| 	/// to complete. Returns true if the thread has finished, | ||||
| 	/// false otherwise. | ||||
|  | ||||
|     bool isRunning() const; | ||||
|     /// Returns true if the thread is running. | ||||
| 	bool isRunning() const; | ||||
| 	/// Returns true if the thread is running. | ||||
|  | ||||
|     static bool trySleep(long milliseconds); | ||||
|     /// Starts an interruptible sleep. When trySleep() is called, | ||||
|     /// the thread will remain suspended until: | ||||
|     ///   - the timeout expires or | ||||
|     ///   - wakeUp() is called | ||||
|     /// | ||||
|     /// Function returns true if sleep attempt was completed, false | ||||
|     /// if sleep was interrupted by a wakeUp() call. | ||||
|     /// A frequent scenario where trySleep()/wakeUp() pair of functions | ||||
|     /// is useful is with threads spending most of the time idle, | ||||
|     /// with periodic activity between the idle times; trying to sleep | ||||
|     /// (as opposed to sleeping) allows immediate ending of idle thread | ||||
|     /// from the outside. | ||||
|     /// | ||||
|     /// The trySleep() and wakeUp() calls should be used with | ||||
|     /// understanding that the suspended state is not a true sleep, | ||||
|     /// but rather a state of waiting for an event, with timeout | ||||
|     /// expiration. This makes order of calls significant; calling | ||||
|     /// wakeUp() before calling trySleep() will prevent the next | ||||
|     /// trySleep() call to actually suspend the thread (which, in | ||||
|     /// some scenarios, may be desirable behavior). | ||||
| 	static bool trySleep(long milliseconds); | ||||
| 	/// Starts an interruptible sleep. When trySleep() is called, | ||||
| 	/// the thread will remain suspended until: | ||||
| 	///   - the timeout expires or | ||||
| 	///   - wakeUp() is called | ||||
| 	/// | ||||
| 	/// Function returns true if sleep attempt was completed, false | ||||
| 	/// if sleep was interrupted by a wakeUp() call. | ||||
| 	/// A frequent scenario where trySleep()/wakeUp() pair of functions | ||||
| 	/// is useful is with threads spending most of the time idle, | ||||
| 	/// with periodic activity between the idle times; trying to sleep | ||||
| 	/// (as opposed to sleeping) allows immediate ending of idle thread | ||||
| 	/// from the outside. | ||||
| 	/// | ||||
| 	/// The trySleep() and wakeUp() calls should be used with | ||||
| 	/// understanding that the suspended state is not a true sleep, | ||||
| 	/// but rather a state of waiting for an event, with timeout | ||||
| 	/// expiration. This makes order of calls significant; calling | ||||
| 	/// wakeUp() before calling trySleep() will prevent the next | ||||
| 	/// trySleep() call to actually suspend the thread (which, in | ||||
| 	/// some scenarios, may be desirable behavior). | ||||
|  | ||||
|     void wakeUp(); | ||||
|     /// Wakes up the thread which is in the state of interruptible | ||||
|     /// sleep. For threads that are not suspended, calling this | ||||
|     /// function has the effect of preventing the subsequent | ||||
|     /// trySleep() call to put thread in a suspended state. | ||||
| 	void wakeUp(); | ||||
| 	/// Wakes up the thread which is in the state of interruptible | ||||
| 	/// sleep. For threads that are not suspended, calling this | ||||
| 	/// function has the effect of preventing the subsequent | ||||
| 	/// trySleep() call to put thread in a suspended state. | ||||
|  | ||||
|     static void sleep(long milliseconds); | ||||
|     /// Suspends the current thread for the specified | ||||
|     /// amount of time. | ||||
| 	static void sleep(long milliseconds); | ||||
| 	/// Suspends the current thread for the specified | ||||
| 	/// amount of time. | ||||
|  | ||||
|     static void yield(); | ||||
|     /// Yields cpu to other threads. | ||||
| 	static void yield(); | ||||
| 	/// Yields cpu to other threads. | ||||
|  | ||||
|     static Thread* current(); | ||||
|     /// Returns the Thread object for the currently active thread. | ||||
|     /// If the current thread is the main thread, 0 is returned. | ||||
| 	static Thread* current(); | ||||
| 	/// Returns the Thread object for the currently active thread. | ||||
| 	/// If the current thread is the main thread, 0 is returned. | ||||
|  | ||||
|     static TID currentTid(); | ||||
|     /// Returns the native thread ID for the current thread. | ||||
| 	static TID currentTid(); | ||||
| 	/// Returns the native thread ID for the current thread. | ||||
|  | ||||
| protected: | ||||
|     ThreadLocalStorage& tls(); | ||||
|     /// Returns a reference to the thread's local storage. | ||||
| 	ThreadLocalStorage& tls(); | ||||
| 	/// Returns a reference to the thread's local storage. | ||||
|  | ||||
|     void clearTLS(); | ||||
|     /// Clears the thread's local storage. | ||||
| 	void clearTLS(); | ||||
| 	/// Clears the thread's local storage. | ||||
|  | ||||
|     std::string makeName(); | ||||
|     /// Creates a unique name for a thread. | ||||
| 	std::string makeName(); | ||||
| 	/// Creates a unique name for a thread. | ||||
|  | ||||
|     static int uniqueId(); | ||||
|     /// Creates and returns a unique id for a thread. | ||||
| 	static int uniqueId(); | ||||
| 	/// Creates and returns a unique id for a thread. | ||||
|  | ||||
|     template <class Functor> | ||||
|     class FunctorRunnable: public Runnable | ||||
|     { | ||||
|     public: | ||||
|         FunctorRunnable(const Functor& functor): | ||||
|             _functor(functor) | ||||
|         { | ||||
|         } | ||||
| 	template <class Functor> | ||||
| 	class FunctorRunnable: public Runnable | ||||
| 	{ | ||||
| 	public: | ||||
| 		FunctorRunnable(const Functor& functor): | ||||
| 			_functor(functor) | ||||
| 		{ | ||||
| 		} | ||||
|  | ||||
|         ~FunctorRunnable() | ||||
|         { | ||||
|         } | ||||
| 		~FunctorRunnable() | ||||
| 		{ | ||||
| 		} | ||||
|  | ||||
|         void run() | ||||
|         { | ||||
|             _functor(); | ||||
|         } | ||||
| 		void run() | ||||
| 		{ | ||||
| 			_functor(); | ||||
| 		} | ||||
|  | ||||
|     private: | ||||
|         Functor _functor; | ||||
|     }; | ||||
| 	private: | ||||
| 		Functor _functor; | ||||
| 	}; | ||||
|  | ||||
| private: | ||||
|     Thread(const Thread&); | ||||
|     Thread& operator = (const Thread&); | ||||
| 	Thread(const Thread&); | ||||
| 	Thread& operator = (const Thread&); | ||||
|  | ||||
|     int                 _id; | ||||
|     std::string         _name; | ||||
|     ThreadLocalStorage* _pTLS; | ||||
|     Event               _event; | ||||
|     mutable FastMutex   _mutex; | ||||
| 	int                 _id; | ||||
| 	std::string         _name; | ||||
| 	ThreadLocalStorage* _pTLS; | ||||
| 	Event               _event; | ||||
| 	mutable FastMutex   _mutex; | ||||
|  | ||||
|     friend class ThreadLocalStorage; | ||||
|     friend class PooledThread; | ||||
| 	friend class ThreadLocalStorage; | ||||
| 	friend class PooledThread; | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -279,104 +279,104 @@ private: | ||||
| // | ||||
| inline Thread::TID Thread::tid() const | ||||
| { | ||||
|     return tidImpl(); | ||||
| 	return tidImpl(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int Thread::id() const | ||||
| { | ||||
|     return _id; | ||||
| 	return _id; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline std::string Thread::name() const | ||||
| { | ||||
|     FastMutex::ScopedLock lock(_mutex); | ||||
| 	FastMutex::ScopedLock lock(_mutex); | ||||
|  | ||||
|     return _name; | ||||
| 	return _name; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline std::string Thread::getName() const | ||||
| { | ||||
|     FastMutex::ScopedLock lock(_mutex); | ||||
| 	FastMutex::ScopedLock lock(_mutex); | ||||
|  | ||||
|     return _name; | ||||
| 	return _name; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline bool Thread::isRunning() const | ||||
| { | ||||
|     return isRunningImpl(); | ||||
| 	return isRunningImpl(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void Thread::sleep(long milliseconds) | ||||
| { | ||||
|     sleepImpl(milliseconds); | ||||
| 	sleepImpl(milliseconds); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void Thread::yield() | ||||
| { | ||||
|     yieldImpl(); | ||||
| 	yieldImpl(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline Thread* Thread::current() | ||||
| { | ||||
|     return static_cast<Thread*>(currentImpl()); | ||||
| 	return static_cast<Thread*>(currentImpl()); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void Thread::setOSPriority(int prio, int policy) | ||||
| { | ||||
|     setOSPriorityImpl(prio, policy); | ||||
| 	setOSPriorityImpl(prio, policy); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int Thread::getOSPriority() const | ||||
| { | ||||
|     return getOSPriorityImpl(); | ||||
| 	return getOSPriorityImpl(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int Thread::getMinOSPriority(int policy) | ||||
| { | ||||
|     return ThreadImpl::getMinOSPriorityImpl(policy); | ||||
| 	return ThreadImpl::getMinOSPriorityImpl(policy); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int Thread::getMaxOSPriority(int policy) | ||||
| { | ||||
|     return ThreadImpl::getMaxOSPriorityImpl(policy); | ||||
| 	return ThreadImpl::getMaxOSPriorityImpl(policy); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void Thread::setStackSize(int size) | ||||
| { | ||||
|     setStackSizeImpl(size); | ||||
| 	setStackSizeImpl(size); | ||||
| } | ||||
|  | ||||
| inline void Thread::setAffinity(unsigned int cpu) | ||||
| { | ||||
|     setAffinityImpl(cpu); | ||||
| 	setAffinityImpl(cpu); | ||||
| } | ||||
|  | ||||
| inline unsigned Thread::getAffinity() const | ||||
| { | ||||
|     return getAffinityImpl(); | ||||
| 	return getAffinityImpl(); | ||||
| } | ||||
|  | ||||
| inline int Thread::getStackSize() const | ||||
| { | ||||
|     return getStackSizeImpl(); | ||||
| 	return getStackSizeImpl(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline Thread::TID Thread::currentTid() | ||||
| { | ||||
|     return currentTidImpl(); | ||||
| 	return currentTidImpl(); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -45,113 +45,113 @@ namespace Poco { | ||||
| class Foundation_API ThreadImpl | ||||
| { | ||||
| public: | ||||
|     typedef pthread_t TIDImpl; | ||||
|     typedef void (*Callable)(void*); | ||||
| 	typedef pthread_t TIDImpl; | ||||
| 	typedef void (*Callable)(void*); | ||||
|  | ||||
|     enum Priority | ||||
|     { | ||||
|         PRIO_LOWEST_IMPL, | ||||
|         PRIO_LOW_IMPL, | ||||
|         PRIO_NORMAL_IMPL, | ||||
|         PRIO_HIGH_IMPL, | ||||
|         PRIO_HIGHEST_IMPL | ||||
|     }; | ||||
| 	enum Priority | ||||
| 	{ | ||||
| 		PRIO_LOWEST_IMPL, | ||||
| 		PRIO_LOW_IMPL, | ||||
| 		PRIO_NORMAL_IMPL, | ||||
| 		PRIO_HIGH_IMPL, | ||||
| 		PRIO_HIGHEST_IMPL | ||||
| 	}; | ||||
|  | ||||
|     enum Policy | ||||
|     { | ||||
|         POLICY_DEFAULT_IMPL = SCHED_OTHER | ||||
|     }; | ||||
| 	enum Policy | ||||
| 	{ | ||||
| 		POLICY_DEFAULT_IMPL = SCHED_OTHER | ||||
| 	}; | ||||
|  | ||||
|     ThreadImpl(); | ||||
|     ~ThreadImpl(); | ||||
| 	ThreadImpl(); | ||||
| 	~ThreadImpl(); | ||||
|  | ||||
|     TIDImpl tidImpl() const; | ||||
|     void setPriorityImpl(int prio); | ||||
|     int getPriorityImpl() const; | ||||
|     void setOSPriorityImpl(int prio, int policy = SCHED_OTHER); | ||||
|     int getOSPriorityImpl() const; | ||||
|     static int getMinOSPriorityImpl(int policy); | ||||
|     static int getMaxOSPriorityImpl(int policy); | ||||
|     void setStackSizeImpl(int size); | ||||
|     int getStackSizeImpl() const; | ||||
|     void setAffinityImpl(unsigned cpu); | ||||
|     unsigned getAffinityImpl() const; | ||||
|     void startImpl(SharedPtr<Runnable> pTarget); | ||||
|     void joinImpl(); | ||||
|     bool joinImpl(long milliseconds); | ||||
|     bool isRunningImpl() const; | ||||
|     static void sleepImpl(long milliseconds); | ||||
|     static void yieldImpl(); | ||||
|     static ThreadImpl* currentImpl(); | ||||
|     static TIDImpl currentTidImpl(); | ||||
| 	TIDImpl tidImpl() const; | ||||
| 	void setPriorityImpl(int prio); | ||||
| 	int getPriorityImpl() const; | ||||
| 	void setOSPriorityImpl(int prio, int policy = SCHED_OTHER); | ||||
| 	int getOSPriorityImpl() const; | ||||
| 	static int getMinOSPriorityImpl(int policy); | ||||
| 	static int getMaxOSPriorityImpl(int policy); | ||||
| 	void setStackSizeImpl(int size); | ||||
| 	int getStackSizeImpl() const; | ||||
| 	void setAffinityImpl(unsigned cpu); | ||||
| 	unsigned getAffinityImpl() const; | ||||
| 	void startImpl(SharedPtr<Runnable> pTarget); | ||||
| 	void joinImpl(); | ||||
| 	bool joinImpl(long milliseconds); | ||||
| 	bool isRunningImpl() const; | ||||
| 	static void sleepImpl(long milliseconds); | ||||
| 	static void yieldImpl(); | ||||
| 	static ThreadImpl* currentImpl(); | ||||
| 	static TIDImpl currentTidImpl(); | ||||
|  | ||||
| protected: | ||||
|     static void* runnableEntry(void* pThread); | ||||
|     static int mapPrio(int prio, int policy = SCHED_OTHER); | ||||
|     static int reverseMapPrio(int osPrio, int policy = SCHED_OTHER); | ||||
| 	static void* runnableEntry(void* pThread); | ||||
| 	static int mapPrio(int prio, int policy = SCHED_OTHER); | ||||
| 	static int reverseMapPrio(int osPrio, int policy = SCHED_OTHER); | ||||
|  | ||||
| private: | ||||
|     class CurrentThreadHolder | ||||
|     { | ||||
|     public: | ||||
|         CurrentThreadHolder() | ||||
|         { | ||||
|             if (pthread_key_create(&_key, NULL)) | ||||
|                 throw SystemException("cannot allocate thread context key"); | ||||
|         } | ||||
|         ~CurrentThreadHolder() | ||||
|         { | ||||
|             pthread_key_delete(_key); | ||||
|         } | ||||
|         ThreadImpl* get() const | ||||
|         { | ||||
|             return reinterpret_cast<ThreadImpl*>(pthread_getspecific(_key)); | ||||
|         } | ||||
|         void set(ThreadImpl* pThread) | ||||
|         { | ||||
|             pthread_setspecific(_key, pThread); | ||||
|         } | ||||
| 	class CurrentThreadHolder | ||||
| 	{ | ||||
| 	public: | ||||
| 		CurrentThreadHolder() | ||||
| 		{ | ||||
| 			if (pthread_key_create(&_key, NULL)) | ||||
| 				throw SystemException("cannot allocate thread context key"); | ||||
| 		} | ||||
| 		~CurrentThreadHolder() | ||||
| 		{ | ||||
| 			pthread_key_delete(_key); | ||||
| 		} | ||||
| 		ThreadImpl* get() const | ||||
| 		{ | ||||
| 			return reinterpret_cast<ThreadImpl*>(pthread_getspecific(_key)); | ||||
| 		} | ||||
| 		void set(ThreadImpl* pThread) | ||||
| 		{ | ||||
| 			pthread_setspecific(_key, pThread); | ||||
| 		} | ||||
|  | ||||
|     private: | ||||
|         pthread_key_t _key; | ||||
|     }; | ||||
| 	private: | ||||
| 		pthread_key_t _key; | ||||
| 	}; | ||||
|  | ||||
|     struct ThreadData: public RefCountedObject | ||||
|     { | ||||
|         ThreadData(): | ||||
|             thread(0), | ||||
|             prio(PRIO_NORMAL_IMPL), | ||||
|             policy(SCHED_OTHER), | ||||
|             done(Event::EVENT_MANUALRESET), | ||||
|             stackSize(POCO_THREAD_STACK_SIZE), | ||||
|             started(false), | ||||
|             joined(false) | ||||
|         { | ||||
| 	struct ThreadData: public RefCountedObject | ||||
| 	{ | ||||
| 		ThreadData(): | ||||
| 			thread(0), | ||||
| 			prio(PRIO_NORMAL_IMPL), | ||||
| 			policy(SCHED_OTHER), | ||||
| 			done(Event::EVENT_MANUALRESET), | ||||
| 			stackSize(POCO_THREAD_STACK_SIZE), | ||||
| 			started(false), | ||||
| 			joined(false) | ||||
| 		{ | ||||
| #if defined(POCO_VXWORKS) | ||||
|             // This workaround is for VxWorks 5.x where | ||||
|             // pthread_init() won't properly initialize the thread. | ||||
|             std::memset(&thread, 0, sizeof(thread)); | ||||
| 			// This workaround is for VxWorks 5.x where | ||||
| 			// pthread_init() won't properly initialize the thread. | ||||
| 			std::memset(&thread, 0, sizeof(thread)); | ||||
| #endif | ||||
|         } | ||||
| 		} | ||||
|  | ||||
|         SharedPtr<Runnable> pRunnableTarget; | ||||
|         pthread_t     thread; | ||||
|         int           prio; | ||||
|         int           osPrio; | ||||
|         int           policy; | ||||
|         Event         done; | ||||
|         std::size_t   stackSize; | ||||
|         bool          started; | ||||
|         bool          joined; | ||||
|     }; | ||||
| 		SharedPtr<Runnable> pRunnableTarget; | ||||
| 		pthread_t     thread; | ||||
| 		int           prio; | ||||
| 		int           osPrio; | ||||
| 		int           policy; | ||||
| 		Event         done; | ||||
| 		std::size_t   stackSize; | ||||
| 		bool          started; | ||||
| 		bool          joined; | ||||
| 	}; | ||||
|  | ||||
|     AutoPtr<ThreadData> _pData; | ||||
| 	AutoPtr<ThreadData> _pData; | ||||
|  | ||||
|     static CurrentThreadHolder _currentThreadHolder; | ||||
| 	static CurrentThreadHolder _currentThreadHolder; | ||||
|  | ||||
| #if defined(POCO_OS_FAMILY_UNIX) && !defined(POCO_VXWORKS) | ||||
|     SignalHandler::JumpBufferVec _jumpBufferVec; | ||||
|     friend class SignalHandler; | ||||
| 	SignalHandler::JumpBufferVec _jumpBufferVec; | ||||
| 	friend class SignalHandler; | ||||
| #endif | ||||
| }; | ||||
|  | ||||
| @@ -161,37 +161,37 @@ private: | ||||
| // | ||||
| inline int ThreadImpl::getPriorityImpl() const | ||||
| { | ||||
|     return _pData->prio; | ||||
| 	return _pData->prio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getOSPriorityImpl() const | ||||
| { | ||||
|     return _pData->osPrio; | ||||
| 	return _pData->osPrio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline bool ThreadImpl::isRunningImpl() const | ||||
| { | ||||
|     return !_pData->pRunnableTarget.isNull(); | ||||
| 	return !_pData->pRunnableTarget.isNull(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::yieldImpl() | ||||
| { | ||||
|     sched_yield(); | ||||
| 	sched_yield(); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getStackSizeImpl() const | ||||
| { | ||||
|     return static_cast<int>(_pData->stackSize); | ||||
| 	return static_cast<int>(_pData->stackSize); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline ThreadImpl::TIDImpl ThreadImpl::tidImpl() const | ||||
| { | ||||
|     return _pData->thread; | ||||
| 	return _pData->thread; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -36,95 +36,95 @@ namespace Poco { | ||||
| class Foundation_API ThreadImpl | ||||
| { | ||||
| public: | ||||
|     typedef int TIDImpl; | ||||
|     typedef void (*Callable)(void*); | ||||
| 	typedef int TIDImpl; | ||||
| 	typedef void (*Callable)(void*); | ||||
|  | ||||
|     enum Priority | ||||
|     { | ||||
|         PRIO_LOWEST_IMPL, | ||||
|         PRIO_LOW_IMPL, | ||||
|         PRIO_NORMAL_IMPL, | ||||
|         PRIO_HIGH_IMPL, | ||||
|         PRIO_HIGHEST_IMPL | ||||
|     }; | ||||
| 	enum Priority | ||||
| 	{ | ||||
| 		PRIO_LOWEST_IMPL, | ||||
| 		PRIO_LOW_IMPL, | ||||
| 		PRIO_NORMAL_IMPL, | ||||
| 		PRIO_HIGH_IMPL, | ||||
| 		PRIO_HIGHEST_IMPL | ||||
| 	}; | ||||
|  | ||||
|     enum Policy | ||||
|     { | ||||
|         POLICY_DEFAULT_IMPL = 0 | ||||
|     }; | ||||
| 	enum Policy | ||||
| 	{ | ||||
| 		POLICY_DEFAULT_IMPL = 0 | ||||
| 	}; | ||||
|  | ||||
|     enum | ||||
|     { | ||||
|         DEFAULT_THREAD_STACK_SIZE = 65536 | ||||
|     }; | ||||
| 	enum | ||||
| 	{ | ||||
| 		DEFAULT_THREAD_STACK_SIZE = 65536 | ||||
| 	}; | ||||
|  | ||||
|     struct CallbackData: public RefCountedObject | ||||
|     { | ||||
|         CallbackData(): callback(0), pData(0) | ||||
|         { | ||||
|         } | ||||
| 	struct CallbackData: public RefCountedObject | ||||
| 	{ | ||||
| 		CallbackData(): callback(0), pData(0) | ||||
| 		{ | ||||
| 		} | ||||
|  | ||||
|         Callable  callback; | ||||
|         void*     pData; | ||||
|     }; | ||||
| 		Callable  callback; | ||||
| 		void*     pData; | ||||
| 	}; | ||||
|  | ||||
|     ThreadImpl(); | ||||
|     ~ThreadImpl(); | ||||
| 	ThreadImpl(); | ||||
| 	~ThreadImpl(); | ||||
|  | ||||
|     TIDImpl tidImpl() const; | ||||
|     void setPriorityImpl(int prio); | ||||
|     int getPriorityImpl() const; | ||||
|     void setOSPriorityImpl(int prio, int policy = 0); | ||||
|     int getOSPriorityImpl() const; | ||||
|     static int getMinOSPriorityImpl(int policy); | ||||
|     static int getMaxOSPriorityImpl(int policy); | ||||
|     void setStackSizeImpl(int size); | ||||
|     int getStackSizeImpl() const; | ||||
|     void setAffinityImpl(unsigned cpu); | ||||
|     unsigned getAffinityImpl() const; | ||||
| 	TIDImpl tidImpl() const; | ||||
| 	void setPriorityImpl(int prio); | ||||
| 	int getPriorityImpl() const; | ||||
| 	void setOSPriorityImpl(int prio, int policy = 0); | ||||
| 	int getOSPriorityImpl() const; | ||||
| 	static int getMinOSPriorityImpl(int policy); | ||||
| 	static int getMaxOSPriorityImpl(int policy); | ||||
| 	void setStackSizeImpl(int size); | ||||
| 	int getStackSizeImpl() const; | ||||
| 	void setAffinityImpl(unsigned cpu); | ||||
| 	unsigned getAffinityImpl() const; | ||||
|  | ||||
|     void startImpl(Runnable& target); | ||||
|     void startImpl(Callable target, void* pData = 0); | ||||
| 	void startImpl(Runnable& target); | ||||
| 	void startImpl(Callable target, void* pData = 0); | ||||
|  | ||||
|     void joinImpl(); | ||||
|     bool joinImpl(long milliseconds); | ||||
|     bool isRunningImpl() const; | ||||
|     static void sleepImpl(long milliseconds); | ||||
|     static void yieldImpl(); | ||||
|     static ThreadImpl* currentImpl(); | ||||
|     static TIDImpl currentTidImpl(); | ||||
| 	void joinImpl(); | ||||
| 	bool joinImpl(long milliseconds); | ||||
| 	bool isRunningImpl() const; | ||||
| 	static void sleepImpl(long milliseconds); | ||||
| 	static void yieldImpl(); | ||||
| 	static ThreadImpl* currentImpl(); | ||||
| 	static TIDImpl currentTidImpl(); | ||||
|  | ||||
| protected: | ||||
|     static void runnableEntry(void* pThread, int, int, int, int, int, int, int, int, int); | ||||
|     static void callableEntry(void* pThread, int, int, int, int, int, int, int, int, int); | ||||
|     static int mapPrio(int prio); | ||||
|     static int reverseMapPrio(int osPrio); | ||||
| 	static void runnableEntry(void* pThread, int, int, int, int, int, int, int, int, int); | ||||
| 	static void callableEntry(void* pThread, int, int, int, int, int, int, int, int, int); | ||||
| 	static int mapPrio(int prio); | ||||
| 	static int reverseMapPrio(int osPrio); | ||||
|  | ||||
|     struct ThreadData: public RefCountedObject | ||||
|     { | ||||
|         ThreadData(): | ||||
|             pRunnableTarget(0), | ||||
|             pCallbackTarget(0), | ||||
|             task(0), | ||||
|             prio(PRIO_NORMAL_IMPL), | ||||
|             osPrio(127), | ||||
|             done(false), | ||||
|             stackSize(POCO_THREAD_STACK_SIZE) | ||||
|         { | ||||
|         } | ||||
| 	struct ThreadData: public RefCountedObject | ||||
| 	{ | ||||
| 		ThreadData(): | ||||
| 			pRunnableTarget(0), | ||||
| 			pCallbackTarget(0), | ||||
| 			task(0), | ||||
| 			prio(PRIO_NORMAL_IMPL), | ||||
| 			osPrio(127), | ||||
| 			done(false), | ||||
| 			stackSize(POCO_THREAD_STACK_SIZE) | ||||
| 		{ | ||||
| 		} | ||||
|  | ||||
|         Runnable* pRunnableTarget; | ||||
|         AutoPtr<CallbackData> pCallbackTarget; | ||||
|         int       task; | ||||
|         int       prio; | ||||
|         int       osPrio; | ||||
|         Event     done; | ||||
|         int       stackSize; | ||||
|     }; | ||||
| 		Runnable* pRunnableTarget; | ||||
| 		AutoPtr<CallbackData> pCallbackTarget; | ||||
| 		int       task; | ||||
| 		int       prio; | ||||
| 		int       osPrio; | ||||
| 		Event     done; | ||||
| 		int       stackSize; | ||||
| 	}; | ||||
|  | ||||
| private: | ||||
|     AutoPtr<ThreadData> _pData; | ||||
|     static ThreadImpl* _pCurrent; | ||||
| 	AutoPtr<ThreadData> _pData; | ||||
| 	static ThreadImpl* _pCurrent; | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -133,48 +133,48 @@ private: | ||||
| // | ||||
| inline int ThreadImpl::getPriorityImpl() const | ||||
| { | ||||
|     return _pData->prio; | ||||
| 	return _pData->prio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getOSPriorityImpl() const | ||||
| { | ||||
|     return _pData->osPrio; | ||||
| 	return _pData->osPrio; | ||||
| } | ||||
|  | ||||
| inline void ThreadImpl::setAffinityImpl(unsigned cpu) | ||||
| { | ||||
|     (void)cpu; | ||||
|     throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| 	(void)cpu; | ||||
| 	throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| } | ||||
|  | ||||
| inline unsigned ThreadImpl::getAffinityImpl() | ||||
| { | ||||
|     throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| 	throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| } | ||||
|  | ||||
| inline bool ThreadImpl::isRunningImpl() const | ||||
| { | ||||
|     return _pData->pRunnableTarget != 0 || | ||||
|            (_pData->pCallbackTarget.get() != 0 && _pData->pCallbackTarget->callback != 0); | ||||
| 	return _pData->pRunnableTarget != 0 || | ||||
| 	       (_pData->pCallbackTarget.get() != 0 && _pData->pCallbackTarget->callback != 0); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::yieldImpl() | ||||
| { | ||||
|     taskDelay(0); | ||||
| 	taskDelay(0); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getStackSizeImpl() const | ||||
| { | ||||
|     return _pData->stackSize; | ||||
| 	return _pData->stackSize; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline ThreadImpl::TIDImpl ThreadImpl::tidImpl() const | ||||
| { | ||||
|     return _pData->task; | ||||
| 	return _pData->task; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -32,95 +32,95 @@ namespace Poco { | ||||
| class Foundation_API ThreadImpl | ||||
| { | ||||
| public: | ||||
|     typedef DWORD TIDImpl; | ||||
|     typedef void (*Callable)(void*); | ||||
| 	typedef DWORD TIDImpl; | ||||
| 	typedef void (*Callable)(void*); | ||||
|  | ||||
| #if defined(_DLL) | ||||
|     typedef DWORD (WINAPI* Entry)(LPVOID); | ||||
| 	typedef DWORD (WINAPI* Entry)(LPVOID); | ||||
| #else | ||||
|     typedef unsigned (__stdcall* Entry)(void*); | ||||
| 	typedef unsigned (__stdcall* Entry)(void*); | ||||
| #endif | ||||
|  | ||||
|     enum Priority | ||||
|     { | ||||
|         PRIO_LOWEST_IMPL  = THREAD_PRIORITY_LOWEST, | ||||
|         PRIO_LOW_IMPL     = THREAD_PRIORITY_BELOW_NORMAL, | ||||
|         PRIO_NORMAL_IMPL  = THREAD_PRIORITY_NORMAL, | ||||
|         PRIO_HIGH_IMPL    = THREAD_PRIORITY_ABOVE_NORMAL, | ||||
|         PRIO_HIGHEST_IMPL = THREAD_PRIORITY_HIGHEST | ||||
|     }; | ||||
| 	enum Priority | ||||
| 	{ | ||||
| 		PRIO_LOWEST_IMPL  = THREAD_PRIORITY_LOWEST, | ||||
| 		PRIO_LOW_IMPL     = THREAD_PRIORITY_BELOW_NORMAL, | ||||
| 		PRIO_NORMAL_IMPL  = THREAD_PRIORITY_NORMAL, | ||||
| 		PRIO_HIGH_IMPL    = THREAD_PRIORITY_ABOVE_NORMAL, | ||||
| 		PRIO_HIGHEST_IMPL = THREAD_PRIORITY_HIGHEST | ||||
| 	}; | ||||
|  | ||||
|     enum Policy | ||||
|     { | ||||
|         POLICY_DEFAULT_IMPL = 0 | ||||
|     }; | ||||
| 	enum Policy | ||||
| 	{ | ||||
| 		POLICY_DEFAULT_IMPL = 0 | ||||
| 	}; | ||||
|  | ||||
|     ThreadImpl(); | ||||
|     ~ThreadImpl(); | ||||
| 	ThreadImpl(); | ||||
| 	~ThreadImpl(); | ||||
|  | ||||
|     TIDImpl tidImpl() const; | ||||
|     void setPriorityImpl(int prio); | ||||
|     int getPriorityImpl() const; | ||||
|     void setOSPriorityImpl(int prio, int policy = 0); | ||||
|     int getOSPriorityImpl() const; | ||||
|     static int getMinOSPriorityImpl(int policy); | ||||
|     static int getMaxOSPriorityImpl(int policy); | ||||
|     void setStackSizeImpl(int size); | ||||
|     void setAffinityImpl(unsigned cpu); | ||||
|     unsigned getAffinityImpl() const; | ||||
|     int getStackSizeImpl() const; | ||||
|     void startImpl(SharedPtr<Runnable> pTarget); | ||||
|     void joinImpl(); | ||||
|     bool joinImpl(long milliseconds); | ||||
|     bool isRunningImpl() const; | ||||
|     static void sleepImpl(long milliseconds); | ||||
|     static void yieldImpl(); | ||||
|     static ThreadImpl* currentImpl(); | ||||
|     static TIDImpl currentTidImpl(); | ||||
| 	TIDImpl tidImpl() const; | ||||
| 	void setPriorityImpl(int prio); | ||||
| 	int getPriorityImpl() const; | ||||
| 	void setOSPriorityImpl(int prio, int policy = 0); | ||||
| 	int getOSPriorityImpl() const; | ||||
| 	static int getMinOSPriorityImpl(int policy); | ||||
| 	static int getMaxOSPriorityImpl(int policy); | ||||
| 	void setStackSizeImpl(int size); | ||||
| 	void setAffinityImpl(unsigned cpu); | ||||
| 	unsigned getAffinityImpl() const; | ||||
| 	int getStackSizeImpl() const; | ||||
| 	void startImpl(SharedPtr<Runnable> pTarget); | ||||
| 	void joinImpl(); | ||||
| 	bool joinImpl(long milliseconds); | ||||
| 	bool isRunningImpl() const; | ||||
| 	static void sleepImpl(long milliseconds); | ||||
| 	static void yieldImpl(); | ||||
| 	static ThreadImpl* currentImpl(); | ||||
| 	static TIDImpl currentTidImpl(); | ||||
|  | ||||
| protected: | ||||
| #if defined(_DLL) | ||||
|     static DWORD WINAPI runnableEntry(LPVOID pThread); | ||||
| 	static DWORD WINAPI runnableEntry(LPVOID pThread); | ||||
| #else | ||||
|     static unsigned __stdcall runnableEntry(void* pThread); | ||||
| 	static unsigned __stdcall runnableEntry(void* pThread); | ||||
| #endif | ||||
|  | ||||
|     void createImpl(Entry ent, void* pData); | ||||
|     void threadCleanup(); | ||||
| 	void createImpl(Entry ent, void* pData); | ||||
| 	void threadCleanup(); | ||||
|  | ||||
| private: | ||||
|     class CurrentThreadHolder | ||||
|     { | ||||
|     public: | ||||
|         CurrentThreadHolder(): _slot(TlsAlloc()) | ||||
|         { | ||||
|             if (_slot == TLS_OUT_OF_INDEXES) | ||||
|                 throw SystemException("cannot allocate thread context key"); | ||||
|         } | ||||
|         ~CurrentThreadHolder() | ||||
|         { | ||||
|             TlsFree(_slot); | ||||
|         } | ||||
|         ThreadImpl* get() const | ||||
|         { | ||||
|             return reinterpret_cast<ThreadImpl*>(TlsGetValue(_slot)); | ||||
|         } | ||||
|         void set(ThreadImpl* pThread) | ||||
|         { | ||||
|             TlsSetValue(_slot, pThread); | ||||
|         } | ||||
| 	class CurrentThreadHolder | ||||
| 	{ | ||||
| 	public: | ||||
| 		CurrentThreadHolder(): _slot(TlsAlloc()) | ||||
| 		{ | ||||
| 			if (_slot == TLS_OUT_OF_INDEXES) | ||||
| 				throw SystemException("cannot allocate thread context key"); | ||||
| 		} | ||||
| 		~CurrentThreadHolder() | ||||
| 		{ | ||||
| 			TlsFree(_slot); | ||||
| 		} | ||||
| 		ThreadImpl* get() const | ||||
| 		{ | ||||
| 			return reinterpret_cast<ThreadImpl*>(TlsGetValue(_slot)); | ||||
| 		} | ||||
| 		void set(ThreadImpl* pThread) | ||||
| 		{ | ||||
| 			TlsSetValue(_slot, pThread); | ||||
| 		} | ||||
|  | ||||
|     private: | ||||
|         DWORD _slot; | ||||
|     }; | ||||
| 	private: | ||||
| 		DWORD _slot; | ||||
| 	}; | ||||
|  | ||||
|     SharedPtr<Runnable> _pRunnableTarget; | ||||
|     HANDLE _thread; | ||||
|     DWORD _threadId; | ||||
|     int _prio; | ||||
|     int _stackSize; | ||||
| 	SharedPtr<Runnable> _pRunnableTarget; | ||||
| 	HANDLE _thread; | ||||
| 	DWORD _threadId; | ||||
| 	int _prio; | ||||
| 	int _stackSize; | ||||
|  | ||||
|     static CurrentThreadHolder _currentThreadHolder; | ||||
| 	static CurrentThreadHolder _currentThreadHolder; | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -129,55 +129,55 @@ private: | ||||
| // | ||||
| inline int ThreadImpl::getPriorityImpl() const | ||||
| { | ||||
|     return _prio; | ||||
| 	return _prio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getOSPriorityImpl() const | ||||
| { | ||||
|     return _prio; | ||||
| 	return _prio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getMinOSPriorityImpl(int /* policy */) | ||||
| { | ||||
|     return PRIO_LOWEST_IMPL; | ||||
| 	return PRIO_LOWEST_IMPL; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getMaxOSPriorityImpl(int /* policy */) | ||||
| { | ||||
|     return PRIO_HIGHEST_IMPL; | ||||
| 	return PRIO_HIGHEST_IMPL; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::sleepImpl(long milliseconds) | ||||
| { | ||||
|     Sleep(DWORD(milliseconds)); | ||||
| 	Sleep(DWORD(milliseconds)); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::yieldImpl() | ||||
| { | ||||
|     Sleep(0); | ||||
| 	Sleep(0); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::setStackSizeImpl(int size) | ||||
| { | ||||
|     _stackSize = size; | ||||
| 	_stackSize = size; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getStackSizeImpl() const | ||||
| { | ||||
|     return _stackSize; | ||||
| 	return _stackSize; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline ThreadImpl::TIDImpl ThreadImpl::tidImpl() const | ||||
| { | ||||
|     return _threadId; | ||||
| 	return _threadId; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -37,86 +37,86 @@ namespace Poco { | ||||
| class Foundation_API ThreadImpl | ||||
| { | ||||
| public: | ||||
|     typedef DWORD TIDImpl; | ||||
|     typedef void (*Callable)(void*); | ||||
|     typedef DWORD (WINAPI* Entry)(LPVOID); | ||||
| 	typedef DWORD TIDImpl; | ||||
| 	typedef void (*Callable)(void*); | ||||
| 	typedef DWORD (WINAPI* Entry)(LPVOID); | ||||
|  | ||||
|     enum Priority | ||||
|     { | ||||
|         PRIO_LOWEST_IMPL  = THREAD_PRIORITY_LOWEST, | ||||
|         PRIO_LOW_IMPL     = THREAD_PRIORITY_BELOW_NORMAL, | ||||
|         PRIO_NORMAL_IMPL  = THREAD_PRIORITY_NORMAL, | ||||
|         PRIO_HIGH_IMPL    = THREAD_PRIORITY_ABOVE_NORMAL, | ||||
|         PRIO_HIGHEST_IMPL = THREAD_PRIORITY_HIGHEST | ||||
|     }; | ||||
| 	enum Priority | ||||
| 	{ | ||||
| 		PRIO_LOWEST_IMPL  = THREAD_PRIORITY_LOWEST, | ||||
| 		PRIO_LOW_IMPL     = THREAD_PRIORITY_BELOW_NORMAL, | ||||
| 		PRIO_NORMAL_IMPL  = THREAD_PRIORITY_NORMAL, | ||||
| 		PRIO_HIGH_IMPL    = THREAD_PRIORITY_ABOVE_NORMAL, | ||||
| 		PRIO_HIGHEST_IMPL = THREAD_PRIORITY_HIGHEST | ||||
| 	}; | ||||
|  | ||||
|     enum Policy | ||||
|     { | ||||
|         POLICY_DEFAULT_IMPL = 0 | ||||
|     }; | ||||
| 	enum Policy | ||||
| 	{ | ||||
| 		POLICY_DEFAULT_IMPL = 0 | ||||
| 	}; | ||||
|  | ||||
|     ThreadImpl(); | ||||
|     ~ThreadImpl(); | ||||
| 	ThreadImpl(); | ||||
| 	~ThreadImpl(); | ||||
|  | ||||
|     TIDImpl tidImpl() const; | ||||
|     void setPriorityImpl(int prio); | ||||
|     int getPriorityImpl() const; | ||||
|     void setOSPriorityImpl(int prio, int policy = 0); | ||||
|     int getOSPriorityImpl() const; | ||||
|     static int getMinOSPriorityImpl(int policy); | ||||
|     static int getMaxOSPriorityImpl(int policy); | ||||
|     void setStackSizeImpl(int size); | ||||
|     int getStackSizeImpl() const; | ||||
|     void setAffinityImpl(unsigned cpu); | ||||
|     unsigned getAffinityImpl() const; | ||||
|     void startImpl(SharedPtr<Runnable> pTarget); | ||||
|     void joinImpl(); | ||||
|     bool joinImpl(long milliseconds); | ||||
|     bool isRunningImpl() const; | ||||
|     static void sleepImpl(long milliseconds); | ||||
|     static void yieldImpl(); | ||||
|     static ThreadImpl* currentImpl(); | ||||
|     static TIDImpl currentTidImpl(); | ||||
| 	TIDImpl tidImpl() const; | ||||
| 	void setPriorityImpl(int prio); | ||||
| 	int getPriorityImpl() const; | ||||
| 	void setOSPriorityImpl(int prio, int policy = 0); | ||||
| 	int getOSPriorityImpl() const; | ||||
| 	static int getMinOSPriorityImpl(int policy); | ||||
| 	static int getMaxOSPriorityImpl(int policy); | ||||
| 	void setStackSizeImpl(int size); | ||||
| 	int getStackSizeImpl() const; | ||||
| 	void setAffinityImpl(unsigned cpu); | ||||
| 	unsigned getAffinityImpl() const; | ||||
| 	void startImpl(SharedPtr<Runnable> pTarget); | ||||
| 	void joinImpl(); | ||||
| 	bool joinImpl(long milliseconds); | ||||
| 	bool isRunningImpl() const; | ||||
| 	static void sleepImpl(long milliseconds); | ||||
| 	static void yieldImpl(); | ||||
| 	static ThreadImpl* currentImpl(); | ||||
| 	static TIDImpl currentTidImpl(); | ||||
|  | ||||
| protected: | ||||
|     static DWORD WINAPI runnableEntry(LPVOID pThread); | ||||
| 	static DWORD WINAPI runnableEntry(LPVOID pThread); | ||||
|  | ||||
|     void createImpl(Entry ent, void* pData); | ||||
|     void threadCleanup(); | ||||
| 	void createImpl(Entry ent, void* pData); | ||||
| 	void threadCleanup(); | ||||
|  | ||||
| private: | ||||
|     class CurrentThreadHolder | ||||
|     { | ||||
|     public: | ||||
|         CurrentThreadHolder(): _slot(TlsAlloc()) | ||||
|         { | ||||
|             if (_slot == TLS_OUT_OF_INDEXES) | ||||
|                 throw SystemException("cannot allocate thread context key"); | ||||
|         } | ||||
|         ~CurrentThreadHolder() | ||||
|         { | ||||
|             TlsFree(_slot); | ||||
|         } | ||||
|         ThreadImpl* get() const | ||||
|         { | ||||
|             return reinterpret_cast<ThreadImpl*>(TlsGetValue(_slot)); | ||||
|         } | ||||
|         void set(ThreadImpl* pThread) | ||||
|         { | ||||
|             TlsSetValue(_slot, pThread); | ||||
|         } | ||||
| 	class CurrentThreadHolder | ||||
| 	{ | ||||
| 	public: | ||||
| 		CurrentThreadHolder(): _slot(TlsAlloc()) | ||||
| 		{ | ||||
| 			if (_slot == TLS_OUT_OF_INDEXES) | ||||
| 				throw SystemException("cannot allocate thread context key"); | ||||
| 		} | ||||
| 		~CurrentThreadHolder() | ||||
| 		{ | ||||
| 			TlsFree(_slot); | ||||
| 		} | ||||
| 		ThreadImpl* get() const | ||||
| 		{ | ||||
| 			return reinterpret_cast<ThreadImpl*>(TlsGetValue(_slot)); | ||||
| 		} | ||||
| 		void set(ThreadImpl* pThread) | ||||
| 		{ | ||||
| 			TlsSetValue(_slot, pThread); | ||||
| 		} | ||||
|  | ||||
|     private: | ||||
|         DWORD _slot; | ||||
|     }; | ||||
| 	private: | ||||
| 		DWORD _slot; | ||||
| 	}; | ||||
|  | ||||
|     SharedPtr<Runnable> _pRunnableTarget; | ||||
|     HANDLE       _thread; | ||||
|     DWORD        _threadId; | ||||
|     int          _prio; | ||||
|     int          _stackSize; | ||||
| 	SharedPtr<Runnable> _pRunnableTarget; | ||||
| 	HANDLE       _thread; | ||||
| 	DWORD        _threadId; | ||||
| 	int          _prio; | ||||
| 	int          _stackSize; | ||||
|  | ||||
|     static CurrentThreadHolder _currentThreadHolder; | ||||
| 	static CurrentThreadHolder _currentThreadHolder; | ||||
| }; | ||||
|  | ||||
|  | ||||
| @@ -125,65 +125,65 @@ private: | ||||
| // | ||||
| inline int ThreadImpl::getPriorityImpl() const | ||||
| { | ||||
|     return _prio; | ||||
| 	return _prio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getOSPriorityImpl() const | ||||
| { | ||||
|     return _prio; | ||||
| 	return _prio; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getMinOSPriorityImpl(int /* policy */) | ||||
| { | ||||
|     return PRIO_LOWEST_IMPL; | ||||
| 	return PRIO_LOWEST_IMPL; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getMaxOSPriorityImpl(int /* policy */) | ||||
| { | ||||
|     return PRIO_HIGHEST_IMPL; | ||||
| 	return PRIO_HIGHEST_IMPL; | ||||
| } | ||||
|  | ||||
| inline void ThreadImpl::setAffinityImpl(unsigned cpu) | ||||
| { | ||||
|     (void)cpu; | ||||
|     throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| 	(void)cpu; | ||||
| 	throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| } | ||||
|  | ||||
| inline unsigned ThreadImpl::getAffinityImpl() | ||||
| { | ||||
|     throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| 	throw Poco::NotImplementedException("Thread affinity not supported on this system"); | ||||
| } | ||||
|  | ||||
| inline void ThreadImpl::sleepImpl(long milliseconds) | ||||
| { | ||||
|     Sleep(DWORD(milliseconds)); | ||||
| 	Sleep(DWORD(milliseconds)); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::yieldImpl() | ||||
| { | ||||
|     Sleep(0); | ||||
| 	Sleep(0); | ||||
| } | ||||
|  | ||||
|  | ||||
| inline void ThreadImpl::setStackSizeImpl(int size) | ||||
| { | ||||
|     _stackSize = size; | ||||
| 	_stackSize = size; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline int ThreadImpl::getStackSizeImpl() const | ||||
| { | ||||
|     return _stackSize; | ||||
| 	return _stackSize; | ||||
| } | ||||
|  | ||||
|  | ||||
| inline ThreadImpl::TIDImpl ThreadImpl::tidImpl() const | ||||
| { | ||||
|     return _threadId; | ||||
| 	return _threadId; | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 ale_bychuk
					ale_bychuk