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

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

#include <pcap-file-wrapper.h>

+ Inheritance diagram for ns3::PcapFileWrapper:
+ Collaboration diagram for ns3::PcapFileWrapper:

Public Member Functions

 PcapFileWrapper ()
 
 ~PcapFileWrapper ()
 
void Clear (void)
 Clear all state bits of the underlying iostream. More...
 
void Close (void)
 Close the underlying pcap file. More...
 
bool Eof (void) const
 
bool Fail (void) const
 
uint32_t GetDataLinkType (void)
 
uint32_t GetMagic (void)
 
uint32_t GetSigFigs (void)
 
uint32_t GetSnapLen (void)
 
int32_t GetTimeZoneOffset (void)
 
uint16_t GetVersionMajor (void)
 
uint16_t GetVersionMinor (void)
 
void Init (uint32_t dataLinkType, uint32_t snapLen=std::numeric_limits< uint32_t >::max(), int32_t tzCorrection=PcapFile::ZONE_DEFAULT)
 Initialize the pcap file associated with this wrapper. More...
 
void Open (std::string const &filename, std::ios::openmode mode)
 Create a new pcap file or open an existing pcap file. More...
 
void Write (Time t, Ptr< const Packet > p)
 Write the next packet to file. More...
 
void Write (Time t, Header &header, Ptr< const Packet > p)
 Write the provided header along with the packet to the pcap file. More...
 
void Write (Time t, uint8_t const *buffer, uint32_t length)
 Write the provided data buffer to the pcap file. More...
 
- Public Member Functions inherited from ns3::Object
 Object ()
 
virtual ~Object ()
 
void AggregateObject (Ptr< Object > other)
 
void Dispose (void)
 Run the DoDispose methods of this object and all the objects aggregated to it. More...
 
AggregateIterator GetAggregateIterator (void) const
 
virtual TypeId GetInstanceTypeId (void) const
 
template<typename T >
Ptr< T > GetObject (void) const
 
template<typename T >
Ptr< T > GetObject (TypeId tid) const
 
void Initialize (void)
 This method calls the virtual DoInitialize method on all the objects aggregated to this object. More...
 
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 SimpleRefCount ()
 Constructor. More...
 
 SimpleRefCount (const SimpleRefCount &o)
 Copy constructor. More...
 
uint32_t GetReferenceCount (void) const
 Get the reference count of the object. More...
 
SimpleRefCountoperator= (const SimpleRefCount &o)
 Assignment. More...
 
void Ref (void) const
 Increment the reference count. More...
 
void Unref (void) const
 Decrement the reference count. More...
 
- 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)
 
- Static Public Member Functions inherited from ns3::Object
static TypeId GetTypeId (void)
 Register this type. More...
 
- Static Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
static void Cleanup (void)
 Noop. More...
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId (void)
 Get the type ID. More...
 

Private Attributes

PcapFile m_file
 
uint32_t m_snapLen
 

Additional Inherited Members

- Protected Member Functions inherited from ns3::Object
 Object (const Object &o)
 
virtual void DoDispose (void)
 This method is called by Object::Dispose or by the object's destructor, whichever comes first. More...
 
virtual void DoInitialize (void)
 This method is called only once by Object::Initialize. More...
 
virtual void NotifyNewAggregate (void)
 This method is invoked whenever two sets of objects are aggregated together. More...
 
- 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.


Attributes

  • CaptureSize: Maximum length of captured packets (cf. pcap snaplen)

No TraceSources are defined for this type.

Definition at line 39 of file pcap-file-wrapper.h.

Constructor & Destructor Documentation

ns3::PcapFileWrapper::PcapFileWrapper ( )

Definition at line 48 of file pcap-file-wrapper.cc.

References NS_LOG_FUNCTION.

ns3::PcapFileWrapper::~PcapFileWrapper ( )

Definition at line 53 of file pcap-file-wrapper.cc.

References Close(), and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

Member Function Documentation

void ns3::PcapFileWrapper::Clear ( void  )

Clear all state bits of the underlying iostream.

Definition at line 73 of file pcap-file-wrapper.cc.

