forked from aristanetworks/EosSdk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathip_types.cpp
82 lines (55 loc) · 1.92 KB
/
ip_types.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// Copyright (c) 2014 Arista Networks, Inc. All rights reserved.
// Arista Networks, Inc. Confidential and Proprietary.
#include "eos/ip.h"
#include <string.h>
namespace eos {
// Take an address family and an array of 4 (v4) or 16 (v6) uint8_t's.
// Representation compatible to Linux's sockaddr_in6.sin6_addr (i.e., __be8[16]).
// NOTE: 'address' is in network byte order for both IPv4 and IPv6 as per Linux and
// Arnet.
ip_addr_t::ip_addr_t(af_t af, uint8_t const * addr) {
af_ = af;
memcpy(&addr_, addr, af_ == AF_IPV4 ? 4 : 16);
}
// Construct from a Linux in_addr (IPv4).
ip_addr_t::ip_addr_t(in_addr const & addr) {
af_ = AF_IPV4;
memcpy(&addr_, &addr, sizeof(addr));
}
// Construct from a Linux in6_addr (IPv6).
ip_addr_t::ip_addr_t(in6_addr const & addr) {
// Linux in.h in_addr is in network byte order, no conversion required
af_ = AF_IPV6;
memcpy(&addr_, &addr, sizeof(addr));
}
bool
ip_addr_t::operator==(ip_addr_t const & other) const {
if (af_ != other.af_) {
return false;
}
return memcmp(addr_.bytes, other.addr_.bytes, af_ == AF_IPV4 ? 4 : 16) == 0;
}
bool
ip_addr_t::operator<(ip_addr_t const & other) const {
if(af_ < other.af_) return true;
if(af_ != other.af_) return false;
return memcmp(addr_.bytes, other.addr_.bytes, af_ == AF_IPV4 ? 4 : 16) < 0;
}
bool
parse_ip_addr(char const * addr, ip_addr_t * result) {
return true; // TODO: No op impl.
}
bool
parse_ip_prefix(char const * addr, ip_prefix_t * result) {
return true; // TODO: No op impl.
}
static inline std::string address_overlap_error_msg(ip_addr_mask_t const & addr) {
std::stringstream str;
str << "Address " << addr.to_string() << " overlaps with an already configured"
" address";
return str.str();
}
address_overlap_error::address_overlap_error(ip_addr_mask_t const & addr) noexcept :
configuration_error(address_overlap_error_msg(addr)), addr_(addr) {
}
}