src/node/address.cc
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--
merge with HEAD
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3729
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     2
/*
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     3
 * Copyright (c) 2007 INRIA
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     4
 *
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     7
 * published by the Free Software Foundation;
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     8
 *
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    12
 * GNU General Public License for more details.
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    13
 *
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    14
 * You should have received a copy of the GNU General Public License
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    15
 * along with this program; if not, write to the Free Software
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    17
 *
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    19
 */
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    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
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    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
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
    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
af204a958bb0 bug 337
Craig Dowell <craigdo@ee.washington.edu>
parents: 3365
diff changeset
   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