NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.3: NDN, CCN, CCNx, content centric networks
API Documentation
nfd::pit::Pit Class Reference

represents the Interest Table More...

#include <pit.hpp>

Inheritance diagram for nfd::pit::Pit:
Collaboration diagram for nfd::pit::Pit:

Public Types

typedef Iterator const_iterator

Public Member Functions

 Pit (NameTree &nameTree)
size_t size () const
shared_ptr< Entryfind (const Interest &interest) const
 finds a PIT entry for Interest More...
std::pair< shared_ptr< Entry >, bool > insert (const Interest &interest)
 inserts a PIT entry for Interest More...
DataMatchResult findAllDataMatches (const Data &data) const
 performs a Data match More...
void erase (Entry *entry)
 deletes an entry More...
void deleteInOutRecords (Entry *entry, const Face &face)
 deletes in-record and out-record for face More...
const_iterator begin () const
const_iterator end () const

Detailed Description

represents the Interest Table

Definition at line 46 of file pit.hpp.

Member Typedef Documentation

◆ const_iterator

Definition at line 101 of file pit.hpp.

Constructor & Destructor Documentation

◆ Pit()

Member Function Documentation

◆ size()

size_t nfd::pit::Pit::size ( ) const
number of entries

Definition at line 55 of file pit.hpp.

Referenced by nfd::ForwarderStatusManager::ForwarderStatusManager().

◆ find()

shared_ptr<Entry> nfd::pit::Pit::find ( const Interest interest) const

finds a PIT entry for Interest

interestthe Interest
an existing entry with same Name and Selectors; otherwise nullptr

Definition at line 65 of file pit.hpp.

Referenced by nfd::Forwarder::startProcessNack().

◆ insert()

std::pair<shared_ptr<Entry>, bool> nfd::pit::Pit::insert ( const Interest interest)

inserts a PIT entry for Interest

interestthe Interest; must be created with make_shared
a new or existing entry with same Name and Selectors, and true for new entry, false for existing entry

Definition at line 76 of file pit.hpp.

References findAllDataMatches().

Referenced by nfd::Forwarder::startProcessNack().

◆ findAllDataMatches()

DataMatchResult nfd::pit::Pit::findAllDataMatches ( const Data data) const

◆ erase()

void nfd::pit::Pit::erase ( Entry entry)

deletes an entry

Definition at line 90 of file pit.hpp.

References deleteInOutRecords().

Referenced by end(), findAllDataMatches(), and nfd::Forwarder::startProcessNack().

◆ deleteInOutRecords()

void nfd::pit::Pit::deleteInOutRecords ( Entry entry,
const Face face 

deletes in-record and out-record for face

Definition at line 117 of file pit.cpp.

References nfd::pit::Entry::deleteInRecord(), and nfd::pit::Entry::deleteOutRecord().

Referenced by nfd::cleanupOnFaceRemoval(), and erase().

◆ begin()

Pit::const_iterator nfd::pit::Pit::begin ( ) const
an iterator to the beginning
Iteration order is implementation-defined.
Undefined behavior may occur if a FIB/PIT/Measurements/StrategyChoice entry is inserted or erased during enumeration.

Definition at line 128 of file pit.cpp.

References nfd::name_tree::NameTree::fullEnumerate(), and nfd::pit::nteHasPitEntries().

◆ end()

const_iterator nfd::pit::Pit::end ( ) const
an iterator to the end
See also

Definition at line 115 of file pit.hpp.

References erase().

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