123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- //
- // io_service.ipp
- // ~~~~~~~~~~~~~~
- //
- // Copyright (c) 2003-2008 Christopher M. Kohlhoff (chris at kohlhoff dot com)
- //
- // 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_ASIO_IO_SERVICE_IPP
- #define BOOST_ASIO_IO_SERVICE_IPP
- #if defined(_MSC_VER) && (_MSC_VER >= 1200)
- # pragma once
- #endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
- #include <boost/asio/detail/push_options.hpp>
- #include <boost/asio/detail/push_options.hpp>
- #include <limits>
- #include <boost/asio/detail/pop_options.hpp>
- #include <boost/asio/detail/dev_poll_reactor.hpp>
- #include <boost/asio/detail/epoll_reactor.hpp>
- #include <boost/asio/detail/kqueue_reactor.hpp>
- #include <boost/asio/detail/select_reactor.hpp>
- #include <boost/asio/detail/service_registry.hpp>
- #include <boost/asio/detail/task_io_service.hpp>
- #include <boost/asio/detail/throw_error.hpp>
- #include <boost/asio/detail/win_iocp_io_service.hpp>
- namespace boost {
- namespace asio {
- inline io_service::io_service()
- : service_registry_(new boost::asio::detail::service_registry(*this)),
- impl_(service_registry_->use_service<impl_type>())
- {
- impl_.init((std::numeric_limits<std::size_t>::max)());
- }
- inline io_service::io_service(std::size_t concurrency_hint)
- : service_registry_(new boost::asio::detail::service_registry(*this)),
- impl_(service_registry_->use_service<impl_type>())
- {
- impl_.init(concurrency_hint);
- }
- inline io_service::~io_service()
- {
- delete service_registry_;
- }
- inline std::size_t io_service::run()
- {
- boost::system::error_code ec;
- std::size_t s = impl_.run(ec);
- boost::asio::detail::throw_error(ec);
- return s;
- }
- inline std::size_t io_service::run(boost::system::error_code& ec)
- {
- return impl_.run(ec);
- }
- inline std::size_t io_service::run_one()
- {
- boost::system::error_code ec;
- std::size_t s = impl_.run_one(ec);
- boost::asio::detail::throw_error(ec);
- return s;
- }
- inline std::size_t io_service::run_one(boost::system::error_code& ec)
- {
- return impl_.run_one(ec);
- }
- inline std::size_t io_service::poll()
- {
- boost::system::error_code ec;
- std::size_t s = impl_.poll(ec);
- boost::asio::detail::throw_error(ec);
- return s;
- }
- inline std::size_t io_service::poll(boost::system::error_code& ec)
- {
- return impl_.poll(ec);
- }
- inline std::size_t io_service::poll_one()
- {
- boost::system::error_code ec;
- std::size_t s = impl_.poll_one(ec);
- boost::asio::detail::throw_error(ec);
- return s;
- }
- inline std::size_t io_service::poll_one(boost::system::error_code& ec)
- {
- return impl_.poll_one(ec);
- }
- inline void io_service::stop()
- {
- impl_.stop();
- }
- inline void io_service::reset()
- {
- impl_.reset();
- }
- template <typename Handler>
- inline void io_service::dispatch(Handler handler)
- {
- impl_.dispatch(handler);
- }
- template <typename Handler>
- inline void io_service::post(Handler handler)
- {
- impl_.post(handler);
- }
- template <typename Handler>
- #if defined(GENERATING_DOCUMENTATION)
- unspecified
- #else
- inline detail::wrapped_handler<io_service&, Handler>
- #endif
- io_service::wrap(Handler handler)
- {
- return detail::wrapped_handler<io_service&, Handler>(*this, handler);
- }
- inline io_service::work::work(boost::asio::io_service& io_service)
- : io_service_(io_service)
- {
- io_service_.impl_.work_started();
- }
- inline io_service::work::work(const work& other)
- : io_service_(other.io_service_)
- {
- io_service_.impl_.work_started();
- }
- inline io_service::work::~work()
- {
- io_service_.impl_.work_finished();
- }
- inline boost::asio::io_service& io_service::work::io_service()
- {
- return io_service_;
- }
- inline boost::asio::io_service& io_service::work::get_io_service()
- {
- return io_service_;
- }
- inline io_service::service::service(boost::asio::io_service& owner)
- : owner_(owner),
- type_info_(0),
- next_(0)
- {
- }
- inline io_service::service::~service()
- {
- }
- inline boost::asio::io_service& io_service::service::io_service()
- {
- return owner_;
- }
- inline boost::asio::io_service& io_service::service::get_io_service()
- {
- return owner_;
- }
- template <typename Service>
- inline Service& use_service(io_service& ios)
- {
- // Check that Service meets the necessary type requirements.
- (void)static_cast<io_service::service*>(static_cast<Service*>(0));
- (void)static_cast<const io_service::id*>(&Service::id);
- return ios.service_registry_->template use_service<Service>();
- }
- template <typename Service>
- void add_service(io_service& ios, Service* svc)
- {
- // Check that Service meets the necessary type requirements.
- (void)static_cast<io_service::service*>(static_cast<Service*>(0));
- (void)static_cast<const io_service::id*>(&Service::id);
- if (&ios != &svc->io_service())
- boost::throw_exception(invalid_service_owner());
- if (!ios.service_registry_->template add_service<Service>(svc))
- boost::throw_exception(service_already_exists());
- }
- template <typename Service>
- bool has_service(io_service& ios)
- {
- // Check that Service meets the necessary type requirements.
- (void)static_cast<io_service::service*>(static_cast<Service*>(0));
- (void)static_cast<const io_service::id*>(&Service::id);
- return ios.service_registry_->template has_service<Service>();
- }
- } // namespace asio
- } // namespace boost
- #include <boost/asio/detail/pop_options.hpp>
- #endif // BOOST_ASIO_IO_SERVICE_IPP
|