25 #include <ndn-cxx/util/concepts.hpp> 26 #include <ndn-cxx/encoding/block-helpers.hpp> 31 BOOST_CONCEPT_ASSERT((ndn::WireEncodable<LsdbStatus>));
32 BOOST_CONCEPT_ASSERT((ndn::WireDecodable<LsdbStatus>));
33 static_assert(std::is_base_of<ndn::tlv::Error, LsdbStatus::Error>::value,
34 "LsdbStatus::Error must inherit from tlv::Error");
37 : m_hasAdjacencyLsas(false)
38 , m_hasCoordinateLsas(false)
39 , m_hasNameLsas(false)
51 m_adjacencyLsas.push_back(adjacencyLsa);
53 m_hasAdjacencyLsas =
true;
60 m_adjacencyLsas.clear();
61 m_hasAdjacencyLsas =
false;
68 m_coordinateLsas.push_back(coordinateLsa);
70 m_hasCoordinateLsas =
true;
77 m_coordinateLsas.clear();
78 m_hasCoordinateLsas =
false;
85 m_nameLsas.push_back(nameLsa);
95 m_hasNameLsas =
false;
99 template<ndn::encoding::Tag TAG>
103 size_t totalLength = 0;
105 for (std::list<NameLsa>::const_reverse_iterator it = m_nameLsas.rbegin();
106 it != m_nameLsas.rend(); ++it) {
107 totalLength += it->wireEncode(block);
110 for (std::list<CoordinateLsa>::const_reverse_iterator it = m_coordinateLsas.rbegin();
111 it != m_coordinateLsas.rend(); ++it) {
112 totalLength += it->wireEncode(block);
115 for (std::list<AdjacencyLsa>::const_reverse_iterator it = m_adjacencyLsas.rbegin();
116 it != m_adjacencyLsas.rend(); ++it) {
117 totalLength += it->wireEncode(block);
120 totalLength += block.prependVarNumber(totalLength);
131 if (m_wire.hasWire()) {
135 ndn::EncodingEstimator estimator;
138 ndn::EncodingBuffer buffer(estimatedSize, 0);
141 m_wire = buffer.block();
149 m_adjacencyLsas.clear();
150 m_coordinateLsas.clear();
153 m_hasAdjacencyLsas =
false;
154 m_hasCoordinateLsas =
false;
155 m_hasNameLsas =
false;
160 std::stringstream error;
161 error <<
"Expected LsdbStatus Block, but Block is of a different type: #" 163 BOOST_THROW_EXCEPTION(
Error(error.str()));
168 ndn::Block::element_const_iterator val = m_wire.elements_begin();
172 m_hasAdjacencyLsas =
true;
177 m_hasCoordinateLsas =
true;
181 m_nameLsas.push_back(
NameLsa(*val));
182 m_hasNameLsas =
true;
185 if (val != m_wire.elements_end()) {
186 std::stringstream error;
187 error <<
"Expected the end of elements, but Block is of a different type: #" 189 BOOST_THROW_EXCEPTION(
Error(error.str()));
222 for (
const auto& nameLsa : lsdbStatus.
getNameLsas()) {
LsdbStatus & clearAdjacencyLsas()
void wireDecode(const ndn::Block &wire)
Populate this object by decoding the one contained in the given block.
const std::list< CoordinateLsa > & getCoordinateLsas() const
Data abstraction for CoordinateLsa.
const ndn::Block & wireEncode() const
Create a TLV encoding of this object.
NDN_CXX_DEFINE_WIRE_ENCODE_INSTANTIATIONS(AdjacencyLsa)
LsdbStatus & clearNameLsas()
LsdbStatus & addCoordinateLsa(const CoordinateLsa &coordinateLsa)
LsdbStatus & clearCoordinateLsas()
LsdbStatus & addAdjacencyLsa(const AdjacencyLsa &adjacencyLsa)
Data abstraction for NameLsa.
const std::list< AdjacencyLsa > & getAdjacencyLsas() const
Copyright (c) 2014-2018, The University of Memphis, Regents of the University of California, Arizona Board of Regents.
Data abstraction for AdjacencyLsa.
Data abstraction for LsdbStatus.
LsdbStatus & addNameLsa(const NameLsa &nameLsa)
std::ostream & operator<<(std::ostream &os, const AdjacencyLsa &adjacencyLsa)
const std::list< NameLsa > & getNameLsas() const