/usr/include/ns3.27/ns3/ripng-header.h is in libns3-dev 3.27+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 | /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* Copyright (c) 2014 Universita' di Firenze, Italy
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Author: Tommaso Pecorella <tommaso.pecorella@unifi.it>
*/
#ifndef RIPNG_HEADER_H
#define RIPNG_HEADER_H
#include <list>
#include "ns3/header.h"
#include "ns3/ipv6-address.h"
#include "ns3/packet.h"
#include "ns3/ipv6-header.h"
namespace ns3 {
/**
* \ingroup ripng
*
* \brief RipNg Routing Table Entry (RTE) - see \RFC{2080}
*/
class RipNgRte : public Header
{
public:
RipNgRte (void);
/**
* \brief Get the type ID.
* \return the object TypeId
*/
static TypeId GetTypeId (void);
/**
* \brief Return the instance type identifier.
* \return instance type ID
*/
virtual TypeId GetInstanceTypeId (void) const;
virtual void Print (std::ostream& os) const;
/**
* \brief Get the serialized size of the packet.
* \return size
*/
virtual uint32_t GetSerializedSize (void) const;
/**
* \brief Serialize the packet.
* \param start Buffer iterator
*/
virtual void Serialize (Buffer::Iterator start) const;
/**
* \brief Deserialize the packet.
* \param start Buffer iterator
* \return size of the packet
*/
virtual uint32_t Deserialize (Buffer::Iterator start);
/**
* \brief Set the prefix
* \param prefix the prefix
*/
void SetPrefix (Ipv6Address prefix);
/**
* \brief Get the prefix
* \returns the prefix
*/
Ipv6Address GetPrefix (void) const;
/**
* \brief Set the prefix length
* \param prefixLen the prefix length
*/
void SetPrefixLen (uint8_t prefixLen);
/**
* \brief Get the prefix length
* \returns the prefix length
*/
uint8_t GetPrefixLen (void) const;
/**
* \brief Set the route tag
* \param routeTag the route tag
*/
void SetRouteTag (uint16_t routeTag);
/**
* \brief Get the route tag
* \returns the route tag
*/
uint16_t GetRouteTag (void) const;
/**
* \brief Set the route metric
* \param routeMetric the route metric
*/
void SetRouteMetric (uint8_t routeMetric);
/**
* \brief Get the route metric
* \returns the route metric
*/
uint8_t GetRouteMetric (void) const;
private:
Ipv6Address m_prefix; //!< prefix
uint16_t m_tag; //!< route tag
uint8_t m_prefixLen; //!< prefix length
uint8_t m_metric; //!< route metric
};
/**
* \brief Stream insertion operator.
*
* \param os the reference to the output stream
* \param h the Routing Table Entry
* \returns the reference to the output stream
*/
std::ostream & operator << (std::ostream & os, const RipNgRte & h);
/**
* \ingroup ripng
*
* \brief RipNgHeader - see \RFC{2080}
*/
class RipNgHeader : public Header
{
public:
RipNgHeader (void);
/**
* \brief Get the type ID.
* \return the object TypeId
*/
static TypeId GetTypeId (void);
/**
* \brief Return the instance type identifier.
* \return instance type ID
*/
virtual TypeId GetInstanceTypeId (void) const;
virtual void Print (std::ostream& os) const;
/**
* \brief Get the serialized size of the packet.
* \return size
*/
virtual uint32_t GetSerializedSize (void) const;
/**
* \brief Serialize the packet.
* \param start Buffer iterator
*/
virtual void Serialize (Buffer::Iterator start) const;
/**
* \brief Deserialize the packet.
* \param start Buffer iterator
* \return size of the packet
*/
virtual uint32_t Deserialize (Buffer::Iterator start);
/**
* Commands to be used in RipNg headers
*/
enum Command_e
{
REQUEST = 0x1,
RESPONSE = 0x2,
};
/**
* \brief Set the command
* \param command the command
*/
void SetCommand (Command_e command);
/**
* \brief Get the command
* \returns the command
*/
Command_e GetCommand (void) const;
/**
* \brief Add a RTE to the message
* \param rte the RTE
*/
void AddRte (RipNgRte rte);
/**
* \brief Clear all the RTEs from the header
*/
void ClearRtes ();
/**
* \brief Get the number of RTE included in the message
* \returns the number of RTE in the message
*/
uint16_t GetRteNumber (void) const;
/**
* \brief Get the list of the RTEs included in the message
* \returns the list of the RTEs in the message
*/
std::list<RipNgRte> GetRteList (void) const;
private:
uint8_t m_command; //!< command type
std::list<RipNgRte> m_rteList; //!< list of the RTEs in the message
};
/**
* \brief Stream insertion operator.
*
* \param os the reference to the output stream
* \param h the RIPng header
* \returns the reference to the output stream
*/
std::ostream & operator << (std::ostream & os, const RipNgHeader & h);
}
#endif /* RIPNG_HEADER_H */
|