NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
fib-entry.hpp
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2014-2018, Regents of the University of California,
4
* Arizona Board of Regents,
5
* Colorado State University,
6
* University Pierre & Marie Curie, Sorbonne University,
7
* Washington University in St. Louis,
8
* Beijing Institute of Technology,
9
* The University of Memphis.
10
*
11
* This file is part of NFD (Named Data Networking Forwarding Daemon).
12
* See AUTHORS.md for complete list of NFD authors and contributors.
13
*
14
* NFD is free software: you can redistribute it and/or modify it under the terms
15
* of the GNU General Public License as published by the Free Software Foundation,
16
* either version 3 of the License, or (at your option) any later version.
17
*
18
* NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20
* PURPOSE. See the GNU General Public License for more details.
21
*
22
* You should have received a copy of the GNU General Public License along with
23
* NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24
*/
25
26
#ifndef NFD_DAEMON_TABLE_FIB_ENTRY_HPP
27
#define NFD_DAEMON_TABLE_FIB_ENTRY_HPP
28
29
#include "
fib-nexthop.hpp
"
30
31
namespace
nfd
{
32
33
namespace
name_tree {
34
class
Entry
;
35
}
// namespace name_tree
36
37
namespace
fib {
38
47
using
NextHopList
= std::vector<NextHop>;
48
51
class
Entry
: noncopyable
52
{
53
public
:
54
explicit
55
Entry
(
const
Name
& prefix);
56
57
const
Name
&
58
getPrefix
()
const
59
{
60
return
m_prefix;
61
}
62
63
const
NextHopList
&
64
getNextHops
()
const
65
{
66
return
m_nextHops;
67
}
68
71
bool
72
hasNextHops
()
const
73
{
74
return
!m_nextHops.empty();
75
}
76
79
bool
80
hasNextHop
(
const
Face
&
face
)
const
;
81
86
void
87
addNextHop
(
Face
&
face
, uint64_t cost);
88
93
void
94
removeNextHop
(
const
Face
&
face
);
95
96
private
:
99
NextHopList::iterator
100
findNextHop(
const
Face
&
face
);
101
104
void
105
sortNextHops();
106
107
private
:
108
Name
m_prefix;
109
NextHopList
m_nextHops;
110
111
name_tree::Entry
* m_nameTreeEntry;
112
113
friend
class
name_tree::Entry
;
114
};
115
116
}
// namespace fib
117
}
// namespace nfd
118
119
#endif // NFD_DAEMON_TABLE_FIB_ENTRY_HPP
nfd::fib::Entry::getPrefix
const Name & getPrefix() const
Definition:
fib-entry.hpp:58
nfd::face::Face
generalization of a network interface
Definition:
face.hpp:67
nfd::fib::Entry
represents a FIB entry
Definition:
fib-entry.hpp:51
nfd::fib::Entry::addNextHop
void addNextHop(Face &face, uint64_t cost)
adds a NextHop record
Definition:
fib-entry.cpp:53
fib-nexthop.hpp
nfd::fib::NextHopList
Represents a collection of nexthops.
nfd::fib::Entry::Entry
Entry(const Name &prefix)
Definition:
fib-entry.cpp:31
nfd::cs::iterator
Table::const_iterator iterator
Definition:
cs-internal.hpp:41
nfd::fib::Entry::removeNextHop
void removeNextHop(const Face &face)
removes a NextHop record
Definition:
fib-entry.cpp:66
nfd
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-common.hpp:40
face
ndn::Name
Represents an absolute name.
Definition:
name.hpp:42
nfd::fib::Entry::getNextHops
const NextHopList & getNextHops() const
Definition:
fib-entry.hpp:64
nfd::fib::Entry::hasNextHops
bool hasNextHops() const
Definition:
fib-entry.hpp:72
nfd::name_tree::Entry
an entry in the name tree
Definition:
name-tree-entry.hpp:41
nfd::fib::Entry::hasNextHop
bool hasNextHop(const Face &face) const
Definition:
fib-entry.cpp:47
ndnSIM
NFD
daemon
table
fib-entry.hpp
Generated on Tue Aug 7 2018 16:19:18 for ndnSIM by
1.8.14