author | Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
Mon, 01 Feb 2010 08:09:11 +0100 | |
changeset 5937 | aa754f49d2f3 |
parent 3729 | af204a958bb0 |
permissions | -rw-r--r-- |
3729 | 1 |
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ |
2 |
/* |
|
3 |
* Copyright (c) 2007 INRIA |
|
4 |
* |
|
5 |
* This program is free software; you can redistribute it and/or modify |
|
6 |
* it under the terms of the GNU General Public License version 2 as |
|
7 |
* published by the Free Software Foundation; |
|
8 |
* |
|
9 |
* This program is distributed in the hope that it will be useful, |
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
12 |
* GNU General Public License for more details. |
|
13 |
* |
|
14 |
* You should have received a copy of the GNU General Public License |
|
15 |
* along with this program; if not, write to the Free Software |
|
16 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
17 |
* |
|
18 |
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
|
19 |
*/ |
|
20 |
||
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
21 |
#include "ns3/assert.h" |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
22 |
#include "address.h" |
3365
6409d2460601
bug 245: build failure with gcc 4.3.x
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3215
diff
changeset
|
23 |
#include <string.h> |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
24 |
#include <iostream> |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
25 |
#include <iomanip> |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
26 |
|
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
27 |
namespace ns3 { |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
28 |
|
1159
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
29 |
Address::Address () |
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
30 |
: m_type (0), |
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
31 |
m_len (0) |
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
32 |
{ |
3729 | 33 |
// Buffer left uninitialized |
1159
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
34 |
} |
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
35 |
|
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
36 |
Address::Address (uint8_t type, const uint8_t *buffer, uint8_t len) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
37 |
: m_type (type), |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
38 |
m_len (len) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
39 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
40 |
NS_ASSERT (m_len <= MAX_SIZE); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
41 |
memcpy (m_data, buffer, m_len); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
42 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
43 |
Address::Address (const Address & address) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
44 |
: m_type (address.m_type), |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
45 |
m_len (address.m_len) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
46 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
47 |
NS_ASSERT (m_len <= MAX_SIZE); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
48 |
memcpy (m_data, address.m_data, m_len); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
49 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
50 |
Address & |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
51 |
Address::operator = (const Address &address) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
52 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
53 |
NS_ASSERT (m_len <= MAX_SIZE); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
54 |
m_type = address.m_type; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
55 |
m_len = address.m_len; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
56 |
NS_ASSERT (m_len <= MAX_SIZE); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
57 |
memcpy (m_data, address.m_data, m_len); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
58 |
return *this; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
59 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
60 |
|
1187
8ea0f4d4fd34
add Address::IsInvalid
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1184
diff
changeset
|
61 |
bool |
8ea0f4d4fd34
add Address::IsInvalid
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1184
diff
changeset
|
62 |
Address::IsInvalid (void) const |
8ea0f4d4fd34
add Address::IsInvalid
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1184
diff
changeset
|
63 |
{ |
8ea0f4d4fd34
add Address::IsInvalid
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1184
diff
changeset
|
64 |
return m_len == 0 && m_type == 0; |
8ea0f4d4fd34
add Address::IsInvalid
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1184
diff
changeset
|
65 |
} |
8ea0f4d4fd34
add Address::IsInvalid
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1184
diff
changeset
|
66 |
|
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
67 |
uint8_t |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
68 |
Address::GetLength (void) const |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
69 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
70 |
NS_ASSERT (m_len <= MAX_SIZE); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
71 |
return m_len; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
72 |
} |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
73 |
uint32_t |
1166
878f546b21e1
add doxygen
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1159
diff
changeset
|
74 |
Address::CopyTo (uint8_t buffer[MAX_SIZE]) const |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
75 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
76 |
NS_ASSERT (m_len <= MAX_SIZE); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
77 |
memcpy (buffer, m_data, m_len); |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
78 |
return m_len; |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
79 |
} |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
80 |
uint32_t |
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
81 |
Address::CopyAllTo (uint8_t *buffer, uint8_t len) const |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
82 |
{ |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
83 |
NS_ASSERT (len >= m_len + 2); |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
84 |
buffer[0] = m_type; |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
85 |
buffer[1] = m_len; |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
86 |
memcpy (buffer + 2, m_data, m_len); |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
87 |
return m_len + 2; |
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
88 |
} |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
89 |
|
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
90 |
uint32_t |
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
91 |
Address::CopyFrom (const uint8_t *buffer, uint8_t len) |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
92 |
{ |
1169
b0aca73e1ea7
fix address deserialization
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1166
diff
changeset
|
93 |
NS_ASSERT (len <= MAX_SIZE); |
1159
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
94 |
memcpy (m_data, buffer, len); |
1169
b0aca73e1ea7
fix address deserialization
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1166
diff
changeset
|
95 |
m_len = len; |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
96 |
return m_len; |
1159
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
97 |
} |
3729 | 98 |
uint32_t |
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
99 |
Address::CopyAllFrom (const uint8_t *buffer, uint8_t len) |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
100 |
{ |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
101 |
NS_ASSERT (len >= 2); |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
102 |
m_type = buffer[0]; |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
103 |
m_len = buffer[1]; |
3729 | 104 |
|
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
105 |
NS_ASSERT (len >= m_len + 2); |
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
106 |
memcpy (m_data, buffer + 2, m_len); |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
107 |
return m_len + 2; |
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
108 |
} |
1159
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
109 |
bool |
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
110 |
Address::CheckCompatible (uint8_t type, uint8_t len) const |
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
111 |
{ |
1184
1da473c2225c
extra Address API to be used by packet socket address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1169
diff
changeset
|
112 |
NS_ASSERT (len <= MAX_SIZE); |
1159
eef87ec51ad7
improve type checking
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1158
diff
changeset
|
113 |
return m_len == len && (m_type == type || m_type == 0); |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
114 |
} |
1191
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
115 |
bool |
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
116 |
Address::IsMatchingType (uint8_t type) const |
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
117 |
{ |
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
118 |
return m_type == type; |
5583facf0af8
PacketSocketAddress serialization code was buggy.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1187
diff
changeset
|
119 |
} |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
120 |
|
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
121 |
uint8_t |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
122 |
Address::Register (void) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
123 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
124 |
static uint8_t type = 1; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
125 |
type++; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
126 |
return type; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
127 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
128 |
|
3139
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
129 |
uint32_t |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
130 |
Address::GetSerializedSize (void) const |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
131 |
{ |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
132 |
return 1 + 1 + m_len; |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
133 |
} |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
134 |
|
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
135 |
void |
3167
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
136 |
Address::Serialize (TagBuffer buffer) const |
3139
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
137 |
{ |
3167
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
138 |
buffer.WriteU8 (m_type); |
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
139 |
buffer.WriteU8 (m_len); |
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
140 |
buffer.Write (m_data, m_len); |
3139
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
141 |
} |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
142 |
|
3167
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
143 |
void |
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
144 |
Address::Deserialize (TagBuffer buffer) |
3139
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
145 |
{ |
3167
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
146 |
m_type = buffer.ReadU8 (); |
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
147 |
m_len = buffer.ReadU8 (); |
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
148 |
NS_ASSERT (m_len <= MAX_SIZE); |
644a220ad981
Fix off-by-2 errors
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3139
diff
changeset
|
149 |
buffer.Read (m_data, m_len); |
3139
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
150 |
} |
37deb9deaf0e
Add tag serialize methods; add serialize routines to Address
Tom Henderson <tomh@tomh.org>
parents:
2973
diff
changeset
|
151 |
|
2582
3e28107b870f
rename old VALUE leftovers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2434
diff
changeset
|
152 |
ATTRIBUTE_HELPER_CPP (Address); |
2413
85fae7abb9d9
add Value support to Address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1262
diff
changeset
|
153 |
|
2922
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
154 |
|
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
155 |
bool operator == (const Address &a, const Address &b) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
156 |
{ |
2922
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
157 |
/* Two addresses can be equal even if their types are |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
158 |
* different if one of the two types is zero. a type of |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
159 |
* zero identifies an Address which might contain meaningful |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
160 |
* payload but for which the type field could not be set because |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
161 |
* we did not know it. This can typically happen in the ARP |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
162 |
* layer where we receive an address from an ArpHeader but |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
163 |
* we do not know its type: we really want to be able to |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
164 |
* compare addresses without knowing their real type. |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
165 |
*/ |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
166 |
if (a.m_type != b.m_type && |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
167 |
a.m_type != 0 && |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
168 |
b.m_type != 0) |
2918
6244ea5e7831
Address instances of different m_type's should compare differently; closes #173.
Gustavo J. A. M. Carneiro <gjc@inescporto.pt>
parents:
2582
diff
changeset
|
169 |
{ |
6244ea5e7831
Address instances of different m_type's should compare differently; closes #173.
Gustavo J. A. M. Carneiro <gjc@inescporto.pt>
parents:
2582
diff
changeset
|
170 |
return false; |
6244ea5e7831
Address instances of different m_type's should compare differently; closes #173.
Gustavo J. A. M. Carneiro <gjc@inescporto.pt>
parents:
2582
diff
changeset
|
171 |
} |
2922
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
172 |
if (a.m_len != b.m_len) |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
173 |
{ |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
174 |
return false; |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
175 |
} |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
176 |
return memcmp (a.m_data, b.m_data, a.m_len) == 0; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
177 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
178 |
bool operator != (const Address &a, const Address &b) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
179 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
180 |
return !(a == b); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
181 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
182 |
bool operator < (const Address &a, const Address &b) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
183 |
{ |
3215
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
184 |
if (a.m_type < b.m_type) |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
185 |
{ |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
186 |
return true; |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
187 |
} |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
188 |
else if (a.m_type > b.m_type) |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
189 |
{ |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
190 |
return false; |
c5a74196e87a
bug 206: allow comparing addresses of different types.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
3167
diff
changeset
|
191 |
} |
2922
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
192 |
if (a.m_len < b.m_len) |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
193 |
{ |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
194 |
return true; |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
195 |
} |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
196 |
else if (a.m_len > b.m_len) |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
197 |
{ |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
198 |
return false; |
916de65f67bf
fix regression introduced by changeset 6244ea5e7831 to fix bug #173
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2918
diff
changeset
|
199 |
} |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
200 |
NS_ASSERT (a.GetLength() == b.GetLength()); |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
201 |
for (uint8_t i = 0; i < a.GetLength(); i++) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
202 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
203 |
if (a.m_data[i] < b.m_data[i]) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
204 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
205 |
return true; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
206 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
207 |
else if (a.m_data[i] > b.m_data[i]) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
208 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
209 |
return false; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
210 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
211 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
212 |
return false; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
213 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
214 |
|
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
215 |
std::ostream& operator<< (std::ostream& os, const Address & address) |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
216 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
217 |
os.setf (std::ios::hex, std::ios::basefield); |
1262
8e3d39fa3565
fix trace output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1191
diff
changeset
|
218 |
os.fill('0'); |
2955
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
219 |
os << std::setw(2) << (uint32_t) address.m_type << "-" << std::setw(2) << (uint32_t) address.m_len << "-"; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
220 |
for (uint8_t i = 0; i < (address.m_len-1); ++i) |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
221 |
{ |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
222 |
os << std::setw(2) << (uint32_t)address.m_data[i] << ":"; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
223 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
224 |
// Final byte not suffixed by ":" |
2955
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
225 |
os << std::setw(2) << (uint32_t) address.m_data[address.m_len-1]; |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
226 |
os.setf (std::ios::dec, std::ios::basefield); |
1262
8e3d39fa3565
fix trace output
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1191
diff
changeset
|
227 |
os.fill(' '); |
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
228 |
return os; |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
229 |
} |
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
230 |
|
2955
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
231 |
static uint8_t |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
232 |
AsInt (std::string v) |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
233 |
{ |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
234 |
std::istringstream iss; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
235 |
iss.str (v); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
236 |
uint32_t retval; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
237 |
iss >> std::hex >> retval >> std::dec; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
238 |
return retval; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
239 |
} |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
240 |
|
2413
85fae7abb9d9
add Value support to Address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1262
diff
changeset
|
241 |
std::istream& operator>> (std::istream& is, Address & address) |
85fae7abb9d9
add Value support to Address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1262
diff
changeset
|
242 |
{ |
2955
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
243 |
std::string v; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
244 |
is >> v; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
245 |
std::string::size_type firstDash, secondDash; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
246 |
firstDash = v.find ("-"); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
247 |
secondDash = v.find ("-", firstDash+1); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
248 |
std::string type = v.substr (0, firstDash-0); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
249 |
std::string len = v.substr (firstDash+1, secondDash-(firstDash+1)); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
250 |
|
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
251 |
address.m_type = AsInt (type); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
252 |
address.m_len = AsInt (len); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
253 |
NS_ASSERT (address.m_len <= Address::MAX_SIZE); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
254 |
|
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
255 |
std::string::size_type col = secondDash + 1; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
256 |
for (uint8_t i = 0; i < address.m_len; ++i) |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
257 |
{ |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
258 |
std::string tmp; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
259 |
std::string::size_type next; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
260 |
next = v.find (":", col); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
261 |
if (next == std::string::npos) |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
262 |
{ |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
263 |
tmp = v.substr (col, v.size ()-col); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
264 |
address.m_data[i] = AsInt (tmp); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
265 |
break; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
266 |
} |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
267 |
else |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
268 |
{ |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
269 |
tmp = v.substr (col, next-col); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
270 |
address.m_data[i] = AsInt (tmp); |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
271 |
col = next + 1; |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
272 |
} |
3d45621712a3
implement operator >>
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2582
diff
changeset
|
273 |
} |
2413
85fae7abb9d9
add Value support to Address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1262
diff
changeset
|
274 |
return is; |
85fae7abb9d9
add Value support to Address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1262
diff
changeset
|
275 |
} |
85fae7abb9d9
add Value support to Address
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1262
diff
changeset
|
276 |
|
1158
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
277 |
|
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
278 |
|
12d68dff3353
new address types
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
279 |
} // namespace ns3 |