100.00% Lines (2/2) 100.00% Functions (2/2)
TLA Baseline Branch
Line Hits Code Line Hits Code
1   // 1   //
2   // Copyright (c) 2026 Steve Gerbino 2   // Copyright (c) 2026 Steve Gerbino
3   // 3   //
4   // Distributed under the Boost Software License, Version 1.0. (See accompanying 4   // Distributed under the Boost Software License, Version 1.0. (See accompanying
5   // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) 5   // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6   // 6   //
7   // Official repository: https://github.com/cppalliance/corosio 7   // Official repository: https://github.com/cppalliance/corosio
8   // 8   //
9   9  
10   #ifndef BOOST_COROSIO_DETAIL_UDP_SERVICE_HPP 10   #ifndef BOOST_COROSIO_DETAIL_UDP_SERVICE_HPP
11   #define BOOST_COROSIO_DETAIL_UDP_SERVICE_HPP 11   #define BOOST_COROSIO_DETAIL_UDP_SERVICE_HPP
12   12  
13   #include <boost/corosio/detail/config.hpp> 13   #include <boost/corosio/detail/config.hpp>
14   #include <boost/corosio/udp_socket.hpp> 14   #include <boost/corosio/udp_socket.hpp>
15   #include <boost/corosio/endpoint.hpp> 15   #include <boost/corosio/endpoint.hpp>
16   #include <boost/capy/ex/execution_context.hpp> 16   #include <boost/capy/ex/execution_context.hpp>
17   #include <system_error> 17   #include <system_error>
18   18  
19   namespace boost::corosio::detail { 19   namespace boost::corosio::detail {
20   20  
21   /** Abstract UDP service base class. 21   /** Abstract UDP service base class.
22   22  
23   Concrete implementations (epoll_udp_service, 23   Concrete implementations (epoll_udp_service,
24   select_udp_service, etc.) inherit from this class and 24   select_udp_service, etc.) inherit from this class and
25   provide platform-specific datagram socket operations. The 25   provide platform-specific datagram socket operations. The
26   context constructor installs whichever backend via 26   context constructor installs whichever backend via
27   `make_service`, and `udp_socket.cpp` retrieves it via 27   `make_service`, and `udp_socket.cpp` retrieves it via
28   `use_service<udp_service>()`. 28   `use_service<udp_service>()`.
29   */ 29   */
30   class BOOST_COROSIO_DECL udp_service 30   class BOOST_COROSIO_DECL udp_service
31   : public capy::execution_context::service 31   : public capy::execution_context::service
32   , public io_object::io_service 32   , public io_object::io_service
33   { 33   {
34   public: 34   public:
35   /// Identifies this service for `execution_context` lookup. 35   /// Identifies this service for `execution_context` lookup.
36   using key_type = udp_service; 36   using key_type = udp_service;
37   37  
38   /** Open a datagram socket. 38   /** Open a datagram socket.
39   39  
40   Creates a socket and associates it with the platform reactor. 40   Creates a socket and associates it with the platform reactor.
41   41  
42   @param impl The socket implementation to open. 42   @param impl The socket implementation to open.
43   @param family Address family (e.g. `AF_INET`, `AF_INET6`). 43   @param family Address family (e.g. `AF_INET`, `AF_INET6`).
44   @param type Socket type (`SOCK_DGRAM`). 44   @param type Socket type (`SOCK_DGRAM`).
45   @param protocol Protocol number (`IPPROTO_UDP`). 45   @param protocol Protocol number (`IPPROTO_UDP`).
46   @return Error code on failure, empty on success. 46   @return Error code on failure, empty on success.
47   */ 47   */
48   virtual std::error_code open_datagram_socket( 48   virtual std::error_code open_datagram_socket(
49   udp_socket::implementation& impl, 49   udp_socket::implementation& impl,
50   int family, 50   int family,
51   int type, 51   int type,
52   int protocol) = 0; 52   int protocol) = 0;
53   53  
54   /** Bind a datagram socket to a local endpoint. 54   /** Bind a datagram socket to a local endpoint.
55   55  
56   @param impl The socket implementation to bind. 56   @param impl The socket implementation to bind.
57   @param ep The local endpoint to bind to. 57   @param ep The local endpoint to bind to.
58   @return Error code on failure, empty on success. 58   @return Error code on failure, empty on success.
59   */ 59   */
60   virtual std::error_code 60   virtual std::error_code
61   bind_datagram(udp_socket::implementation& impl, endpoint ep) = 0; 61   bind_datagram(udp_socket::implementation& impl, endpoint ep) = 0;
62   62  
63   protected: 63   protected:
64   /// Construct the UDP service. 64   /// Construct the UDP service.
HITCBC 65   605 udp_service() = default; 65   605 udp_service() = default;
66   66  
67   /// Destroy the UDP service. 67   /// Destroy the UDP service.
HITCBC 68   605 ~udp_service() override = default; 68   605 ~udp_service() override = default;
69   }; 69   };
70   70  
71   } // namespace boost::corosio::detail 71   } // namespace boost::corosio::detail
72   72  
73   #endif // BOOST_COROSIO_DETAIL_UDP_SERVICE_HPP 73   #endif // BOOST_COROSIO_DETAIL_UDP_SERVICE_HPP