PATH:
opt
/
cpanel
/
ea-ruby27
/
src
/
passenger-release-6.1.2
/
src
/
cxx_supportlib
/
vendor-modified
/
boost
/
thread
// Copyright (C) 2001-2003 // William E. Kempf // Copyright (C) 2007-9 Anthony Williams // (C) Copyright 2011-2012 Vicente J. Botet Escriba // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifndef BOOST_THREAD_EXCEPTIONS_PDM070801_H #define BOOST_THREAD_EXCEPTIONS_PDM070801_H #include <boost/thread/detail/config.hpp> // pdm: Sorry, but this class is used all over the place & I end up // with recursive headers if I don't separate it // wek: Not sure why recursive headers would cause compilation problems // given the include guards, but regardless it makes sense to // seperate this out any way. #include <string> #include <stdexcept> #include <boost/system/system_error.hpp> #include <boost/system/error_code.hpp> #include <oxt/tracable_exception.hpp> #include <boost/config/abi_prefix.hpp> namespace boost { #if defined BOOST_THREAD_PROVIDES_INTERRUPTIONS class BOOST_SYMBOL_VISIBLE thread_interrupted : public oxt::tracable_exception {}; #endif class BOOST_SYMBOL_VISIBLE thread_exception: public system::system_error //public std::exception { typedef system::system_error base_type; public: thread_exception() : base_type(0,system::generic_category()) {} thread_exception(int sys_error_code) : base_type(sys_error_code, system::generic_category()) {} thread_exception( int ev, const char * what_arg ) : base_type(system::error_code(ev, system::generic_category()), what_arg) { } thread_exception( int ev, const std::string & what_arg ) : base_type(system::error_code(ev, system::generic_category()), what_arg) { } ~thread_exception() BOOST_NOEXCEPT_OR_NOTHROW {} int native_error() const { return code().value(); } }; class BOOST_SYMBOL_VISIBLE condition_error: public system::system_error //public std::exception { typedef system::system_error base_type; public: condition_error() : base_type(system::error_code(0, system::generic_category()), "Condition error") {} condition_error( int ev ) : base_type(system::error_code(ev, system::generic_category()), "Condition error") { } condition_error( int ev, const char * what_arg ) : base_type(system::error_code(ev, system::generic_category()), what_arg) { } condition_error( int ev, const std::string & what_arg ) : base_type(system::error_code(ev, system::generic_category()), what_arg) { } }; class BOOST_SYMBOL_VISIBLE lock_error: public thread_exception { typedef thread_exception base_type; public: lock_error() : base_type(0, "boost::lock_error") {} lock_error( int ev ) : base_type(ev, "boost::lock_error") { } lock_error( int ev, const char * what_arg ) : base_type(ev, what_arg) { } lock_error( int ev, const std::string & what_arg ) : base_type(ev, what_arg) { } ~lock_error() BOOST_NOEXCEPT_OR_NOTHROW {} }; class BOOST_SYMBOL_VISIBLE thread_resource_error: public thread_exception { typedef thread_exception base_type; public: thread_resource_error() : base_type(static_cast<int>(system::errc::resource_unavailable_try_again), "boost::thread_resource_error") {} thread_resource_error( int ev ) : base_type(ev, "boost::thread_resource_error") { } thread_resource_error( int ev, const char * what_arg ) : base_type(ev, what_arg) { } thread_resource_error( int ev, const std::string & what_arg ) : base_type(ev, what_arg) { } ~thread_resource_error() BOOST_NOEXCEPT_OR_NOTHROW {} }; class BOOST_SYMBOL_VISIBLE unsupported_thread_option: public thread_exception { typedef thread_exception base_type; public: unsupported_thread_option() : base_type(static_cast<int>(system::errc::invalid_argument), "boost::unsupported_thread_option") {} unsupported_thread_option( int ev ) : base_type(ev, "boost::unsupported_thread_option") { } unsupported_thread_option( int ev, const char * what_arg ) : base_type(ev, what_arg) { } unsupported_thread_option( int ev, const std::string & what_arg ) : base_type(ev, what_arg) { } }; class BOOST_SYMBOL_VISIBLE invalid_thread_argument: public thread_exception { typedef thread_exception base_type; public: invalid_thread_argument() : base_type(static_cast<int>(system::errc::invalid_argument), "boost::invalid_thread_argument") {} invalid_thread_argument( int ev ) : base_type(ev, "boost::invalid_thread_argument") { } invalid_thread_argument( int ev, const char * what_arg ) : base_type(ev, what_arg) { } invalid_thread_argument( int ev, const std::string & what_arg ) : base_type(ev, what_arg) { } }; class BOOST_SYMBOL_VISIBLE thread_permission_error: public thread_exception { typedef thread_exception base_type; public: thread_permission_error() : base_type(static_cast<int>(system::errc::permission_denied), "boost::thread_permission_error") {} thread_permission_error( int ev ) : base_type(ev, "boost::thread_permission_error") { } thread_permission_error( int ev, const char * what_arg ) : base_type(ev, what_arg) { } thread_permission_error( int ev, const std::string & what_arg ) : base_type(ev, what_arg) { } }; } // namespace boost #include <boost/config/abi_suffix.hpp> #endif
[-] caller_context.hpp
[edit]
[-] thread_time.hpp
[edit]
[-] thread_guard.hpp
[edit]
[+]
csbl
[-] scoped_thread.hpp
[edit]
[+]
concurrent_queues
[-] with_lock_guard.hpp
[edit]
[-] ostream_buffer.hpp
[edit]
[-] testable_mutex.hpp
[edit]
[-] lockable_traits.hpp
[edit]
[-] externally_locked.hpp
[edit]
[+]
v2
[-] lock_concepts.hpp
[edit]
[-] thread.hpp
[edit]
[-] is_locked_by_this_thread.hpp
[edit]
[-] locks.hpp
[edit]
[-] latch.hpp
[edit]
[-] barrier.hpp
[edit]
[-] condition.hpp
[edit]
[-] thread_pool.hpp
[edit]
[-] shared_lock_guard.hpp
[edit]
[-] cv_status.hpp
[edit]
[+]
..
[-] condition_variable.hpp
[edit]
[-] thread_only.hpp
[edit]
[-] exceptions.hpp
[edit]
[+]
executors
[-] sync_bounded_queue.hpp
[edit]
[-] poly_lockable.hpp
[edit]
[-] lock_guard.hpp
[edit]
[+]
experimental
[-] future.hpp
[edit]
[-] lock_types.hpp
[edit]
[+]
futures
[-] sync_queue.hpp
[edit]
[-] exceptional_ptr.hpp
[edit]
[-] lock_traits.hpp
[edit]
[-] mutex.hpp
[edit]
[-] lock_options.hpp
[edit]
[-] poly_lockable_adapter.hpp
[edit]
[-] poly_shared_lockable.hpp
[edit]
[-] interruption.hpp
[edit]
[-] poly_shared_lockable_adapter.hpp
[edit]
[-] synchronized_value.hpp
[edit]
[-] executor.hpp
[edit]
[-] completion_latch.hpp
[edit]
[-] lock_algorithms.hpp
[edit]
[-] tss.hpp
[edit]
[+]
detail
[+]
pthread
[-] recursive_mutex.hpp
[edit]
[-] lock_factories.hpp
[edit]
[-] user_scheduler.hpp
[edit]
[-] null_mutex.hpp
[edit]
[-] lockable_adapter.hpp
[edit]
[-] strict_lock.hpp
[edit]
[-] lockable_concepts.hpp
[edit]
[-] reverse_lock.hpp
[edit]
[-] shared_mutex.hpp
[edit]
[-] xtime.hpp
[edit]
[-] externally_locked_stream.hpp
[edit]
[-] once.hpp
[edit]
[-] thread_functors.hpp
[edit]