A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ns3::SeqTsHeader Class Reference

Doxygen introspection did not find any typical Config paths. More...

#include <seq-ts-header.h>

+ Inheritance diagram for ns3::SeqTsHeader:
+ Collaboration diagram for ns3::SeqTsHeader:

Public Member Functions

 SeqTsHeader ()
 
virtual uint32_t Deserialize (Buffer::Iterator start)
 
virtual TypeId GetInstanceTypeId (void) const
 
uint32_t GetSeq (void) const
 
virtual uint32_t GetSerializedSize (void) const
 
Time GetTs (void) const
 
virtual void Print (std::ostream &os) const
 
virtual void Serialize (Buffer::Iterator start) const
 
void SetSeq (uint32_t seq)
 
- Public Member Functions inherited from ns3::Header
virtual ~Header ()
 
- Public Member Functions inherited from ns3::ObjectBase
virtual ~ObjectBase ()
 Virtual destructor. More...
 
void GetAttribute (std::string name, AttributeValue &value) const
 
bool GetAttributeFailSafe (std::string name, AttributeValue &attribute) const
 
void SetAttribute (std::string name, const AttributeValue &value)
 
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
 
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
 
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
 
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
 
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)
 

Static Public Member Functions

static TypeId GetTypeId (void)
 Get the type ID. More...
 
- Static Public Member Functions inherited from ns3::Header
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::Chunk
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId (void)
 Get the type ID. More...
 

Private Attributes

uint32_t m_seq
 Sequence number. More...
 
uint64_t m_ts
 Timestamp. More...
 

Additional Inherited Members

- Protected Member Functions inherited from ns3::ObjectBase
void ConstructSelf (const AttributeConstructionList &attributes)
 
virtual void NotifyConstructionCompleted (void)
 This method is invoked once all member attributes have been initialized. More...
 

Detailed Description

Doxygen introspection did not find any typical Config paths.

Packet header for UDP client/server application.


No Attributes are defined for this type.
No TraceSources are defined for this type.

The header is made of a 32bits sequence number followed by a 64bits time stamp.

Definition at line 36 of file seq-ts-header.h.

Constructor & Destructor Documentation

ns3::SeqTsHeader::SeqTsHeader ( )

Definition at line 34 of file seq-ts-header.cc.

References NS_LOG_FUNCTION.

Member Function Documentation

uint32_t ns3::SeqTsHeader::Deserialize ( Buffer::Iterator  start)
virtual
Parameters
startan iterator which points to where the header should written.
Returns
the number of bytes read.

This method is used by Packet::RemoveHeader to re-create a header from the byte buffer of a packet. The data read is expected to match bit-for-bit the representation of this header in real networks.

Implements ns3::Header.

Definition at line 97 of file seq-ts-header.cc.

References GetSerializedSize(), m_seq, m_ts, NS_LOG_FUNCTION, ns3::Buffer::Iterator::ReadNtohU32(), ns3::Buffer::Iterator::ReadNtohU64(), and visualizer.core::start().

+ Here is the call graph for this function:

TypeId ns3::SeqTsHeader::GetInstanceTypeId ( void  ) const
virtual
Returns
the TypeId associated to the most-derived type of this instance.

This method is typically implemented by ns3::Object::GetInstanceTypeId but some classes which derive from ns3::ObjectBase directly have to implement it themselves.

Implements ns3::ObjectBase.

Definition at line 71 of file seq-ts-header.cc.

References GetTypeId().

+ Here is the call graph for this function:

uint32_t ns3::SeqTsHeader::GetSeq ( void  ) const
Returns
the sequence number

Definition at line 48 of file seq-ts-header.cc.

References m_seq, and NS_LOG_FUNCTION.

Referenced by ns3::UdpServer::HandleRead().

+ Here is the caller graph for this function:

uint32_t ns3::SeqTsHeader::GetSerializedSize ( void  ) const
virtual
Returns
the expected size of the header.

This method is used by Packet::AddHeader to store a header into the byte buffer of a packet. This method should return the number of bytes which are needed to store the full header data by Serialize.

Implements ns3::Header.

Definition at line 82 of file seq-ts-header.cc.

References NS_LOG_FUNCTION.

Referenced by Deserialize().

+ Here is the caller graph for this function:

Time ns3::SeqTsHeader::GetTs ( void  ) const
Returns
the time stamp

Definition at line 55 of file seq-ts-header.cc.

References m_ts, NS_LOG_FUNCTION, and ns3::TimeStep().

Referenced by ns3::UdpServer::HandleRead().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

TypeId ns3::SeqTsHeader::GetTypeId ( void  )
static

Get the type ID.

Returns
the object TypeId

Definition at line 62 of file seq-ts-header.cc.

References ns3::TypeId::SetParent().

Referenced by GetInstanceTypeId().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::SeqTsHeader::Print ( std::ostream &  os) const
virtual
Parameters
osoutput stream This method is used by Packet::Print to print the content of a trailer as ascii data to a c++ output stream. Although the trailer is free to format its output as it wishes, it is recommended to follow a few rules to integrate with the packet pretty printer: start with flags, small field values located between a pair of parens. Values should be separated by whitespace. Follow the parens with the important fields, separated by whitespace. i.e.: (field1 val1 field2 val2 field3 val3) field4 val4 field5 val5

Implements ns3::Header.

Definition at line 76 of file seq-ts-header.cc.

References ns3::Time::GetSeconds(), m_seq, m_ts, NS_LOG_FUNCTION, and ns3::TimeStep().

+ Here is the call graph for this function:

void ns3::SeqTsHeader::Serialize ( Buffer::Iterator  start) const
virtual
Parameters
startan iterator which points to where the header should be written.

This method is used by Packet::AddHeader to store a header into the byte buffer of a packet. The data written is expected to match bit-for-bit the representation of this header in a real network.

Implements ns3::Header.

Definition at line 89 of file seq-ts-header.cc.

References m_seq, m_ts, NS_LOG_FUNCTION, visualizer.core::start(), ns3::Buffer::Iterator::WriteHtonU32(), and ns3::Buffer::Iterator::WriteHtonU64().

+ Here is the call graph for this function:

void ns3::SeqTsHeader::SetSeq ( uint32_t  seq)
Parameters
seqthe sequence number

Definition at line 42 of file seq-ts-header.cc.

References m_seq, and NS_LOG_FUNCTION.

Referenced by ns3::UdpClient::Send(), ns3::EpsBearerTagUdpClient::Send(), and ns3::UdpTraceClient::SendPacket().

+ Here is the caller graph for this function:

Member Data Documentation

uint32_t ns3::SeqTsHeader::m_seq
private

Sequence number.

Definition at line 67 of file seq-ts-header.h.

Referenced by Deserialize(), GetSeq(), Print(), Serialize(), and SetSeq().

uint64_t ns3::SeqTsHeader::m_ts
private

Timestamp.

Definition at line 68 of file seq-ts-header.h.

Referenced by Deserialize(), GetTs(), Print(), and Serialize().


The documentation for this class was generated from the following files: