PageRenderTime 42ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 0ms

/Src/Dependencies/Boost/boost/asio/ip/multicast.hpp

http://hadesmem.googlecode.com/
C++ Header | 180 lines | 51 code | 13 blank | 116 comment | 1 complexity | b2518b70b38d4dc20588291eaeef1a93 MD5 | raw file
Possible License(s): GPL-3.0, LGPL-2.0, Apache-2.0, LGPL-3.0
  1. //
  2. // ip/multicast.hpp
  3. // ~~~~~~~~~~~~~~~~
  4. //
  5. // Copyright (c) 2003-2011 Christopher M. Kohlhoff (chris at kohlhoff dot com)
  6. //
  7. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  8. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  9. //
  10. #ifndef BOOST_ASIO_IP_MULTICAST_HPP
  11. #define BOOST_ASIO_IP_MULTICAST_HPP
  12. #if defined(_MSC_VER) && (_MSC_VER >= 1200)
  13. # pragma once
  14. #endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
  15. #include <boost/asio/detail/config.hpp>
  16. #include <cstddef>
  17. #include <boost/asio/ip/detail/socket_option.hpp>
  18. #include <boost/asio/detail/push_options.hpp>
  19. namespace boost {
  20. namespace asio {
  21. namespace ip {
  22. namespace multicast {
  23. /// Socket option to join a multicast group on a specified interface.
  24. /**
  25. * Implements the IPPROTO_IP/IP_ADD_MEMBERSHIP socket option.
  26. *
  27. * @par Examples
  28. * Setting the option to join a multicast group:
  29. * @code
  30. * boost::asio::ip::udp::socket socket(io_service);
  31. * ...
  32. * boost::asio::ip::address multicast_address =
  33. * boost::asio::ip::address::from_string("225.0.0.1");
  34. * boost::asio::ip::multicast::join_group option(multicast_address);
  35. * socket.set_option(option);
  36. * @endcode
  37. *
  38. * @par Concepts:
  39. * SettableSocketOption.
  40. */
  41. #if defined(GENERATING_DOCUMENTATION)
  42. typedef implementation_defined join_group;
  43. #else
  44. typedef boost::asio::ip::detail::socket_option::multicast_request<
  45. IPPROTO_IP, IP_ADD_MEMBERSHIP, IPPROTO_IPV6, IPV6_JOIN_GROUP> join_group;
  46. #endif
  47. /// Socket option to leave a multicast group on a specified interface.
  48. /**
  49. * Implements the IPPROTO_IP/IP_DROP_MEMBERSHIP socket option.
  50. *
  51. * @par Examples
  52. * Setting the option to leave a multicast group:
  53. * @code
  54. * boost::asio::ip::udp::socket socket(io_service);
  55. * ...
  56. * boost::asio::ip::address multicast_address =
  57. * boost::asio::ip::address::from_string("225.0.0.1");
  58. * boost::asio::ip::multicast::leave_group option(multicast_address);
  59. * socket.set_option(option);
  60. * @endcode
  61. *
  62. * @par Concepts:
  63. * SettableSocketOption.
  64. */
  65. #if defined(GENERATING_DOCUMENTATION)
  66. typedef implementation_defined leave_group;
  67. #else
  68. typedef boost::asio::ip::detail::socket_option::multicast_request<
  69. IPPROTO_IP, IP_DROP_MEMBERSHIP, IPPROTO_IPV6, IPV6_LEAVE_GROUP> leave_group;
  70. #endif
  71. /// Socket option for local interface to use for outgoing multicast packets.
  72. /**
  73. * Implements the IPPROTO_IP/IP_MULTICAST_IF socket option.
  74. *
  75. * @par Examples
  76. * Setting the option:
  77. * @code
  78. * boost::asio::ip::udp::socket socket(io_service);
  79. * ...
  80. * boost::asio::ip::address_v4 local_interface =
  81. * boost::asio::ip::address_v4::from_string("1.2.3.4");
  82. * boost::asio::ip::multicast::outbound_interface option(local_interface);
  83. * socket.set_option(option);
  84. * @endcode
  85. *
  86. * @par Concepts:
  87. * SettableSocketOption.
  88. */
  89. #if defined(GENERATING_DOCUMENTATION)
  90. typedef implementation_defined outbound_interface;
  91. #else
  92. typedef boost::asio::ip::detail::socket_option::network_interface<
  93. IPPROTO_IP, IP_MULTICAST_IF, IPPROTO_IPV6, IPV6_MULTICAST_IF>
  94. outbound_interface;
  95. #endif
  96. /// Socket option for time-to-live associated with outgoing multicast packets.
  97. /**
  98. * Implements the IPPROTO_IP/IP_MULTICAST_TTL socket option.
  99. *
  100. * @par Examples
  101. * Setting the option:
  102. * @code
  103. * boost::asio::ip::udp::socket socket(io_service);
  104. * ...
  105. * boost::asio::ip::multicast::hops option(4);
  106. * socket.set_option(option);
  107. * @endcode
  108. *
  109. * @par
  110. * Getting the current option value:
  111. * @code
  112. * boost::asio::ip::udp::socket socket(io_service);
  113. * ...
  114. * boost::asio::ip::multicast::hops option;
  115. * socket.get_option(option);
  116. * int ttl = option.value();
  117. * @endcode
  118. *
  119. * @par Concepts:
  120. * GettableSocketOption, SettableSocketOption.
  121. */
  122. #if defined(GENERATING_DOCUMENTATION)
  123. typedef implementation_defined hops;
  124. #else
  125. typedef boost::asio::ip::detail::socket_option::multicast_hops<
  126. IPPROTO_IP, IP_MULTICAST_TTL, IPPROTO_IPV6, IPV6_MULTICAST_HOPS> hops;
  127. #endif
  128. /// Socket option determining whether outgoing multicast packets will be
  129. /// received on the same socket if it is a member of the multicast group.
  130. /**
  131. * Implements the IPPROTO_IP/IP_MULTICAST_LOOP socket option.
  132. *
  133. * @par Examples
  134. * Setting the option:
  135. * @code
  136. * boost::asio::ip::udp::socket socket(io_service);
  137. * ...
  138. * boost::asio::ip::multicast::enable_loopback option(true);
  139. * socket.set_option(option);
  140. * @endcode
  141. *
  142. * @par
  143. * Getting the current option value:
  144. * @code
  145. * boost::asio::ip::udp::socket socket(io_service);
  146. * ...
  147. * boost::asio::ip::multicast::enable_loopback option;
  148. * socket.get_option(option);
  149. * bool is_set = option.value();
  150. * @endcode
  151. *
  152. * @par Concepts:
  153. * GettableSocketOption, SettableSocketOption.
  154. */
  155. #if defined(GENERATING_DOCUMENTATION)
  156. typedef implementation_defined enable_loopback;
  157. #else
  158. typedef boost::asio::ip::detail::socket_option::multicast_enable_loopback<
  159. IPPROTO_IP, IP_MULTICAST_LOOP, IPPROTO_IPV6, IPV6_MULTICAST_LOOP>
  160. enable_loopback;
  161. #endif
  162. } // namespace multicast
  163. } // namespace ip
  164. } // namespace asio
  165. } // namespace boost
  166. #include <boost/asio/detail/pop_options.hpp>
  167. #endif // BOOST_ASIO_IP_MULTICAST_HPP