A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
ie-dot11s-peering-protocol.cc
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2008,2009 IITP RAS
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  * Authors: Kirill Andreev <andreev@iitp.ru>
19  */
20 
21 #include "ie-dot11s-peering-protocol.h"
22 namespace ns3 {
23 namespace dot11s {
24 uint8_t
26 {
27  return 1;
28 }
29 IePeeringProtocol::IePeeringProtocol () :
30  m_protocol (0)
31 {
32 }
35 {
36  return IE11S_MESH_PEERING_PROTOCOL_VERSION;
37 }
38 void
40 {
41  i.WriteU8 (m_protocol);
42 }
43 uint8_t
45 {
46  Buffer::Iterator start = i;
47  m_protocol = i.ReadU8 ();
48  return i.GetDistanceFrom (start);
49 }
50 void
51 IePeeringProtocol::Print (std::ostream& os) const
52 {
53  os << std::endl << "<information_element id=" << ElementId () << ">" << std::endl;
54  os << "peering protocol = " << m_protocol;
55  os << "</information_element>" << std::endl;
56 }
57 std::ostream &
58 operator << (std::ostream &os, const IePeeringProtocol &a)
59 {
60  a.Print (os);
61  return os;
62 }
63 } // namespace dot11s
64 } // namespace ns3
65 
uint32_t GetDistanceFrom(Iterator const &o) const
Definition: buffer.cc:807
iterator in a Buffer instance
Definition: buffer.h:98
virtual uint8_t DeserializeInformationField(Buffer::Iterator i, uint8_t length)
std::ostream & operator<<(std::ostream &os, const Angles &a)
Definition: angles.cc:43
virtual void SerializeInformationField(Buffer::Iterator i) const
virtual WifiInformationElementId ElementId() const
Own unique Element ID.
virtual void Print(std::ostream &os) const
In addition, a subclass may optionally override the following...
void WriteU8(uint8_t data)
Definition: buffer.h:690
uint8_t ReadU8(void)
Definition: buffer.h:819
uint8_t WifiInformationElementId
virtual uint8_t GetInformationFieldSize() const