diff options
Diffstat (limited to 'dep/include/zthread/Exceptions.h')
-rw-r--r-- | dep/include/zthread/Exceptions.h | 245 |
1 files changed, 0 insertions, 245 deletions
diff --git a/dep/include/zthread/Exceptions.h b/dep/include/zthread/Exceptions.h deleted file mode 100644 index 458c556c0ff..00000000000 --- a/dep/include/zthread/Exceptions.h +++ /dev/null @@ -1,245 +0,0 @@ -/* - * Copyright (c) 2005, Eric Crahen - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is furnished - * to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in all - * copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, - * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - * - */ - -#ifndef __ZTEXCEPTIONS_H__ -#define __ZTEXCEPTIONS_H__ - - -#include "zthread/Config.h" -#include <string> - -namespace ZThread { - -/** - * @class Synchronization_Exception - * - * Serves as a general base class for the Exception hierarchy used within - * this package. - * - */ -class Synchronization_Exception { - - // Restrict heap allocation - static void * operator new(size_t size); - static void * operator new[](size_t size); - - std::string _msg; - -public: - - /** - * Create a new exception with a default error message 'Synchronization - * Exception' - */ - Synchronization_Exception() : _msg("Synchronization exception") { } - - /** - * Create a new exception with a given error message - * - * @param const char* - error message - */ - Synchronization_Exception(const char* msg) : _msg(msg) { } - - /** - * Get additional info about the exception - * - * @return const char* for the error message - */ - const char* what() const { - return _msg.c_str(); - } - -}; - - -/** - * @class Interrupted_Exception - * - * Used to describe an interrupted operation that would have normally - * blocked the calling thread - */ -class Interrupted_Exception : public Synchronization_Exception { - - public: - - //! Create a new exception - Interrupted_Exception() : Synchronization_Exception("Thread interrupted") { } - - //! Create a new exception - Interrupted_Exception(const char* msg) : Synchronization_Exception(msg) { } - -}; - - - -/** - * @class Deadlock_Exception - * - * Thrown when deadlock has been detected - */ -class Deadlock_Exception : public Synchronization_Exception { - public: - - //! Create a new exception - Deadlock_Exception() : Synchronization_Exception("Deadlock detected") { } - - //! Create a new exception - Deadlock_Exception(const char* msg) : Synchronization_Exception(msg) { } - -}; - - -/** - * @class InvalidOp_Exception - * - * Thrown when performing an illegal operation this object - */ -class InvalidOp_Exception : public Synchronization_Exception { - public: - - //! Create a new exception - InvalidOp_Exception() : Synchronization_Exception("Invalid operation") { } - //! Create a new exception - InvalidOp_Exception(const char* msg) : Synchronization_Exception(msg) { } - -}; - - - -/** - * @class Initialization_Exception - * - * Thrown when the system has no more resources to create new - * synchronization controls - */ -class Initialization_Exception : public Synchronization_Exception { - - public: - - //! Create a new exception - Initialization_Exception() : Synchronization_Exception("Initialization error") { } - //! Create a new exception - Initialization_Exception(const char*msg) : Synchronization_Exception(msg) { } - -}; - -/** - * @class Cancellation_Exception - * - * Cancellation_Exceptions are thrown by 'Canceled' objects. - * @see Cancelable - */ -class Cancellation_Exception : public Synchronization_Exception { - - public: - - //! Create a new Cancelltion_Exception - Cancellation_Exception() : Synchronization_Exception("Canceled") { } - //! Create a new Cancelltion_Exception - Cancellation_Exception(const char*msg) : Synchronization_Exception(msg) { } - -}; - - -/** - * @class Timeout_Exception - * - * There is no need for error messaged simply indicates the last - * operation timed out - */ -class Timeout_Exception : public Synchronization_Exception { - public: - - //! Create a new Timeout_Exception - Timeout_Exception() : Synchronization_Exception("Timeout") { } - //! Create a new - Timeout_Exception(const char*msg) : Synchronization_Exception(msg) { } - -}; - -/** - * @class NoSuchElement_Exception - * - * The last operation that was attempted on a Queue could not find - * the item that was indicated (during that last Queue method invocation) - */ -class NoSuchElement_Exception { - public: - - //! Create a new exception - NoSuchElement_Exception() {} - -}; - -/** - * @class InvalidTask_Exception - * - * Thrown when a task is not valid (e.g. null or start()ing a thread with - * no overriden run() method) - */ -class InvalidTask_Exception : public InvalidOp_Exception { - public: - - //! Create a new exception - InvalidTask_Exception() : InvalidOp_Exception("Invalid task") {} - -}; - -/** - * @class BrokenBarrier_Exception - * - * Thrown when a Barrier is broken because one of the participating threads - * has been interrupted. - */ -class BrokenBarrier_Exception : public Synchronization_Exception { - - public: - - //! Create a new exception - BrokenBarrier_Exception() : Synchronization_Exception("Barrier broken") { } - - //! Create a new exception - BrokenBarrier_Exception(const char* msg) : Synchronization_Exception(msg) { } - -}; - -/** - * @class Future_Exception - * - * Thrown when there is an error using a Future. - */ -class Future_Exception : public Synchronization_Exception { - - public: - - //! Create a new exception - Future_Exception() : Synchronization_Exception() { } - - //! Create a new exception - Future_Exception(const char* msg) : Synchronization_Exception(msg) { } - -}; - -}; - -#endif // __ZTEXCEPTIONS_H__ - |