| PcapPlusPlus
    20.08
    | 
#include <IpAddress.h>
| Public Member Functions | |
| IPv6Address () | |
| IPv6Address (const uint8_t bytes[16]) | |
| IPv6Address (const std::string &addrAsString) | |
| const uint8_t * | toBytes () const | 
| std::string | toString () const | 
| bool | isValid () const | 
| bool | operator== (const IPv6Address &rhs) const | 
| bool | operator< (const IPv6Address &rhs) const | 
| bool | operator!= (const IPv6Address &rhs) const | 
| void | copyTo (uint8_t **arr, size_t &length) const | 
| void | copyTo (uint8_t *arr) const | 
| bool | matchSubnet (const IPv6Address &subnet, uint8_t prefixLength) const | 
| Static Public Attributes | |
| static const IPv6Address | Zero | 
Represents an IPv6 address (of type xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx).
| 
 | inline | 
A default constructor that creates an instance of the class with unspecified/zero address
| 
 | inline | 
A constructor that creates an instance of the class out of 16-byte array.
| [in] | bytes | The address as 16-byte array in network byte order | 
| pcpp::IPv6Address::IPv6Address | ( | const std::string & | addrAsString | ) | 
A constructor that creates an instance of the class out of std::string value If the string doesn't represent a valid IPv6 address, an instance will store an unspecified address
| [in] | addrAsString | The std::string representation of the address | 
| void pcpp::IPv6Address::copyTo | ( | uint8_t ** | arr, | 
| size_t & | length | ||
| ) | const | 
Allocates a byte array and copies address value into it. Array deallocation is user responsibility
| [in] | arr | A pointer to where array will be allocated | 
| [out] | length | Returns the length in bytes of the array that was allocated | 
| 
 | inline | 
Gets a pointer to an already allocated byte array and copies the address value to it. This method assumes array allocated size is at least 16 (the size of an IPv6 address)
| [in] | arr | A pointer to the array which address will be copied to | 
| 
 | inline | 
Determine whether the address is unspecified
| bool pcpp::IPv6Address::matchSubnet | ( | const IPv6Address & | subnet, | 
| uint8_t | prefixLength | ||
| ) | const | 
Checks whether the address matches a subnet. For example: if subnet is 2001:3CA1:010F:001A::, prefixLength is 64, and address is 2001:3CA1:010F:001A:121B:0000:0000:0010, then the method will return true Another example: if subnet is 2001:3CA1:010F:001A::, prefixLength is 70 and address is 2001:3CA1:010F:001A:121B:0000:0000:0010 then the method will return false
| [in] | subnet | The subnet to be verified | 
| [in] | prefixLength | How many bits to use in the mask | 
| 
 | inline | 
Overload of the not-equal-to operator
| 
 | inline | 
Overload of the less-than operator
| 
 | inline | 
Overload of the equal-to operator
| 
 | inline | 
Returns a pointer to 16-byte array representing the IPv6 address
| std::string pcpp::IPv6Address::toString | ( | ) | const | 
Returns a std::string representation of the address
| 
 | static | 
A static value representing a zero value of IPv6 address, meaning address of value "0:0:0:0:0:0:0:0:0:0:0:0:0:0:0:0" Notice this value can be omitted in the user code because the default constructor creates an instance with an unspecified/zero address. In order to check whether the address is zero the method isValid can be used