| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 | //// ip/network_v6.hpp// ~~~~~~~~~~~~~~~~~//// Copyright (c) 2003-2024 Christopher M. Kohlhoff (chris at kohlhoff dot com)// Copyright (c) 2014 Oliver Kowalke (oliver dot kowalke at gmail 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_IP_NETWORK_V6_HPP#define BOOST_ASIO_IP_NETWORK_V6_HPP#if defined(_MSC_VER) && (_MSC_VER >= 1200)# pragma once#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)#include <boost/asio/detail/config.hpp>#include <string>#include <boost/asio/detail/string_view.hpp>#include <boost/system/error_code.hpp>#include <boost/asio/ip/address_v6_range.hpp>#include <boost/asio/detail/push_options.hpp>namespace boost {namespace asio {namespace ip {/// Represents an IPv6 network./** * The boost::asio::ip::network_v6 class provides the ability to use and * manipulate IP version 6 networks. * * @par Thread Safety * @e Distinct @e objects: Safe.@n * @e Shared @e objects: Unsafe. */class network_v6{public:  /// Default constructor.  network_v6() noexcept    : address_(),      prefix_length_(0)  {  }  /// Construct a network based on the specified address and prefix length.  BOOST_ASIO_DECL network_v6(const address_v6& addr,      unsigned short prefix_len);  /// Copy constructor.  network_v6(const network_v6& other) noexcept    : address_(other.address_),      prefix_length_(other.prefix_length_)  {  }  /// Move constructor.  network_v6(network_v6&& other) noexcept    : address_(static_cast<address_v6&&>(other.address_)),      prefix_length_(other.prefix_length_)  {  }  /// Assign from another network.  network_v6& operator=(const network_v6& other) noexcept  {    address_ = other.address_;    prefix_length_ = other.prefix_length_;    return *this;  }  /// Move-assign from another network.  network_v6& operator=(network_v6&& other) noexcept  {    address_ = static_cast<address_v6&&>(other.address_);    prefix_length_ = other.prefix_length_;    return *this;  }  /// Obtain the address object specified when the network object was created.  address_v6 address() const noexcept  {    return address_;  }  /// Obtain the prefix length that was specified when the network object was  /// created.  unsigned short prefix_length() const noexcept  {    return prefix_length_;  }  /// Obtain an address object that represents the network address.  BOOST_ASIO_DECL address_v6 network() const noexcept;  /// Obtain an address range corresponding to the hosts in the network.  BOOST_ASIO_DECL address_v6_range hosts() const noexcept;  /// Obtain the true network address, omitting any host bits.  network_v6 canonical() const noexcept  {    return network_v6(network(), prefix_length());  }  /// Test if network is a valid host address.  bool is_host() const noexcept  {    return prefix_length_ == 128;  }  /// Test if a network is a real subnet of another network.  BOOST_ASIO_DECL bool is_subnet_of(const network_v6& other) const;  /// Get the network as an address in dotted decimal format.  BOOST_ASIO_DECL std::string to_string() const;  /// Get the network as an address in dotted decimal format.  BOOST_ASIO_DECL std::string to_string(boost::system::error_code& ec) const;  /// Compare two networks for equality.  friend bool operator==(const network_v6& a, const network_v6& b)  {    return a.address_ == b.address_ && a.prefix_length_ == b.prefix_length_;  }  /// Compare two networks for inequality.  friend bool operator!=(const network_v6& a, const network_v6& b)  {    return !(a == b);  }private:  address_v6 address_;  unsigned short prefix_length_;};/// Create an IPv6 network from an address and prefix length./** * @relates address_v6 */inline network_v6 make_network_v6(    const address_v6& addr, unsigned short prefix_len){  return network_v6(addr, prefix_len);}/// Create an IPv6 network from a string containing IP address and prefix/// length./** * @relates network_v6 */BOOST_ASIO_DECL network_v6 make_network_v6(const char* str);/// Create an IPv6 network from a string containing IP address and prefix/// length./** * @relates network_v6 */BOOST_ASIO_DECL network_v6 make_network_v6(    const char* str, boost::system::error_code& ec);/// Create an IPv6 network from a string containing IP address and prefix/// length./** * @relates network_v6 */BOOST_ASIO_DECL network_v6 make_network_v6(const std::string& str);/// Create an IPv6 network from a string containing IP address and prefix/// length./** * @relates network_v6 */BOOST_ASIO_DECL network_v6 make_network_v6(    const std::string& str, boost::system::error_code& ec);#if defined(BOOST_ASIO_HAS_STRING_VIEW) \  || defined(GENERATING_DOCUMENTATION)/// Create an IPv6 network from a string containing IP address and prefix/// length./** * @relates network_v6 */BOOST_ASIO_DECL network_v6 make_network_v6(string_view str);/// Create an IPv6 network from a string containing IP address and prefix/// length./** * @relates network_v6 */BOOST_ASIO_DECL network_v6 make_network_v6(    string_view str, boost::system::error_code& ec);#endif // defined(BOOST_ASIO_HAS_STRING_VIEW)       //  || defined(GENERATING_DOCUMENTATION)#if !defined(BOOST_ASIO_NO_IOSTREAM)/// Output a network as a string./** * Used to output a human-readable string for a specified network. * * @param os The output stream to which the string will be written. * * @param net The network to be written. * * @return The output stream. * * @relates boost::asio::ip::address_v6 */template <typename Elem, typename Traits>std::basic_ostream<Elem, Traits>& operator<<(    std::basic_ostream<Elem, Traits>& os, const network_v6& net);#endif // !defined(BOOST_ASIO_NO_IOSTREAM)} // namespace ip} // namespace asio} // namespace boost#include <boost/asio/detail/pop_options.hpp>#include <boost/asio/ip/impl/network_v6.hpp>#if defined(BOOST_ASIO_HEADER_ONLY)# include <boost/asio/ip/impl/network_v6.ipp>#endif // defined(BOOST_ASIO_HEADER_ONLY)#endif // BOOST_ASIO_IP_NETWORK_V6_HPP
 |