1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710 |
- //
- // basic_socket_acceptor.hpp
- // ~~~~~~~~~~~~~~~~~~~~~~~~~
- //
- // Copyright (c) 2003-2024 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_BASIC_SOCKET_ACCEPTOR_HPP
- #define BOOST_ASIO_BASIC_SOCKET_ACCEPTOR_HPP
- #if defined(_MSC_VER) && (_MSC_VER >= 1200)
- # pragma once
- #endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
- #include <utility>
- #include <boost/asio/detail/config.hpp>
- #include <boost/asio/any_io_executor.hpp>
- #include <boost/asio/basic_socket.hpp>
- #include <boost/asio/detail/handler_type_requirements.hpp>
- #include <boost/asio/detail/io_object_impl.hpp>
- #include <boost/asio/detail/non_const_lvalue.hpp>
- #include <boost/asio/detail/throw_error.hpp>
- #include <boost/asio/detail/type_traits.hpp>
- #include <boost/asio/error.hpp>
- #include <boost/asio/execution_context.hpp>
- #include <boost/asio/socket_base.hpp>
- #if defined(BOOST_ASIO_WINDOWS_RUNTIME)
- # include <boost/asio/detail/null_socket_service.hpp>
- #elif defined(BOOST_ASIO_HAS_IOCP)
- # include <boost/asio/detail/win_iocp_socket_service.hpp>
- #elif defined(BOOST_ASIO_HAS_IO_URING_AS_DEFAULT)
- # include <boost/asio/detail/io_uring_socket_service.hpp>
- #else
- # include <boost/asio/detail/reactive_socket_service.hpp>
- #endif
- #include <boost/asio/detail/push_options.hpp>
- namespace boost {
- namespace asio {
- #if !defined(BOOST_ASIO_BASIC_SOCKET_ACCEPTOR_FWD_DECL)
- #define BOOST_ASIO_BASIC_SOCKET_ACCEPTOR_FWD_DECL
- // Forward declaration with defaulted arguments.
- template <typename Protocol, typename Executor = any_io_executor>
- class basic_socket_acceptor;
- #endif // !defined(BOOST_ASIO_BASIC_SOCKET_ACCEPTOR_FWD_DECL)
- /// Provides the ability to accept new connections.
- /**
- * The basic_socket_acceptor class template is used for accepting new socket
- * connections.
- *
- * @par Thread Safety
- * @e Distinct @e objects: Safe.@n
- * @e Shared @e objects: Unsafe.
- *
- * Synchronous @c accept operations are thread safe, if the underlying
- * operating system calls are also thread safe. This means that it is permitted
- * to perform concurrent calls to synchronous @c accept operations on a single
- * socket object. Other synchronous operations, such as @c open or @c close, are
- * not thread safe.
- *
- * @par Example
- * Opening a socket acceptor with the SO_REUSEADDR option enabled:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), port);
- * acceptor.open(endpoint.protocol());
- * acceptor.set_option(boost::asio::ip::tcp::acceptor::reuse_address(true));
- * acceptor.bind(endpoint);
- * acceptor.listen();
- * @endcode
- */
- template <typename Protocol, typename Executor>
- class basic_socket_acceptor
- : public socket_base
- {
- private:
- class initiate_async_wait;
- class initiate_async_accept;
- class initiate_async_move_accept;
- public:
- /// The type of the executor associated with the object.
- typedef Executor executor_type;
- /// Rebinds the acceptor type to another executor.
- template <typename Executor1>
- struct rebind_executor
- {
- /// The socket type when rebound to the specified executor.
- typedef basic_socket_acceptor<Protocol, Executor1> other;
- };
- /// The native representation of an acceptor.
- #if defined(GENERATING_DOCUMENTATION)
- typedef implementation_defined native_handle_type;
- #elif defined(BOOST_ASIO_WINDOWS_RUNTIME)
- typedef typename detail::null_socket_service<
- Protocol>::native_handle_type native_handle_type;
- #elif defined(BOOST_ASIO_HAS_IOCP)
- typedef typename detail::win_iocp_socket_service<
- Protocol>::native_handle_type native_handle_type;
- #elif defined(BOOST_ASIO_HAS_IO_URING_AS_DEFAULT)
- typedef typename detail::io_uring_socket_service<
- Protocol>::native_handle_type native_handle_type;
- #else
- typedef typename detail::reactive_socket_service<
- Protocol>::native_handle_type native_handle_type;
- #endif
- /// The protocol type.
- typedef Protocol protocol_type;
- /// The endpoint type.
- typedef typename Protocol::endpoint endpoint_type;
- /// Construct an acceptor without opening it.
- /**
- * This constructor creates an acceptor without opening it to listen for new
- * connections. The open() function must be called before the acceptor can
- * accept new socket connections.
- *
- * @param ex The I/O executor that the acceptor will use, by default, to
- * dispatch handlers for any asynchronous operations performed on the
- * acceptor.
- */
- explicit basic_socket_acceptor(const executor_type& ex)
- : impl_(0, ex)
- {
- }
- /// Construct an acceptor without opening it.
- /**
- * This constructor creates an acceptor without opening it to listen for new
- * connections. The open() function must be called before the acceptor can
- * accept new socket connections.
- *
- * @param context An execution context which provides the I/O executor that
- * the acceptor will use, by default, to dispatch handlers for any
- * asynchronous operations performed on the acceptor.
- */
- template <typename ExecutionContext>
- explicit basic_socket_acceptor(ExecutionContext& context,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- : impl_(0, 0, context)
- {
- }
- /// Construct an open acceptor.
- /**
- * This constructor creates an acceptor and automatically opens it.
- *
- * @param ex The I/O executor that the acceptor will use, by default, to
- * dispatch handlers for any asynchronous operations performed on the
- * acceptor.
- *
- * @param protocol An object specifying protocol parameters to be used.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- basic_socket_acceptor(const executor_type& ex, const protocol_type& protocol)
- : impl_(0, ex)
- {
- boost::system::error_code ec;
- impl_.get_service().open(impl_.get_implementation(), protocol, ec);
- boost::asio::detail::throw_error(ec, "open");
- }
- /// Construct an open acceptor.
- /**
- * This constructor creates an acceptor and automatically opens it.
- *
- * @param context An execution context which provides the I/O executor that
- * the acceptor will use, by default, to dispatch handlers for any
- * asynchronous operations performed on the acceptor.
- *
- * @param protocol An object specifying protocol parameters to be used.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- template <typename ExecutionContext>
- basic_socket_acceptor(ExecutionContext& context,
- const protocol_type& protocol,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value,
- defaulted_constraint
- > = defaulted_constraint())
- : impl_(0, 0, context)
- {
- boost::system::error_code ec;
- impl_.get_service().open(impl_.get_implementation(), protocol, ec);
- boost::asio::detail::throw_error(ec, "open");
- }
- /// Construct an acceptor opened on the given endpoint.
- /**
- * This constructor creates an acceptor and automatically opens it to listen
- * for new connections on the specified endpoint.
- *
- * @param ex The I/O executor that the acceptor will use, by default, to
- * dispatch handlers for any asynchronous operations performed on the
- * acceptor.
- *
- * @param endpoint An endpoint on the local machine on which the acceptor
- * will listen for new connections.
- *
- * @param reuse_addr Whether the constructor should set the socket option
- * socket_base::reuse_address.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @note This constructor is equivalent to the following code:
- * @code
- * basic_socket_acceptor<Protocol> acceptor(my_context);
- * acceptor.open(endpoint.protocol());
- * if (reuse_addr)
- * acceptor.set_option(socket_base::reuse_address(true));
- * acceptor.bind(endpoint);
- * acceptor.listen();
- * @endcode
- */
- basic_socket_acceptor(const executor_type& ex,
- const endpoint_type& endpoint, bool reuse_addr = true)
- : impl_(0, ex)
- {
- boost::system::error_code ec;
- const protocol_type protocol = endpoint.protocol();
- impl_.get_service().open(impl_.get_implementation(), protocol, ec);
- boost::asio::detail::throw_error(ec, "open");
- if (reuse_addr)
- {
- impl_.get_service().set_option(impl_.get_implementation(),
- socket_base::reuse_address(true), ec);
- boost::asio::detail::throw_error(ec, "set_option");
- }
- impl_.get_service().bind(impl_.get_implementation(), endpoint, ec);
- boost::asio::detail::throw_error(ec, "bind");
- impl_.get_service().listen(impl_.get_implementation(),
- socket_base::max_listen_connections, ec);
- boost::asio::detail::throw_error(ec, "listen");
- }
- /// Construct an acceptor opened on the given endpoint.
- /**
- * This constructor creates an acceptor and automatically opens it to listen
- * for new connections on the specified endpoint.
- *
- * @param context An execution context which provides the I/O executor that
- * the acceptor will use, by default, to dispatch handlers for any
- * asynchronous operations performed on the acceptor.
- *
- * @param endpoint An endpoint on the local machine on which the acceptor
- * will listen for new connections.
- *
- * @param reuse_addr Whether the constructor should set the socket option
- * socket_base::reuse_address.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @note This constructor is equivalent to the following code:
- * @code
- * basic_socket_acceptor<Protocol> acceptor(my_context);
- * acceptor.open(endpoint.protocol());
- * if (reuse_addr)
- * acceptor.set_option(socket_base::reuse_address(true));
- * acceptor.bind(endpoint);
- * acceptor.listen();
- * @endcode
- */
- template <typename ExecutionContext>
- basic_socket_acceptor(ExecutionContext& context,
- const endpoint_type& endpoint, bool reuse_addr = true,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- : impl_(0, 0, context)
- {
- boost::system::error_code ec;
- const protocol_type protocol = endpoint.protocol();
- impl_.get_service().open(impl_.get_implementation(), protocol, ec);
- boost::asio::detail::throw_error(ec, "open");
- if (reuse_addr)
- {
- impl_.get_service().set_option(impl_.get_implementation(),
- socket_base::reuse_address(true), ec);
- boost::asio::detail::throw_error(ec, "set_option");
- }
- impl_.get_service().bind(impl_.get_implementation(), endpoint, ec);
- boost::asio::detail::throw_error(ec, "bind");
- impl_.get_service().listen(impl_.get_implementation(),
- socket_base::max_listen_connections, ec);
- boost::asio::detail::throw_error(ec, "listen");
- }
- /// Construct a basic_socket_acceptor on an existing native acceptor.
- /**
- * This constructor creates an acceptor object to hold an existing native
- * acceptor.
- *
- * @param ex The I/O executor that the acceptor will use, by default, to
- * dispatch handlers for any asynchronous operations performed on the
- * acceptor.
- *
- * @param protocol An object specifying protocol parameters to be used.
- *
- * @param native_acceptor A native acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- basic_socket_acceptor(const executor_type& ex,
- const protocol_type& protocol, const native_handle_type& native_acceptor)
- : impl_(0, ex)
- {
- boost::system::error_code ec;
- impl_.get_service().assign(impl_.get_implementation(),
- protocol, native_acceptor, ec);
- boost::asio::detail::throw_error(ec, "assign");
- }
- /// Construct a basic_socket_acceptor on an existing native acceptor.
- /**
- * This constructor creates an acceptor object to hold an existing native
- * acceptor.
- *
- * @param context An execution context which provides the I/O executor that
- * the acceptor will use, by default, to dispatch handlers for any
- * asynchronous operations performed on the acceptor.
- *
- * @param protocol An object specifying protocol parameters to be used.
- *
- * @param native_acceptor A native acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- template <typename ExecutionContext>
- basic_socket_acceptor(ExecutionContext& context,
- const protocol_type& protocol, const native_handle_type& native_acceptor,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- : impl_(0, 0, context)
- {
- boost::system::error_code ec;
- impl_.get_service().assign(impl_.get_implementation(),
- protocol, native_acceptor, ec);
- boost::asio::detail::throw_error(ec, "assign");
- }
- /// Move-construct a basic_socket_acceptor from another.
- /**
- * This constructor moves an acceptor from one object to another.
- *
- * @param other The other basic_socket_acceptor object from which the move
- * will occur.
- *
- * @note Following the move, the moved-from object is in the same state as if
- * constructed using the @c basic_socket_acceptor(const executor_type&)
- * constructor.
- */
- basic_socket_acceptor(basic_socket_acceptor&& other) noexcept
- : impl_(std::move(other.impl_))
- {
- }
- /// Move-assign a basic_socket_acceptor from another.
- /**
- * This assignment operator moves an acceptor from one object to another.
- *
- * @param other The other basic_socket_acceptor object from which the move
- * will occur.
- *
- * @note Following the move, the moved-from object is in the same state as if
- * constructed using the @c basic_socket_acceptor(const executor_type&)
- * constructor.
- */
- basic_socket_acceptor& operator=(basic_socket_acceptor&& other)
- {
- impl_ = std::move(other.impl_);
- return *this;
- }
- // All socket acceptors have access to each other's implementations.
- template <typename Protocol1, typename Executor1>
- friend class basic_socket_acceptor;
- /// Move-construct a basic_socket_acceptor from an acceptor of another
- /// protocol type.
- /**
- * This constructor moves an acceptor from one object to another.
- *
- * @param other The other basic_socket_acceptor object from which the move
- * will occur.
- *
- * @note Following the move, the moved-from object is in the same state as if
- * constructed using the @c basic_socket_acceptor(const executor_type&)
- * constructor.
- */
- template <typename Protocol1, typename Executor1>
- basic_socket_acceptor(basic_socket_acceptor<Protocol1, Executor1>&& other,
- constraint_t<
- is_convertible<Protocol1, Protocol>::value
- && is_convertible<Executor1, Executor>::value
- > = 0)
- : impl_(std::move(other.impl_))
- {
- }
- /// Move-assign a basic_socket_acceptor from an acceptor of another protocol
- /// type.
- /**
- * This assignment operator moves an acceptor from one object to another.
- *
- * @param other The other basic_socket_acceptor object from which the move
- * will occur.
- *
- * @note Following the move, the moved-from object is in the same state as if
- * constructed using the @c basic_socket_acceptor(const executor_type&)
- * constructor.
- */
- template <typename Protocol1, typename Executor1>
- constraint_t<
- is_convertible<Protocol1, Protocol>::value
- && is_convertible<Executor1, Executor>::value,
- basic_socket_acceptor&
- > operator=(basic_socket_acceptor<Protocol1, Executor1>&& other)
- {
- basic_socket_acceptor tmp(std::move(other));
- impl_ = std::move(tmp.impl_);
- return *this;
- }
- /// Destroys the acceptor.
- /**
- * This function destroys the acceptor, cancelling any outstanding
- * asynchronous operations associated with the acceptor as if by calling
- * @c cancel.
- */
- ~basic_socket_acceptor()
- {
- }
- /// Get the executor associated with the object.
- const executor_type& get_executor() noexcept
- {
- return impl_.get_executor();
- }
- /// Open the acceptor using the specified protocol.
- /**
- * This function opens the socket acceptor so that it will use the specified
- * protocol.
- *
- * @param protocol An object specifying which protocol is to be used.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * acceptor.open(boost::asio::ip::tcp::v4());
- * @endcode
- */
- void open(const protocol_type& protocol = protocol_type())
- {
- boost::system::error_code ec;
- impl_.get_service().open(impl_.get_implementation(), protocol, ec);
- boost::asio::detail::throw_error(ec, "open");
- }
- /// Open the acceptor using the specified protocol.
- /**
- * This function opens the socket acceptor so that it will use the specified
- * protocol.
- *
- * @param protocol An object specifying which protocol is to be used.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * boost::system::error_code ec;
- * acceptor.open(boost::asio::ip::tcp::v4(), ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- BOOST_ASIO_SYNC_OP_VOID open(const protocol_type& protocol,
- boost::system::error_code& ec)
- {
- impl_.get_service().open(impl_.get_implementation(), protocol, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Assigns an existing native acceptor to the acceptor.
- /*
- * This function opens the acceptor to hold an existing native acceptor.
- *
- * @param protocol An object specifying which protocol is to be used.
- *
- * @param native_acceptor A native acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- void assign(const protocol_type& protocol,
- const native_handle_type& native_acceptor)
- {
- boost::system::error_code ec;
- impl_.get_service().assign(impl_.get_implementation(),
- protocol, native_acceptor, ec);
- boost::asio::detail::throw_error(ec, "assign");
- }
- /// Assigns an existing native acceptor to the acceptor.
- /*
- * This function opens the acceptor to hold an existing native acceptor.
- *
- * @param protocol An object specifying which protocol is to be used.
- *
- * @param native_acceptor A native acceptor.
- *
- * @param ec Set to indicate what error occurred, if any.
- */
- BOOST_ASIO_SYNC_OP_VOID assign(const protocol_type& protocol,
- const native_handle_type& native_acceptor, boost::system::error_code& ec)
- {
- impl_.get_service().assign(impl_.get_implementation(),
- protocol, native_acceptor, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Determine whether the acceptor is open.
- bool is_open() const
- {
- return impl_.get_service().is_open(impl_.get_implementation());
- }
- /// Bind the acceptor to the given local endpoint.
- /**
- * This function binds the socket acceptor to the specified endpoint on the
- * local machine.
- *
- * @param endpoint An endpoint on the local machine to which the socket
- * acceptor will be bound.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), 12345);
- * acceptor.open(endpoint.protocol());
- * acceptor.bind(endpoint);
- * @endcode
- */
- void bind(const endpoint_type& endpoint)
- {
- boost::system::error_code ec;
- impl_.get_service().bind(impl_.get_implementation(), endpoint, ec);
- boost::asio::detail::throw_error(ec, "bind");
- }
- /// Bind the acceptor to the given local endpoint.
- /**
- * This function binds the socket acceptor to the specified endpoint on the
- * local machine.
- *
- * @param endpoint An endpoint on the local machine to which the socket
- * acceptor will be bound.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * boost::asio::ip::tcp::endpoint endpoint(boost::asio::ip::tcp::v4(), 12345);
- * acceptor.open(endpoint.protocol());
- * boost::system::error_code ec;
- * acceptor.bind(endpoint, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- BOOST_ASIO_SYNC_OP_VOID bind(const endpoint_type& endpoint,
- boost::system::error_code& ec)
- {
- impl_.get_service().bind(impl_.get_implementation(), endpoint, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Place the acceptor into the state where it will listen for new
- /// connections.
- /**
- * This function puts the socket acceptor into the state where it may accept
- * new connections.
- *
- * @param backlog The maximum length of the queue of pending connections.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- void listen(int backlog = socket_base::max_listen_connections)
- {
- boost::system::error_code ec;
- impl_.get_service().listen(impl_.get_implementation(), backlog, ec);
- boost::asio::detail::throw_error(ec, "listen");
- }
- /// Place the acceptor into the state where it will listen for new
- /// connections.
- /**
- * This function puts the socket acceptor into the state where it may accept
- * new connections.
- *
- * @param backlog The maximum length of the queue of pending connections.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::system::error_code ec;
- * acceptor.listen(boost::asio::socket_base::max_listen_connections, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- BOOST_ASIO_SYNC_OP_VOID listen(int backlog, boost::system::error_code& ec)
- {
- impl_.get_service().listen(impl_.get_implementation(), backlog, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Close the acceptor.
- /**
- * This function is used to close the acceptor. Any asynchronous accept
- * operations will be cancelled immediately.
- *
- * A subsequent call to open() is required before the acceptor can again be
- * used to again perform socket accept operations.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- void close()
- {
- boost::system::error_code ec;
- impl_.get_service().close(impl_.get_implementation(), ec);
- boost::asio::detail::throw_error(ec, "close");
- }
- /// Close the acceptor.
- /**
- * This function is used to close the acceptor. Any asynchronous accept
- * operations will be cancelled immediately.
- *
- * A subsequent call to open() is required before the acceptor can again be
- * used to again perform socket accept operations.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::system::error_code ec;
- * acceptor.close(ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- BOOST_ASIO_SYNC_OP_VOID close(boost::system::error_code& ec)
- {
- impl_.get_service().close(impl_.get_implementation(), ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Release ownership of the underlying native acceptor.
- /**
- * This function causes all outstanding asynchronous accept operations to
- * finish immediately, and the handlers for cancelled operations will be
- * passed the boost::asio::error::operation_aborted error. Ownership of the
- * native acceptor is then transferred to the caller.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @note This function is unsupported on Windows versions prior to Windows
- * 8.1, and will fail with boost::asio::error::operation_not_supported on
- * these platforms.
- */
- #if defined(BOOST_ASIO_MSVC) && (BOOST_ASIO_MSVC >= 1400) \
- && (!defined(_WIN32_WINNT) || _WIN32_WINNT < 0x0603)
- __declspec(deprecated("This function always fails with "
- "operation_not_supported when used on Windows versions "
- "prior to Windows 8.1."))
- #endif
- native_handle_type release()
- {
- boost::system::error_code ec;
- native_handle_type s = impl_.get_service().release(
- impl_.get_implementation(), ec);
- boost::asio::detail::throw_error(ec, "release");
- return s;
- }
- /// Release ownership of the underlying native acceptor.
- /**
- * This function causes all outstanding asynchronous accept operations to
- * finish immediately, and the handlers for cancelled operations will be
- * passed the boost::asio::error::operation_aborted error. Ownership of the
- * native acceptor is then transferred to the caller.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @note This function is unsupported on Windows versions prior to Windows
- * 8.1, and will fail with boost::asio::error::operation_not_supported on
- * these platforms.
- */
- #if defined(BOOST_ASIO_MSVC) && (BOOST_ASIO_MSVC >= 1400) \
- && (!defined(_WIN32_WINNT) || _WIN32_WINNT < 0x0603)
- __declspec(deprecated("This function always fails with "
- "operation_not_supported when used on Windows versions "
- "prior to Windows 8.1."))
- #endif
- native_handle_type release(boost::system::error_code& ec)
- {
- return impl_.get_service().release(impl_.get_implementation(), ec);
- }
- /// Get the native acceptor representation.
- /**
- * This function may be used to obtain the underlying representation of the
- * acceptor. This is intended to allow access to native acceptor functionality
- * that is not otherwise provided.
- */
- native_handle_type native_handle()
- {
- return impl_.get_service().native_handle(impl_.get_implementation());
- }
- /// Cancel all asynchronous operations associated with the acceptor.
- /**
- * This function causes all outstanding asynchronous connect, send and receive
- * operations to finish immediately, and the handlers for cancelled operations
- * will be passed the boost::asio::error::operation_aborted error.
- *
- * @throws boost::system::system_error Thrown on failure.
- */
- void cancel()
- {
- boost::system::error_code ec;
- impl_.get_service().cancel(impl_.get_implementation(), ec);
- boost::asio::detail::throw_error(ec, "cancel");
- }
- /// Cancel all asynchronous operations associated with the acceptor.
- /**
- * This function causes all outstanding asynchronous connect, send and receive
- * operations to finish immediately, and the handlers for cancelled operations
- * will be passed the boost::asio::error::operation_aborted error.
- *
- * @param ec Set to indicate what error occurred, if any.
- */
- BOOST_ASIO_SYNC_OP_VOID cancel(boost::system::error_code& ec)
- {
- impl_.get_service().cancel(impl_.get_implementation(), ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Set an option on the acceptor.
- /**
- * This function is used to set an option on the acceptor.
- *
- * @param option The new option value to be set on the acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @sa SettableSocketOption @n
- * boost::asio::socket_base::reuse_address
- * boost::asio::socket_base::enable_connection_aborted
- *
- * @par Example
- * Setting the SOL_SOCKET/SO_REUSEADDR option:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::acceptor::reuse_address option(true);
- * acceptor.set_option(option);
- * @endcode
- */
- template <typename SettableSocketOption>
- void set_option(const SettableSocketOption& option)
- {
- boost::system::error_code ec;
- impl_.get_service().set_option(impl_.get_implementation(), option, ec);
- boost::asio::detail::throw_error(ec, "set_option");
- }
- /// Set an option on the acceptor.
- /**
- * This function is used to set an option on the acceptor.
- *
- * @param option The new option value to be set on the acceptor.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @sa SettableSocketOption @n
- * boost::asio::socket_base::reuse_address
- * boost::asio::socket_base::enable_connection_aborted
- *
- * @par Example
- * Setting the SOL_SOCKET/SO_REUSEADDR option:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::acceptor::reuse_address option(true);
- * boost::system::error_code ec;
- * acceptor.set_option(option, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename SettableSocketOption>
- BOOST_ASIO_SYNC_OP_VOID set_option(const SettableSocketOption& option,
- boost::system::error_code& ec)
- {
- impl_.get_service().set_option(impl_.get_implementation(), option, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Get an option from the acceptor.
- /**
- * This function is used to get the current value of an option on the
- * acceptor.
- *
- * @param option The option value to be obtained from the acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @sa GettableSocketOption @n
- * boost::asio::socket_base::reuse_address
- *
- * @par Example
- * Getting the value of the SOL_SOCKET/SO_REUSEADDR option:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::acceptor::reuse_address option;
- * acceptor.get_option(option);
- * bool is_set = option.get();
- * @endcode
- */
- template <typename GettableSocketOption>
- void get_option(GettableSocketOption& option) const
- {
- boost::system::error_code ec;
- impl_.get_service().get_option(impl_.get_implementation(), option, ec);
- boost::asio::detail::throw_error(ec, "get_option");
- }
- /// Get an option from the acceptor.
- /**
- * This function is used to get the current value of an option on the
- * acceptor.
- *
- * @param option The option value to be obtained from the acceptor.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @sa GettableSocketOption @n
- * boost::asio::socket_base::reuse_address
- *
- * @par Example
- * Getting the value of the SOL_SOCKET/SO_REUSEADDR option:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::acceptor::reuse_address option;
- * boost::system::error_code ec;
- * acceptor.get_option(option, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * bool is_set = option.get();
- * @endcode
- */
- template <typename GettableSocketOption>
- BOOST_ASIO_SYNC_OP_VOID get_option(GettableSocketOption& option,
- boost::system::error_code& ec) const
- {
- impl_.get_service().get_option(impl_.get_implementation(), option, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Perform an IO control command on the acceptor.
- /**
- * This function is used to execute an IO control command on the acceptor.
- *
- * @param command The IO control command to be performed on the acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @sa IoControlCommand @n
- * boost::asio::socket_base::non_blocking_io
- *
- * @par Example
- * Getting the number of bytes ready to read:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::acceptor::non_blocking_io command(true);
- * socket.io_control(command);
- * @endcode
- */
- template <typename IoControlCommand>
- void io_control(IoControlCommand& command)
- {
- boost::system::error_code ec;
- impl_.get_service().io_control(impl_.get_implementation(), command, ec);
- boost::asio::detail::throw_error(ec, "io_control");
- }
- /// Perform an IO control command on the acceptor.
- /**
- * This function is used to execute an IO control command on the acceptor.
- *
- * @param command The IO control command to be performed on the acceptor.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @sa IoControlCommand @n
- * boost::asio::socket_base::non_blocking_io
- *
- * @par Example
- * Getting the number of bytes ready to read:
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::acceptor::non_blocking_io command(true);
- * boost::system::error_code ec;
- * socket.io_control(command, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename IoControlCommand>
- BOOST_ASIO_SYNC_OP_VOID io_control(IoControlCommand& command,
- boost::system::error_code& ec)
- {
- impl_.get_service().io_control(impl_.get_implementation(), command, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Gets the non-blocking mode of the acceptor.
- /**
- * @returns @c true if the acceptor's synchronous operations will fail with
- * boost::asio::error::would_block if they are unable to perform the requested
- * operation immediately. If @c false, synchronous operations will block
- * until complete.
- *
- * @note The non-blocking mode has no effect on the behaviour of asynchronous
- * operations. Asynchronous operations will never fail with the error
- * boost::asio::error::would_block.
- */
- bool non_blocking() const
- {
- return impl_.get_service().non_blocking(impl_.get_implementation());
- }
- /// Sets the non-blocking mode of the acceptor.
- /**
- * @param mode If @c true, the acceptor's synchronous operations will fail
- * with boost::asio::error::would_block if they are unable to perform the
- * requested operation immediately. If @c false, synchronous operations will
- * block until complete.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @note The non-blocking mode has no effect on the behaviour of asynchronous
- * operations. Asynchronous operations will never fail with the error
- * boost::asio::error::would_block.
- */
- void non_blocking(bool mode)
- {
- boost::system::error_code ec;
- impl_.get_service().non_blocking(impl_.get_implementation(), mode, ec);
- boost::asio::detail::throw_error(ec, "non_blocking");
- }
- /// Sets the non-blocking mode of the acceptor.
- /**
- * @param mode If @c true, the acceptor's synchronous operations will fail
- * with boost::asio::error::would_block if they are unable to perform the
- * requested operation immediately. If @c false, synchronous operations will
- * block until complete.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @note The non-blocking mode has no effect on the behaviour of asynchronous
- * operations. Asynchronous operations will never fail with the error
- * boost::asio::error::would_block.
- */
- BOOST_ASIO_SYNC_OP_VOID non_blocking(
- bool mode, boost::system::error_code& ec)
- {
- impl_.get_service().non_blocking(impl_.get_implementation(), mode, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Gets the non-blocking mode of the native acceptor implementation.
- /**
- * This function is used to retrieve the non-blocking mode of the underlying
- * native acceptor. This mode has no effect on the behaviour of the acceptor
- * object's synchronous operations.
- *
- * @returns @c true if the underlying acceptor is in non-blocking mode and
- * direct system calls may fail with boost::asio::error::would_block (or the
- * equivalent system error).
- *
- * @note The current non-blocking mode is cached by the acceptor object.
- * Consequently, the return value may be incorrect if the non-blocking mode
- * was set directly on the native acceptor.
- */
- bool native_non_blocking() const
- {
- return impl_.get_service().native_non_blocking(impl_.get_implementation());
- }
- /// Sets the non-blocking mode of the native acceptor implementation.
- /**
- * This function is used to modify the non-blocking mode of the underlying
- * native acceptor. It has no effect on the behaviour of the acceptor object's
- * synchronous operations.
- *
- * @param mode If @c true, the underlying acceptor is put into non-blocking
- * mode and direct system calls may fail with boost::asio::error::would_block
- * (or the equivalent system error).
- *
- * @throws boost::system::system_error Thrown on failure. If the @c mode is
- * @c false, but the current value of @c non_blocking() is @c true, this
- * function fails with boost::asio::error::invalid_argument, as the
- * combination does not make sense.
- */
- void native_non_blocking(bool mode)
- {
- boost::system::error_code ec;
- impl_.get_service().native_non_blocking(
- impl_.get_implementation(), mode, ec);
- boost::asio::detail::throw_error(ec, "native_non_blocking");
- }
- /// Sets the non-blocking mode of the native acceptor implementation.
- /**
- * This function is used to modify the non-blocking mode of the underlying
- * native acceptor. It has no effect on the behaviour of the acceptor object's
- * synchronous operations.
- *
- * @param mode If @c true, the underlying acceptor is put into non-blocking
- * mode and direct system calls may fail with boost::asio::error::would_block
- * (or the equivalent system error).
- *
- * @param ec Set to indicate what error occurred, if any. If the @c mode is
- * @c false, but the current value of @c non_blocking() is @c true, this
- * function fails with boost::asio::error::invalid_argument, as the
- * combination does not make sense.
- */
- BOOST_ASIO_SYNC_OP_VOID native_non_blocking(
- bool mode, boost::system::error_code& ec)
- {
- impl_.get_service().native_non_blocking(
- impl_.get_implementation(), mode, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Get the local endpoint of the acceptor.
- /**
- * This function is used to obtain the locally bound endpoint of the acceptor.
- *
- * @returns An object that represents the local endpoint of the acceptor.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint = acceptor.local_endpoint();
- * @endcode
- */
- endpoint_type local_endpoint() const
- {
- boost::system::error_code ec;
- endpoint_type ep = impl_.get_service().local_endpoint(
- impl_.get_implementation(), ec);
- boost::asio::detail::throw_error(ec, "local_endpoint");
- return ep;
- }
- /// Get the local endpoint of the acceptor.
- /**
- * This function is used to obtain the locally bound endpoint of the acceptor.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns An object that represents the local endpoint of the acceptor.
- * Returns a default-constructed endpoint object if an error occurred and the
- * error handler did not throw an exception.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::system::error_code ec;
- * boost::asio::ip::tcp::endpoint endpoint = acceptor.local_endpoint(ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- endpoint_type local_endpoint(boost::system::error_code& ec) const
- {
- return impl_.get_service().local_endpoint(impl_.get_implementation(), ec);
- }
- /// Wait for the acceptor to become ready to read, ready to write, or to have
- /// pending error conditions.
- /**
- * This function is used to perform a blocking wait for an acceptor to enter
- * a ready to read, write or error condition state.
- *
- * @param w Specifies the desired acceptor state.
- *
- * @par Example
- * Waiting for an acceptor to become readable.
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * acceptor.wait(boost::asio::ip::tcp::acceptor::wait_read);
- * @endcode
- */
- void wait(wait_type w)
- {
- boost::system::error_code ec;
- impl_.get_service().wait(impl_.get_implementation(), w, ec);
- boost::asio::detail::throw_error(ec, "wait");
- }
- /// Wait for the acceptor to become ready to read, ready to write, or to have
- /// pending error conditions.
- /**
- * This function is used to perform a blocking wait for an acceptor to enter
- * a ready to read, write or error condition state.
- *
- * @param w Specifies the desired acceptor state.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * Waiting for an acceptor to become readable.
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::system::error_code ec;
- * acceptor.wait(boost::asio::ip::tcp::acceptor::wait_read, ec);
- * @endcode
- */
- BOOST_ASIO_SYNC_OP_VOID wait(wait_type w, boost::system::error_code& ec)
- {
- impl_.get_service().wait(impl_.get_implementation(), w, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Asynchronously wait for the acceptor to become ready to read, ready to
- /// write, or to have pending error conditions.
- /**
- * This function is used to perform an asynchronous wait for an acceptor to
- * enter a ready to read, write or error condition state. It is an initiating
- * function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * @param w Specifies the desired acceptor state.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the wait completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * const boost::system::error_code& error // Result of operation.
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code) @endcode
- *
- * @par Example
- * @code
- * void wait_handler(const boost::system::error_code& error)
- * {
- * if (!error)
- * {
- * // Wait succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * acceptor.async_wait(
- * boost::asio::ip::tcp::acceptor::wait_read,
- * wait_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code))
- WaitToken = default_completion_token_t<executor_type>>
- auto async_wait(wait_type w,
- WaitToken&& token = default_completion_token_t<executor_type>())
- -> decltype(
- async_initiate<WaitToken, void (boost::system::error_code)>(
- declval<initiate_async_wait>(), token, w))
- {
- return async_initiate<WaitToken, void (boost::system::error_code)>(
- initiate_async_wait(this), token, w);
- }
- #if !defined(BOOST_ASIO_NO_EXTENSIONS)
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer into the
- * given socket. The function call will block until a new connection has been
- * accepted successfully or an error occurs.
- *
- * @param peer The socket into which the new connection will be accepted.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(my_context);
- * acceptor.accept(socket);
- * @endcode
- */
- template <typename Protocol1, typename Executor1>
- void accept(basic_socket<Protocol1, Executor1>& peer,
- constraint_t<
- is_convertible<Protocol, Protocol1>::value
- > = 0)
- {
- boost::system::error_code ec;
- impl_.get_service().accept(impl_.get_implementation(),
- peer, static_cast<endpoint_type*>(0), ec);
- boost::asio::detail::throw_error(ec, "accept");
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer into the
- * given socket. The function call will block until a new connection has been
- * accepted successfully or an error occurs.
- *
- * @param peer The socket into which the new connection will be accepted.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(my_context);
- * boost::system::error_code ec;
- * acceptor.accept(socket, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename Protocol1, typename Executor1>
- BOOST_ASIO_SYNC_OP_VOID accept(
- basic_socket<Protocol1, Executor1>& peer, boost::system::error_code& ec,
- constraint_t<
- is_convertible<Protocol, Protocol1>::value
- > = 0)
- {
- impl_.get_service().accept(impl_.get_implementation(),
- peer, static_cast<endpoint_type*>(0), ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection into a
- * socket, and additionally obtain the endpoint of the remote peer. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * @param peer The socket into which the new connection will be accepted.
- * Ownership of the peer object is retained by the caller, which must
- * guarantee that it is valid until the completion handler is called.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * const boost::system::error_code& error // Result of operation.
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(my_context);
- * acceptor.async_accept(socket, accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <typename Protocol1, typename Executor1,
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code))
- AcceptToken = default_completion_token_t<executor_type>>
- auto async_accept(basic_socket<Protocol1, Executor1>& peer,
- AcceptToken&& token = default_completion_token_t<executor_type>(),
- constraint_t<
- is_convertible<Protocol, Protocol1>::value
- > = 0)
- -> decltype(
- async_initiate<AcceptToken, void (boost::system::error_code)>(
- declval<initiate_async_accept>(), token,
- &peer, static_cast<endpoint_type*>(0)))
- {
- return async_initiate<AcceptToken, void (boost::system::error_code)>(
- initiate_async_accept(this), token,
- &peer, static_cast<endpoint_type*>(0));
- }
- /// Accept a new connection and obtain the endpoint of the peer
- /**
- * This function is used to accept a new connection from a peer into the
- * given socket, and additionally provide the endpoint of the remote peer.
- * The function call will block until a new connection has been accepted
- * successfully or an error occurs.
- *
- * @param peer The socket into which the new connection will be accepted.
- *
- * @param peer_endpoint An endpoint object which will receive the endpoint of
- * the remote peer.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(my_context);
- * boost::asio::ip::tcp::endpoint endpoint;
- * acceptor.accept(socket, endpoint);
- * @endcode
- */
- template <typename Executor1>
- void accept(basic_socket<protocol_type, Executor1>& peer,
- endpoint_type& peer_endpoint)
- {
- boost::system::error_code ec;
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- boost::asio::detail::throw_error(ec, "accept");
- }
- /// Accept a new connection and obtain the endpoint of the peer
- /**
- * This function is used to accept a new connection from a peer into the
- * given socket, and additionally provide the endpoint of the remote peer.
- * The function call will block until a new connection has been accepted
- * successfully or an error occurs.
- *
- * @param peer The socket into which the new connection will be accepted.
- *
- * @param peer_endpoint An endpoint object which will receive the endpoint of
- * the remote peer.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(my_context);
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::system::error_code ec;
- * acceptor.accept(socket, endpoint, ec);
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename Executor1>
- BOOST_ASIO_SYNC_OP_VOID accept(basic_socket<protocol_type, Executor1>& peer,
- endpoint_type& peer_endpoint, boost::system::error_code& ec)
- {
- impl_.get_service().accept(
- impl_.get_implementation(), peer, &peer_endpoint, ec);
- BOOST_ASIO_SYNC_OP_VOID_RETURN(ec);
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection into a
- * socket, and additionally obtain the endpoint of the remote peer. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * @param peer The socket into which the new connection will be accepted.
- * Ownership of the peer object is retained by the caller, which must
- * guarantee that it is valid until the completion handler is called.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written. Ownership of the peer_endpoint object is
- * retained by the caller, which must guarantee that it is valid until the
- * handler is called.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * const boost::system::error_code& error // Result of operation.
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code) @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <typename Executor1,
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code))
- AcceptToken = default_completion_token_t<executor_type>>
- auto async_accept(basic_socket<protocol_type, Executor1>& peer,
- endpoint_type& peer_endpoint,
- AcceptToken&& token = default_completion_token_t<executor_type>())
- -> decltype(
- async_initiate<AcceptToken, void (boost::system::error_code)>(
- declval<initiate_async_accept>(), token, &peer, &peer_endpoint))
- {
- return async_initiate<AcceptToken, void (boost::system::error_code)>(
- initiate_async_accept(this), token, &peer, &peer_endpoint);
- }
- #endif // !defined(BOOST_ASIO_NO_EXTENSIONS)
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @returns A socket object representing the newly accepted connection.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(acceptor.accept());
- * @endcode
- */
- typename Protocol::socket::template rebind_executor<executor_type>::other
- accept()
- {
- boost::system::error_code ec;
- typename Protocol::socket::template rebind_executor<
- executor_type>::other peer(impl_.get_executor());
- impl_.get_service().accept(impl_.get_implementation(), peer, 0, ec);
- boost::asio::detail::throw_error(ec, "accept");
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns On success, a socket object representing the newly accepted
- * connection. On error, a socket object where is_open() is false.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(acceptor.accept(ec));
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- typename Protocol::socket::template rebind_executor<executor_type>::other
- accept(boost::system::error_code& ec)
- {
- typename Protocol::socket::template rebind_executor<
- executor_type>::other peer(impl_.get_executor());
- impl_.get_service().accept(impl_.get_implementation(), peer, 0, ec);
- return peer;
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * // Result of operation.
- * const boost::system::error_code& error,
- *
- * // On success, the newly accepted socket.
- * typename Protocol::socket::template
- * rebind_executor<executor_type>::other peer
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code,
- * typename Protocol::socket::template
- * rebind_executor<executor_type>::other)) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error,
- * boost::asio::ip::tcp::socket peer)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * acceptor.async_accept(accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- executor_type>::other)) MoveAcceptToken
- = default_completion_token_t<executor_type>>
- auto async_accept(
- MoveAcceptToken&& token = default_completion_token_t<executor_type>())
- -> decltype(
- async_initiate<MoveAcceptToken,
- void (boost::system::error_code, typename Protocol::socket::template
- rebind_executor<executor_type>::other)>(
- declval<initiate_async_move_accept>(), token,
- declval<const executor_type&>(), static_cast<endpoint_type*>(0),
- static_cast<typename Protocol::socket::template
- rebind_executor<executor_type>::other*>(0)))
- {
- return async_initiate<MoveAcceptToken,
- void (boost::system::error_code, typename Protocol::socket::template
- rebind_executor<executor_type>::other)>(
- initiate_async_move_accept(this), token,
- impl_.get_executor(), static_cast<endpoint_type*>(0),
- static_cast<typename Protocol::socket::template
- rebind_executor<executor_type>::other*>(0));
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ex The I/O executor object to be used for the newly
- * accepted socket.
- *
- * @returns A socket object representing the newly accepted connection.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(acceptor.accept());
- * @endcode
- */
- template <typename Executor1>
- typename Protocol::socket::template rebind_executor<Executor1>::other
- accept(const Executor1& ex,
- constraint_t<
- is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value
- > = 0)
- {
- boost::system::error_code ec;
- typename Protocol::socket::template
- rebind_executor<Executor1>::other peer(ex);
- impl_.get_service().accept(impl_.get_implementation(), peer, 0, ec);
- boost::asio::detail::throw_error(ec, "accept");
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param context The I/O execution context object to be used for the newly
- * accepted socket.
- *
- * @returns A socket object representing the newly accepted connection.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(acceptor.accept());
- * @endcode
- */
- template <typename ExecutionContext>
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other
- accept(ExecutionContext& context,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- {
- boost::system::error_code ec;
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other peer(context);
- impl_.get_service().accept(impl_.get_implementation(), peer, 0, ec);
- boost::asio::detail::throw_error(ec, "accept");
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ex The I/O executor object to be used for the newly accepted
- * socket.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns On success, a socket object representing the newly accepted
- * connection. On error, a socket object where is_open() is false.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(acceptor.accept(my_context2, ec));
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename Executor1>
- typename Protocol::socket::template rebind_executor<Executor1>::other
- accept(const Executor1& ex, boost::system::error_code& ec,
- constraint_t<
- is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value
- > = 0)
- {
- typename Protocol::socket::template
- rebind_executor<Executor1>::other peer(ex);
- impl_.get_service().accept(impl_.get_implementation(), peer, 0, ec);
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param context The I/O execution context object to be used for the newly
- * accepted socket.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns On success, a socket object representing the newly accepted
- * connection. On error, a socket object where is_open() is false.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::socket socket(acceptor.accept(my_context2, ec));
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename ExecutionContext>
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other
- accept(ExecutionContext& context, boost::system::error_code& ec,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- {
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other peer(context);
- impl_.get_service().accept(impl_.get_implementation(), peer, 0, ec);
- return peer;
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ex The I/O executor object to be used for the newly accepted
- * socket.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * // Result of operation.
- * const boost::system::error_code& error,
- *
- * // On success, the newly accepted socket.
- * typename Protocol::socket::template rebind_executor<
- * Executor1>::other peer
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code,
- * typename Protocol::socket::template rebind_executor<
- * Executor1>::other)) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error,
- * boost::asio::ip::tcp::socket peer)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * acceptor.async_accept(my_context2, accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <typename Executor1,
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- constraint_t<is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value,
- Executor1>>::other)) MoveAcceptToken
- = default_completion_token_t<executor_type>>
- auto async_accept(const Executor1& ex,
- MoveAcceptToken&& token = default_completion_token_t<executor_type>(),
- constraint_t<
- is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value
- > = 0)
- -> decltype(
- async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- Executor1>::other)>(
- declval<initiate_async_move_accept>(), token,
- ex, static_cast<endpoint_type*>(0),
- static_cast<typename Protocol::socket::template
- rebind_executor<Executor1>::other*>(0)))
- {
- return async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- Executor1>::other)>(
- initiate_async_move_accept(this), token,
- ex, static_cast<endpoint_type*>(0),
- static_cast<typename Protocol::socket::template
- rebind_executor<Executor1>::other*>(0));
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param context The I/O execution context object to be used for the newly
- * accepted socket.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * // Result of operation.
- * const boost::system::error_code& error,
- *
- * // On success, the newly accepted socket.
- * typename Protocol::socket::template rebind_executor<
- * typename ExecutionContext::executor_type>::other peer
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code,
- * typename Protocol::socket::template rebind_executor<
- * typename ExecutionContext::executor_type>::other)) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error,
- * boost::asio::ip::tcp::socket peer)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * acceptor.async_accept(my_context2, accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <typename ExecutionContext,
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other)) MoveAcceptToken
- = default_completion_token_t<executor_type>>
- auto async_accept(ExecutionContext& context,
- MoveAcceptToken&& token = default_completion_token_t<executor_type>(),
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- -> decltype(
- async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other)>(
- declval<initiate_async_move_accept>(), token,
- context.get_executor(), static_cast<endpoint_type*>(0),
- static_cast<typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other*>(0)))
- {
- return async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other)>(
- initiate_async_move_accept(this), token,
- context.get_executor(), static_cast<endpoint_type*>(0),
- static_cast<typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other*>(0));
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written.
- *
- * @returns A socket object representing the newly accepted connection.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::asio::ip::tcp::socket socket(acceptor.accept(endpoint));
- * @endcode
- */
- typename Protocol::socket::template rebind_executor<executor_type>::other
- accept(endpoint_type& peer_endpoint)
- {
- boost::system::error_code ec;
- typename Protocol::socket::template rebind_executor<
- executor_type>::other peer(impl_.get_executor());
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- boost::asio::detail::throw_error(ec, "accept");
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns On success, a socket object representing the newly accepted
- * connection. On error, a socket object where is_open() is false.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::asio::ip::tcp::socket socket(acceptor.accept(endpoint, ec));
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- typename Protocol::socket::template rebind_executor<executor_type>::other
- accept(endpoint_type& peer_endpoint, boost::system::error_code& ec)
- {
- typename Protocol::socket::template rebind_executor<
- executor_type>::other peer(impl_.get_executor());
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- return peer;
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written. Ownership of the peer_endpoint object is
- * retained by the caller, which must guarantee that it is valid until the
- * completion handler is called.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * // Result of operation.
- * const boost::system::error_code& error,
- *
- * // On success, the newly accepted socket.
- * typename Protocol::socket::template
- * rebind_executor<executor_type>::other peer
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code,
- * typename Protocol::socket::template
- * rebind_executor<executor_type>::other)) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error,
- * boost::asio::ip::tcp::socket peer)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * acceptor.async_accept(endpoint, accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- executor_type>::other)) MoveAcceptToken
- = default_completion_token_t<executor_type>>
- auto async_accept(endpoint_type& peer_endpoint,
- MoveAcceptToken&& token = default_completion_token_t<executor_type>())
- -> decltype(
- async_initiate<MoveAcceptToken,
- void (boost::system::error_code, typename Protocol::socket::template
- rebind_executor<executor_type>::other)>(
- declval<initiate_async_move_accept>(), token,
- declval<const executor_type&>(), &peer_endpoint,
- static_cast<typename Protocol::socket::template
- rebind_executor<executor_type>::other*>(0)))
- {
- return async_initiate<MoveAcceptToken,
- void (boost::system::error_code, typename Protocol::socket::template
- rebind_executor<executor_type>::other)>(
- initiate_async_move_accept(this), token,
- impl_.get_executor(), &peer_endpoint,
- static_cast<typename Protocol::socket::template
- rebind_executor<executor_type>::other*>(0));
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ex The I/O executor object to be used for the newly accepted
- * socket.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written.
- *
- * @returns A socket object representing the newly accepted connection.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::asio::ip::tcp::socket socket(
- * acceptor.accept(my_context2, endpoint));
- * @endcode
- */
- template <typename Executor1>
- typename Protocol::socket::template rebind_executor<Executor1>::other
- accept(const Executor1& ex, endpoint_type& peer_endpoint,
- constraint_t<
- is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value
- > = 0)
- {
- boost::system::error_code ec;
- typename Protocol::socket::template
- rebind_executor<Executor1>::other peer(ex);
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- boost::asio::detail::throw_error(ec, "accept");
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param context The I/O execution context object to be used for the newly
- * accepted socket.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written.
- *
- * @returns A socket object representing the newly accepted connection.
- *
- * @throws boost::system::system_error Thrown on failure.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::asio::ip::tcp::socket socket(
- * acceptor.accept(my_context2, endpoint));
- * @endcode
- */
- template <typename ExecutionContext>
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other
- accept(ExecutionContext& context, endpoint_type& peer_endpoint,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- {
- boost::system::error_code ec;
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other peer(context);
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- boost::asio::detail::throw_error(ec, "accept");
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ex The I/O executor object to be used for the newly accepted
- * socket.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns On success, a socket object representing the newly accepted
- * connection. On error, a socket object where is_open() is false.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::asio::ip::tcp::socket socket(
- * acceptor.accept(my_context2, endpoint, ec));
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename Executor1>
- typename Protocol::socket::template rebind_executor<Executor1>::other
- accept(const executor_type& ex,
- endpoint_type& peer_endpoint, boost::system::error_code& ec,
- constraint_t<
- is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value
- > = 0)
- {
- typename Protocol::socket::template
- rebind_executor<Executor1>::other peer(ex);
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- return peer;
- }
- /// Accept a new connection.
- /**
- * This function is used to accept a new connection from a peer. The function
- * call will block until a new connection has been accepted successfully or
- * an error occurs.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param context The I/O execution context object to be used for the newly
- * accepted socket.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written.
- *
- * @param ec Set to indicate what error occurred, if any.
- *
- * @returns On success, a socket object representing the newly accepted
- * connection. On error, a socket object where is_open() is false.
- *
- * @par Example
- * @code
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * boost::asio::ip::tcp::socket socket(
- * acceptor.accept(my_context2, endpoint, ec));
- * if (ec)
- * {
- * // An error occurred.
- * }
- * @endcode
- */
- template <typename ExecutionContext>
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other
- accept(ExecutionContext& context,
- endpoint_type& peer_endpoint, boost::system::error_code& ec,
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- {
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other peer(context);
- impl_.get_service().accept(impl_.get_implementation(),
- peer, &peer_endpoint, ec);
- return peer;
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param ex The I/O executor object to be used for the newly accepted
- * socket.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written. Ownership of the peer_endpoint object is
- * retained by the caller, which must guarantee that it is valid until the
- * completion handler is called.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * // Result of operation.
- * const boost::system::error_code& error,
- *
- * // On success, the newly accepted socket.
- * typename Protocol::socket::template rebind_executor<
- * Executor1>::other peer
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code,
- * typename Protocol::socket::template rebind_executor<
- * Executor1>::other)) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error,
- * boost::asio::ip::tcp::socket peer)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * acceptor.async_accept(my_context2, endpoint, accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <typename Executor1,
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- constraint_t<is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value,
- Executor1>>::other)) MoveAcceptToken
- = default_completion_token_t<executor_type>>
- auto async_accept(const Executor1& ex, endpoint_type& peer_endpoint,
- MoveAcceptToken&& token = default_completion_token_t<executor_type>(),
- constraint_t<
- is_executor<Executor1>::value
- || execution::is_executor<Executor1>::value
- > = 0)
- -> decltype(
- async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- Executor1>::other)>(
- declval<initiate_async_move_accept>(), token, ex, &peer_endpoint,
- static_cast<typename Protocol::socket::template
- rebind_executor<Executor1>::other*>(0)))
- {
- return async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- Executor1>::other)>(
- initiate_async_move_accept(this), token, ex, &peer_endpoint,
- static_cast<typename Protocol::socket::template
- rebind_executor<Executor1>::other*>(0));
- }
- /// Start an asynchronous accept.
- /**
- * This function is used to asynchronously accept a new connection. It is an
- * initiating function for an @ref asynchronous_operation, and always returns
- * immediately.
- *
- * This overload requires that the Protocol template parameter satisfy the
- * AcceptableProtocol type requirements.
- *
- * @param context The I/O execution context object to be used for the newly
- * accepted socket.
- *
- * @param peer_endpoint An endpoint object into which the endpoint of the
- * remote peer will be written. Ownership of the peer_endpoint object is
- * retained by the caller, which must guarantee that it is valid until the
- * completion handler is called.
- *
- * @param token The @ref completion_token that will be used to produce a
- * completion handler, which will be called when the accept completes.
- * Potential completion tokens include @ref use_future, @ref use_awaitable,
- * @ref yield_context, or a function object with the correct completion
- * signature. The function signature of the completion handler must be:
- * @code void handler(
- * // Result of operation.
- * const boost::system::error_code& error,
- *
- * // On success, the newly accepted socket.
- * typename Protocol::socket::template rebind_executor<
- * typename ExecutionContext::executor_type>::other peer
- * ); @endcode
- * Regardless of whether the asynchronous operation completes immediately or
- * not, the completion handler will not be invoked from within this function.
- * On immediate completion, invocation of the handler will be performed in a
- * manner equivalent to using boost::asio::post().
- *
- * @par Completion Signature
- * @code void(boost::system::error_code,
- * typename Protocol::socket::template rebind_executor<
- * typename ExecutionContext::executor_type>::other)) @endcode
- *
- * @par Example
- * @code
- * void accept_handler(const boost::system::error_code& error,
- * boost::asio::ip::tcp::socket peer)
- * {
- * if (!error)
- * {
- * // Accept succeeded.
- * }
- * }
- *
- * ...
- *
- * boost::asio::ip::tcp::acceptor acceptor(my_context);
- * ...
- * boost::asio::ip::tcp::endpoint endpoint;
- * acceptor.async_accept(my_context2, endpoint, accept_handler);
- * @endcode
- *
- * @par Per-Operation Cancellation
- * On POSIX or Windows operating systems, this asynchronous operation supports
- * cancellation for the following boost::asio::cancellation_type values:
- *
- * @li @c cancellation_type::terminal
- *
- * @li @c cancellation_type::partial
- *
- * @li @c cancellation_type::total
- */
- template <typename ExecutionContext,
- BOOST_ASIO_COMPLETION_TOKEN_FOR(void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other)) MoveAcceptToken
- = default_completion_token_t<executor_type>>
- auto async_accept(ExecutionContext& context, endpoint_type& peer_endpoint,
- MoveAcceptToken&& token = default_completion_token_t<executor_type>(),
- constraint_t<
- is_convertible<ExecutionContext&, execution_context&>::value
- > = 0)
- -> decltype(
- async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other)>(
- declval<initiate_async_move_accept>(), token,
- context.get_executor(), &peer_endpoint,
- static_cast<typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other*>(0)))
- {
- return async_initiate<MoveAcceptToken,
- void (boost::system::error_code,
- typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other)>(
- initiate_async_move_accept(this), token,
- context.get_executor(), &peer_endpoint,
- static_cast<typename Protocol::socket::template rebind_executor<
- typename ExecutionContext::executor_type>::other*>(0));
- }
- private:
- // Disallow copying and assignment.
- basic_socket_acceptor(const basic_socket_acceptor&) = delete;
- basic_socket_acceptor& operator=(
- const basic_socket_acceptor&) = delete;
- class initiate_async_wait
- {
- public:
- typedef Executor executor_type;
- explicit initiate_async_wait(basic_socket_acceptor* self)
- : self_(self)
- {
- }
- const executor_type& get_executor() const noexcept
- {
- return self_->get_executor();
- }
- template <typename WaitHandler>
- void operator()(WaitHandler&& handler, wait_type w) const
- {
- // If you get an error on the following line it means that your handler
- // does not meet the documented type requirements for a WaitHandler.
- BOOST_ASIO_WAIT_HANDLER_CHECK(WaitHandler, handler) type_check;
- detail::non_const_lvalue<WaitHandler> handler2(handler);
- self_->impl_.get_service().async_wait(
- self_->impl_.get_implementation(), w,
- handler2.value, self_->impl_.get_executor());
- }
- private:
- basic_socket_acceptor* self_;
- };
- class initiate_async_accept
- {
- public:
- typedef Executor executor_type;
- explicit initiate_async_accept(basic_socket_acceptor* self)
- : self_(self)
- {
- }
- const executor_type& get_executor() const noexcept
- {
- return self_->get_executor();
- }
- template <typename AcceptHandler, typename Protocol1, typename Executor1>
- void operator()(AcceptHandler&& handler,
- basic_socket<Protocol1, Executor1>* peer,
- endpoint_type* peer_endpoint) const
- {
- // If you get an error on the following line it means that your handler
- // does not meet the documented type requirements for a AcceptHandler.
- BOOST_ASIO_ACCEPT_HANDLER_CHECK(AcceptHandler, handler) type_check;
- detail::non_const_lvalue<AcceptHandler> handler2(handler);
- self_->impl_.get_service().async_accept(
- self_->impl_.get_implementation(), *peer, peer_endpoint,
- handler2.value, self_->impl_.get_executor());
- }
- private:
- basic_socket_acceptor* self_;
- };
- class initiate_async_move_accept
- {
- public:
- typedef Executor executor_type;
- explicit initiate_async_move_accept(basic_socket_acceptor* self)
- : self_(self)
- {
- }
- const executor_type& get_executor() const noexcept
- {
- return self_->get_executor();
- }
- template <typename MoveAcceptHandler, typename Executor1, typename Socket>
- void operator()(MoveAcceptHandler&& handler,
- const Executor1& peer_ex, endpoint_type* peer_endpoint, Socket*) const
- {
- // If you get an error on the following line it means that your handler
- // does not meet the documented type requirements for a MoveAcceptHandler.
- BOOST_ASIO_MOVE_ACCEPT_HANDLER_CHECK(
- MoveAcceptHandler, handler, Socket) type_check;
- detail::non_const_lvalue<MoveAcceptHandler> handler2(handler);
- self_->impl_.get_service().async_move_accept(
- self_->impl_.get_implementation(), peer_ex, peer_endpoint,
- handler2.value, self_->impl_.get_executor());
- }
- private:
- basic_socket_acceptor* self_;
- };
- #if defined(BOOST_ASIO_WINDOWS_RUNTIME)
- detail::io_object_impl<
- detail::null_socket_service<Protocol>, Executor> impl_;
- #elif defined(BOOST_ASIO_HAS_IOCP)
- detail::io_object_impl<
- detail::win_iocp_socket_service<Protocol>, Executor> impl_;
- #elif defined(BOOST_ASIO_HAS_IO_URING_AS_DEFAULT)
- detail::io_object_impl<
- detail::io_uring_socket_service<Protocol>, Executor> impl_;
- #else
- detail::io_object_impl<
- detail::reactive_socket_service<Protocol>, Executor> impl_;
- #endif
- };
- } // namespace asio
- } // namespace boost
- #include <boost/asio/detail/pop_options.hpp>
- #endif // BOOST_ASIO_BASIC_SOCKET_ACCEPTOR_HPP
|