References ns3::PcapFile::Clear(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

void ns3::PcapFileWrapper::Close ( void  )

Close the underlying pcap file.

Definition at line 80 of file pcap-file-wrapper.cc.

References ns3::PcapFile::Close(), m_file, and NS_LOG_FUNCTION.

Referenced by ~PcapFileWrapper().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

bool ns3::PcapFileWrapper::Eof ( void  ) const
Returns
true if the 'eof' bit is set in the underlying iostream, false otherwise.

Definition at line 67 of file pcap-file-wrapper.cc.

References ns3::PcapFile::Eof(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

bool ns3::PcapFileWrapper::Fail ( void  ) const
Returns
true if the 'fail' bit is set in the underlying iostream, false otherwise.

Definition at line 61 of file pcap-file-wrapper.cc.

References ns3::PcapFile::Fail(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

uint32_t ns3::PcapFileWrapper::GetDataLinkType ( void  )

Definition at line 188 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetDataLinkType(), m_file, and NS_LOG_FUNCTION.

Referenced by ns3::PcapSniffRxEvent(), and ns3::PcapSniffTxEvent().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

uint32_t ns3::PcapFileWrapper::GetMagic ( void  )

Definition at line 146 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetMagic(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

uint32_t ns3::PcapFileWrapper::GetSigFigs ( void  )

Definition at line 174 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetSigFigs(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

uint32_t ns3::PcapFileWrapper::GetSnapLen ( void  )

Definition at line 181 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetSnapLen(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

int32_t ns3::PcapFileWrapper::GetTimeZoneOffset ( void  )

Definition at line 167 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetTimeZoneOffset(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

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

Definition at line 33 of file pcap-file-wrapper.cc.

References m_snapLen, ns3::TypeId::SetParent(), and ns3::PcapFile::SNAPLEN_DEFAULT.

+ Here is the call graph for this function:

uint16_t ns3::PcapFileWrapper::GetVersionMajor ( void  )

Definition at line 153 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetVersionMajor(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

uint16_t ns3::PcapFileWrapper::GetVersionMinor ( void  )

Definition at line 160 of file pcap-file-wrapper.cc.

References ns3::PcapFile::GetVersionMinor(), m_file, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

void ns3::PcapFileWrapper::Init ( uint32_t  dataLinkType,
uint32_t  snapLen = std::numeric_limits<uint32_t>::max (),
int32_t  tzCorrection = PcapFile::ZONE_DEFAULT 
)

Initialize the pcap file associated with this wrapper.

This file must have been previously opened with write permissions.

Parameters
dataLinkTypeA data link type as defined in the pcap library. If you want to make resulting pcap files visible in existing tools, the data link type must match existing definitions, such as PCAP_ETHERNET, PCAP_PPP, PCAP_80211, etc. If you are storing different kinds of packet data, such as naked TCP headers, you are at liberty to locally define your own data link types. According to the pcap-linktype man page, "well-known" pcap linktypes range from 0 to 177. If you use a large random number for your type, chances are small for a collision.
snapLenAn optional maximum size for packets written to the file. Defaults to 65535. If packets exceed this length they are truncated.
tzCorrectionAn integer describing the offset of your local time zone from UTC/GMT. For example, Pacific Standard Time in the US is GMT-8, so one would enter -8 for that correction. Defaults to 0 (UTC).
Warning
Calling this method on an existing file will result in the loss any existing data.

Definition at line 94 of file pcap-file-wrapper.cc.

References ns3::PcapFile::Init(), m_file, m_snapLen, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

void ns3::PcapFileWrapper::Open ( std::string const &  filename,
std::ios::openmode  mode 
)

Create a new pcap file or open an existing pcap file.

Semantics are similar to the stdc++ io stream classes.

Since a pcap file is always a binary file, the file type is automatically selected as a binary file (fstream::binary is automatically ored with the mode field).

Parameters
filenameString containing the name of the file.
modeString containing the access mode for the file.

Definition at line 87 of file pcap-file-wrapper.cc.

References m_file, NS_LOG_FUNCTION, and ns3::PcapFile::Open().

+ Here is the call graph for this function:

void ns3::PcapFileWrapper::Write ( Time  t,
Ptr< const Packet p 
)

Write the next packet to file.

Parameters
tPacket timestamp as ns3::Time.
pPacket to write to the pcap file.

Definition at line 113 of file pcap-file-wrapper.cc.

References current, ns3::Time::GetMicroSeconds(), m_file, NS_LOG_FUNCTION, s, and ns3::PcapFile::Write().

Referenced by ns3::Ipv4L3ProtocolRxTxSink(), ns3::Ipv6L3ProtocolRxTxSink(), ns3::PcapSniffRxEvent(), ns3::PcapSniffTxEvent(), ns3::PcapSniffTxRxEvent(), and RxDrop().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::PcapFileWrapper::Write ( Time  t,
Header header,
Ptr< const Packet p 
)

Write the provided header along with the packet to the pcap file.

It is the case that adding a header to a packet prior to writing it to a file must trigger a deep copy in the Packet. By providing the header separately, we can avoid that copy.

Parameters
tPacket timestamp as ns3::Time.
headerThe Header to prepend to the packet.
pPacket to write to the pcap file.

Definition at line 124 of file pcap-file-wrapper.cc.

References current, ns3::Time::GetMicroSeconds(), m_file, NS_LOG_FUNCTION, s, and ns3::PcapFile::Write().

+ Here is the call graph for this function:

void ns3::PcapFileWrapper::Write ( Time  t,
uint8_t const *  buffer,
uint32_t  length 
)

Write the provided data buffer to the pcap file.

Parameters
tPacket timestamp as ns3::Time.
bufferThe buffer to write.
lengthThe size of the buffer.

Definition at line 135 of file pcap-file-wrapper.cc.

References current, ns3::Time::GetMicroSeconds(), m_file, NS_LOG_FUNCTION, s, and ns3::PcapFile::Write().

+ Here is the call graph for this function:

Member Data Documentation

uint32_t ns3::PcapFileWrapper::m_snapLen
private

Definition at line 199 of file pcap-file-wrapper.h.

Referenced by GetTypeId(), and Init().


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