ndn::name::Component Class Reference

Component holds a read-only name component value. More...

#include <name-component.hpp>

+ Inheritance diagram for ndn::name::Component:
+ Collaboration diagram for ndn::name::Component:

Classes

class  Error
 Error that can be thrown from name::Component. More...
 

Public Types

using element_const_iterator = element_container::const_iterator
 
using element_container = std::vector< Block >
 
using element_iterator = element_container::iterator
 

Public Member Functions

 Component ()
 Create a new name::Component with an empty value. More...
 
 Component (const Block &wire)
 Create name::Component from a wire block. More...
 
 Component (const ConstBufferPtr &buffer)
 Create a new name::Component from the buffer pointer (buffer pointer will be copied) More...
 
 Component (const Buffer &buffer)
 Create a new name::Component from the buffer (data from buffer will be copied) More...
 
 Component (const uint8_t *buffer, size_t bufferSize)
 Create a new name::Component from the buffer (data from buffer will be copied) More...
 
template<class Iterator >
 Component (Iterator first, Iterator last)
 Create a new name::Component frome the range [first, last) of bytes. More...
 
 Component (const char *str)
 Create a new name::Component from the C string (data from string will be copied) More...
 
 Component (const std::string &str)
 Create a new name::Component from the STL string (data from string will be copied) More...
 
Buffer::const_iterator begin () const
 Get begin iterator of encoded wire. More...
 
Block blockFromValue () const
 
int compare (const Component &other) const
 Compare this to the other Component using NDN canonical ordering. More...
 
const element_containerelements () const
 Get container of sub elements. More...
 
element_const_iterator elements_begin () const
 Equivalent to elements().begin() More...
 
element_const_iterator elements_end () const
 Equivalent to elements().end() More...
 
size_t elements_size () const
 Equivalent to elements().size() More...
 
bool empty () const
 
void encode ()
 Encode sub elements into TLV-VALUE. More...
 
Buffer::const_iterator end () const
 Get end iterator of encoded wire. More...
 
bool equals (const Component &other) const
 Check if this is the same component as other. More...
 
element_iterator erase (element_const_iterator position)
 Erase a sub element. More...
 
element_iterator erase (element_const_iterator first, element_const_iterator last)
 Erase a range of sub elements. More...
 
element_const_iterator find (uint32_t type) const
 Find the first sub element of specified TLV-TYPE. More...
 
const Blockget (uint32_t type) const
 Get the first sub element of specified TLV-TYPE. More...
 
shared_ptr< const BuffergetBuffer () const
 Get underlying buffer. More...
 
Component getSuccessor () const
 
bool hasValue () const
 Get begin iterator of TLV-VALUE. More...
 
bool hasWire () const
 Check if the Block has fully encoded wire. More...
 
element_iterator insert (element_const_iterator pos, const Block &element)
 Insert a sub element. More...
 
bool isGeneric () const
 Check if the component is GenericComponent. More...
 
bool isImplicitSha256Digest () const
 Check if the component is ImplicitSha256DigestComponent. More...
 
bool isNumber () const
 Check if the component is nonNegativeInteger. More...
 
bool isNumberWithMarker (uint8_t marker) const
 Check if the component is NameComponentWithMarker per NDN naming conventions. More...
 
bool isSegment () const
 Check if the component is segment number per NDN naming conventions. More...
 
bool isSegmentOffset () const
 Check if the component is segment offset per NDN naming conventions. More...
 
bool isSequenceNumber () const
 Check if the component is sequence number per NDN naming conventions. More...
 
bool isTimestamp () const
 Check if the component is timestamp per NDN naming conventions. More...
 
bool isVersion () const
 Check if the component is version per NDN naming conventions. More...
 
 operator boost::asio::const_buffer () const
 Implicit conversion to const_buffer. More...
 
bool operator!= (const Component &other) const
 Check if this is not the same component as other. More...
 
bool operator< (const Component &other) const
 Check if the *this is less than the other in NDN canonical ordering. More...
 
bool operator<= (const Component &other) const
 Check if the *this is less than or equal to the other in NDN canonical ordering. More...
 
bool operator== (const Component &other) const
 Check if this is the same component as other. More...
 
bool operator> (const Component &other) const
 Check if the *this is greater than the other in NDN canonical ordering. More...
 
bool operator>= (const Component &other) const
 Check if the *this is greater or equal than the other in NDN canonical ordering. More...
 
void parse () const
 Parse TLV-VALUE into sub elements. More...
 
void push_back (const Block &element)
 Append a sub element. More...
 
void remove (uint32_t type)
 Remove all sub elements of specified TLV-TYPE. More...
 
void reset ()
 Reset wire buffer of the element. More...
 
void resetWire ()
 Reset wire buffer but keep TLV-TYPE and sub elements (if any) More...
 
size_t size () const
 Get size of encoded wire, including Type-Length-Value. More...
 
uint64_t toNumber () const
 Interpret this name component as nonNegativeInteger. More...
 
uint64_t toNumberWithMarker (uint8_t marker) const
 Interpret this name component as NameComponentWithMarker. More...
 
uint64_t toSegment () const
 Interpret as segment number component using NDN naming conventions. More...
 
uint64_t toSegmentOffset () const
 Interpret as segment offset component using NDN naming conventions. More...
 
uint64_t toSequenceNumber () const
 Interpret as sequence number component using NDN naming conventions. More...
 
time::system_clock::TimePoint toTimestamp () const
 Interpret as timestamp component using NDN naming conventions. More...
 
void toUri (std::ostream &os) const
 Write *this to the output stream, escaping characters according to the NDN URI Scheme. More...
 
std::string toUri () const
 Convert *this by escaping characters according to the NDN URI Scheme. More...
 
uint64_t toVersion () const
 Interpret as version component using NDN naming conventions. More...
 
uint32_t type () const
 Get TLV-TYPE. More...
 
const uint8_t * value () const
 Get pointer to TLV-VALUE. More...
 
Buffer::const_iterator value_begin () const
 Get begin iterator of TLV-VALUE. More...
 
Buffer::const_iterator value_end () const
 Get end iterator of TLV-VALUE. More...
 
size_t value_size () const
 Get size of TLV-VALUE aka TLV-LENGTH. More...
 
const uint8_t * wire () const
 Get pointer to encoded wire. More...
 
void wireDecode (const Block &wire)
 Decode from the wire format. More...
 
template<encoding::Tag TAG>
size_t wireEncode (EncodingImpl< TAG > &encoder) const
 Fast encoding or block size estimation. More...
 
const BlockwireEncode () const
 Encode to a wire format. More...
 

Static Public Member Functions

static std::tuple< bool, BlockfromBuffer (ConstBufferPtr buffer, size_t offset)
 Try to parse Block from a wire buffer. More...
 
static std::tuple< bool, BlockfromBuffer (const uint8_t *buf, size_t bufSize)
 Try to parse Block from a raw buffer. More...
 
static Component fromEscapedString (const char *escapedString, size_t beginOffset, size_t endOffset)
 Create name::Component by decoding the escapedString between beginOffset and endOffset according to the NDN URI Scheme. More...
 
static Component fromEscapedString (const char *escapedString)
 Create name::Component by decoding the escapedString according to the NDN URI Scheme. More...
 
static Component fromEscapedString (const std::string &escapedString)
 Create name::Component by decoding the escapedString according to the NDN URI Scheme. More...
 
static Component fromImplicitSha256Digest (const ConstBufferPtr &digest)
 Create ImplicitSha256DigestComponent component. More...
 
static Component fromImplicitSha256Digest (const uint8_t *digest, size_t digestSize)
 Create ImplicitSha256DigestComponent component. More...
 
static Component fromNumber (uint64_t number)
 Create a component encoded as nonNegativeInteger. More...
 
static Component fromNumberWithMarker (uint8_t marker, uint64_t number)
 Create a component encoded as NameComponentWithMarker. More...
 
static Component fromSegment (uint64_t segmentNo)
 Create segment number component using NDN naming conventions. More...
 
static Component fromSegmentOffset (uint64_t offset)
 Create segment offset component using NDN naming conventions. More...
 
static Component fromSequenceNumber (uint64_t seqNo)
 Create sequence number component using NDN naming conventions. More...
 
static Block fromStream (std::istream &is)
 Parse Block from an input stream. More...
 
static Component fromTimestamp (const time::system_clock::TimePoint &timePoint)
 Create sequence number component using NDN naming conventions. More...
 
static Component fromVersion (uint64_t version)
 Create version component using NDN naming conventions. More...
 

Protected Attributes

Buffer::const_iterator m_begin
 
shared_ptr< const Bufferm_buffer
 underlying buffer storing TLV-VALUE and possibly TLV-TYPE and TLV-LENGTH fields More...
 
element_container m_elements
 sub elements More...
 
Buffer::const_iterator m_end
 
uint32_t m_size
 total size including Type-Length-Value More...
 
uint32_t m_type
 TLV-TYPE. More...
 
Buffer::const_iterator m_valueBegin
 
Buffer::const_iterator m_valueEnd
 

Detailed Description

Component holds a read-only name component value.

Definition at line 47 of file name-component.hpp.

Member Typedef Documentation

using ndn::Block::element_const_iterator = element_container::const_iterator
inherited

Definition at line 47 of file block.hpp.

using ndn::Block::element_container = std::vector<Block>
inherited

Definition at line 45 of file block.hpp.

using ndn::Block::element_iterator = element_container::iterator
inherited

Definition at line 46 of file block.hpp.

Constructor & Destructor Documentation

ndn::name::Component::Component ( )

Create a new name::Component with an empty value.

Definition at line 53 of file name-component.cpp.

ndn::name::Component::Component ( const Block wire)

Create name::Component from a wire block.

Parameters
wiretlv::NameComponent Block from which to create name::Component
Exceptions
Errorif wire.type() is not tlv::NameComponent

Any block can be implicitly converted to name::Component

Definition at line 58 of file name-component.cpp.

ndn::name::Component::Component ( const ConstBufferPtr buffer)
explicit

Create a new name::Component from the buffer pointer (buffer pointer will be copied)

Parameters
bufferA pointer to an immutable buffer

This constructor will create a new tlv::NameComponent Block with buffer as a payload. Note that this method will not allocate new memory for and copy the payload until toWire() method is called.

Definition at line 66 of file name-component.cpp.

ndn::name::Component::Component ( const Buffer buffer)
explicit

Create a new name::Component from the buffer (data from buffer will be copied)

Parameters
bufferA reference to the buffer

This constructor will create a new tlv::NameComponent Block with buffer as a payload. Note that this method will allocate new memory for and copy the payload.

Definition at line 71 of file name-component.cpp.

ndn::name::Component::Component ( const uint8_t *  buffer,
size_t  bufferSize 
)

Create a new name::Component from the buffer (data from buffer will be copied)

Parameters
bufferA pointer to the first byte of the buffer
bufferSizeSize of the buffer

This constructor will create a new tlv::NameComponent Block with buffer as a payload. Note that this method will allocate new memory for and copy the payload.

Definition at line 76 of file name-component.cpp.

template<class Iterator >
ndn::name::Component::Component ( Iterator  first,
Iterator  last 
)
inline

Create a new name::Component frome the range [first, last) of bytes.

Parameters
firstIterator pointing to the beginning of the buffer
lastIterator pointing to the ending of the buffer
Template Parameters
Iteratoriterator type satisfying at least InputIterator concept. Implementation is more optimal when the iterator type satisfies RandomAccessIterator concept. It is required that sizeof(std::iterator_traits<Iterator>::value_type) == 1.

This constructor will create a new tlv::NameComponent Block with buffer as a payload. Note that this method will allocate new memory for and copy the payload.

Definition at line 581 of file name-component.hpp.

ndn::name::Component::Component ( const char *  str)
explicit

Create a new name::Component from the C string (data from string will be copied)

Parameters
strZero-ended string. Note that this string will be interpreted as is (i.e., it will not be interpreted as URI)

This constructor will create a new tlv::NameComponent Block with buffer as a payload. Note that this method will allocate new memory for and copy the payload.

Definition at line 81 of file name-component.cpp.

ndn::name::Component::Component ( const std::string &  str)
explicit

Create a new name::Component from the STL string (data from string will be copied)

Parameters
strConst reference to STL string. Note that this string will be interpreted as is (i.e., it will not be interpreted as URI)

This constructor will create a new tlv::NameComponent Block with buffer as a payload. Note that this method will allocate new memory for and copy the payload.

Definition at line 86 of file name-component.cpp.

Member Function Documentation

Buffer::const_iterator ndn::Block::begin ( ) const
inherited

Get begin iterator of encoded wire.

Precondition
hasWire() == true

Definition at line 272 of file block.cpp.

Block ndn::Block::blockFromValue ( ) const
inherited

Definition at line 323 of file block.cpp.

int ndn::name::Component::compare ( const Component other) const

Compare this to the other Component using NDN canonical ordering.

Parameters
otherThe other Component to compare with.
Return values
negativethis comes before other in canonical ordering
zerothis equals other
positivethis comes after other in canonical ordering
See also
http://named-data.net/doc/ndn-tlv/name.html#canonical-order

Definition at line 395 of file name-component.cpp.

const element_container& ndn::Block::elements ( ) const
inlineinherited

Get container of sub elements.

Precondition
parse() has been executed

Definition at line 347 of file block.hpp.

element_const_iterator ndn::Block::elements_begin ( ) const
inlineinherited

Equivalent to elements().begin()

Definition at line 355 of file block.hpp.

element_const_iterator ndn::Block::elements_end ( ) const
inlineinherited

Equivalent to elements().end()

Definition at line 363 of file block.hpp.

size_t ndn::Block::elements_size ( ) const
inlineinherited

Equivalent to elements().size()

Definition at line 371 of file block.hpp.

bool ndn::name::Component::empty ( ) const
inline

Definition at line 463 of file name-component.hpp.

void ndn::Block::encode ( )
inherited

Encode sub elements into TLV-VALUE.

Postcondition
TLV-VALUE contains sub elements from elements()

Definition at line 362 of file block.cpp.

Buffer::const_iterator ndn::Block::end ( ) const
inherited

Get end iterator of encoded wire.

Precondition
hasWire() == true

Definition at line 281 of file block.cpp.

bool ndn::name::Component::equals ( const Component other) const

Check if this is the same component as other.

Parameters
otherThe other Component to compare with
Returns
true if the components are equal, otherwise false.

Definition at line 386 of file name-component.cpp.

Block::element_iterator ndn::Block::erase ( Block::element_const_iterator  position)
inherited

Erase a sub element.

Definition at line 445 of file block.cpp.

Block::element_iterator ndn::Block::erase ( Block::element_const_iterator  first,
Block::element_const_iterator  last 
)
inherited

Erase a range of sub elements.

Definition at line 459 of file block.cpp.

Block::element_const_iterator ndn::Block::find ( uint32_t  type) const
inherited

Find the first sub element of specified TLV-TYPE.

Precondition
parse() has been executed
Returns
iterator in elements() to the found sub element, otherwise elements_end()

Definition at line 428 of file block.cpp.

std::tuple< bool, Block > ndn::Block::fromBuffer ( ConstBufferPtr  buffer,
size_t  offset 
)
staticinherited

Try to parse Block from a wire buffer.

Parameters
buffera Buffer containing an TLV element at offset offset
offsetbegin position of the TLV element within buffer
Note
This function does not throw exceptions upon decoding failure.
Returns
true and the Block if parsing succeeds; otherwise false

Definition at line 195 of file block.cpp.

std::tuple< bool, Block > ndn::Block::fromBuffer ( const uint8_t *  buf,
size_t  bufSize 
)
staticinherited

Try to parse Block from a raw buffer.

Parameters
bufpointer to the first octet of an TLV element
bufSizesize of the raw buffer; may be more than size of the TLV element
Note
This function does not throw exceptions upon decoding failure.
This overload copies the TLV element into an internal wire buffer.
Returns
true and the Block if parsing succeeds; otherwise false

Definition at line 220 of file block.cpp.

Component ndn::name::Component::fromEscapedString ( const char *  escapedString,
size_t  beginOffset,
size_t  endOffset 
)
static

Create name::Component by decoding the escapedString between beginOffset and endOffset according to the NDN URI Scheme.

If the escaped string is "", "." or ".." then return an empty name::Component. Note that an empty name::Component should not be added to Name and if attempted, an exception will be thrown.

Parameters
escapedStringString containing NDN URI-encoded name component. [escapedString+beginOffset, beginOffset+endOffset) must be a valid memory buffer.
beginOffsetThe offset in escapedString of the beginning of the portion to decode.
endOffsetThe offset in escapedString of the end of the portion to decode.

Definition at line 92 of file name-component.cpp.

static Component ndn::name::Component::fromEscapedString ( const char *  escapedString)
inlinestatic

Create name::Component by decoding the escapedString according to the NDN URI Scheme.

This overload is a convenience wrapper for fromEscapedString(char*,size_t,size)

Definition at line 190 of file name-component.hpp.

static Component ndn::name::Component::fromEscapedString ( const std::string &  escapedString)
inlinestatic

Create name::Component by decoding the escapedString according to the NDN URI Scheme.

This overload is a convenience wrapper for fromEscapedString(char*,size_t,size)

Definition at line 201 of file name-component.hpp.

Component ndn::name::Component::fromImplicitSha256Digest ( const ConstBufferPtr digest)
static

Create ImplicitSha256DigestComponent component.

Definition at line 364 of file name-component.cpp.

Component ndn::name::Component::fromImplicitSha256Digest ( const uint8_t *  digest,
size_t  digestSize 
)
static

Create ImplicitSha256DigestComponent component.

Definition at line 374 of file name-component.cpp.

Component ndn::name::Component::fromNumber ( uint64_t  number)
static

Create a component encoded as nonNegativeInteger.

See also
http://named-data.net/doc/ndn-tlv/tlv.html#non-negative-integer-encoding
Parameters
numberThe non-negative number
Returns
The component value.

Definition at line 291 of file name-component.cpp.

Component ndn::name::Component::fromNumberWithMarker ( uint8_t  marker,
uint64_t  number 
)
static

Create a component encoded as NameComponentWithMarker.

NameComponentWithMarker is defined as:

NameComponentWithMarker ::= NAME-COMPONENT-TYPE TLV-LEGTH
                              Marker
                              includedNonNegativeInteger
Marker ::= BYTE
includedNonNegativeInteger ::= BYTE{1,2,4,8}
NDN-TLV := TLV-TYPE TLV-LENGTH TLV-VALUE?
TLV-TYPE := VAR-NUMBER
TLV-LENGTH := VAR-NUMBER
TLV-VALUE := BYTE+
See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Parameters
marker1-byte marker octet
numberThe non-negative number
Returns
The component value.

Definition at line 297 of file name-component.cpp.

Component ndn::name::Component::fromSegment ( uint64_t  segmentNo)
static

Create segment number component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 323 of file name-component.cpp.

Component ndn::name::Component::fromSegmentOffset ( uint64_t  offset)
static

Create segment offset component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 329 of file name-component.cpp.

Component ndn::name::Component::fromSequenceNumber ( uint64_t  seqNo)
static

Create sequence number component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 343 of file name-component.cpp.

Block ndn::Block::fromStream ( std::istream &  is)
staticinherited

Parse Block from an input stream.

Exceptions
tlv::ErrorTLV-LENGTH is zero or exceeds upper bound
Warning
If decoding fails, bytes are still consumed from the input stream.

Definition at line 163 of file block.cpp.

Component ndn::name::Component::fromTimestamp ( const time::system_clock::TimePoint timePoint)
static

Create sequence number component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 335 of file name-component.cpp.

Component ndn::name::Component::fromVersion ( uint64_t  version)
static

Create version component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 317 of file name-component.cpp.

const Block & ndn::Block::get ( uint32_t  type) const
inherited

Get the first sub element of specified TLV-TYPE.

Precondition
parse() has been executed
Exceptions
Errorsub element of type does not exist

Definition at line 416 of file block.cpp.

shared_ptr<const Buffer> ndn::Block::getBuffer ( ) const
inlineinherited

Get underlying buffer.

Definition at line 226 of file block.hpp.

Component ndn::name::Component::getSuccessor ( ) const

Definition at line 420 of file name-component.cpp.

bool ndn::Block::hasValue ( ) const
inlineinherited

Get begin iterator of TLV-VALUE.

This property reflects whether the underlying buffer contains TLV-VALUE. If this is false, TLV-VALUE has zero-length. If this is true, TLV-VALUE may be zero-length.

Definition at line 246 of file block.hpp.

bool ndn::Block::hasWire ( ) const
inherited

Check if the Block has fully encoded wire.

A Block has fully encoded wire if the underlying buffer exists and contains full Type-Length-Value instead of just TLV-VALUE field.

Definition at line 250 of file block.cpp.

Block::element_iterator ndn::Block::insert ( Block::element_const_iterator  pos,
const Block element 
)
inherited

Insert a sub element.

Parameters
posposition of new sub element
elementnew sub element
Returns
iterator in elements() to the new sub element

Definition at line 482 of file block.cpp.

bool ndn::name::Component::isGeneric ( ) const

Check if the component is GenericComponent.

Definition at line 351 of file name-component.cpp.

bool ndn::name::Component::isImplicitSha256Digest ( ) const

Check if the component is ImplicitSha256DigestComponent.

Definition at line 357 of file name-component.cpp.

bool ndn::name::Component::isNumber ( ) const

Check if the component is nonNegativeInteger.

See also
http://named-data.net/doc/ndn-tlv/tlv.html#non-negative-integer-encoding

Definition at line 191 of file name-component.cpp.

bool ndn::name::Component::isNumberWithMarker ( uint8_t  marker) const

Check if the component is NameComponentWithMarker per NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 198 of file name-component.cpp.

bool ndn::name::Component::isSegment ( ) const

Check if the component is segment number per NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 212 of file name-component.cpp.

bool ndn::name::Component::isSegmentOffset ( ) const

Check if the component is segment offset per NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 218 of file name-component.cpp.

bool ndn::name::Component::isSequenceNumber ( ) const

Check if the component is sequence number per NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 230 of file name-component.cpp.

bool ndn::name::Component::isTimestamp ( ) const

Check if the component is timestamp per NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 224 of file name-component.cpp.

bool ndn::name::Component::isVersion ( ) const

Check if the component is version per NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf

Definition at line 206 of file name-component.cpp.

ndn::Block::operator boost::asio::const_buffer ( ) const
inherited

Implicit conversion to const_buffer.

Definition at line 497 of file block.cpp.

bool ndn::name::Component::operator!= ( const Component other) const
inline

Check if this is not the same component as other.

Parameters
otherThe other Component to compare with
Returns
true if the components are not equal, otherwise false

Definition at line 508 of file name-component.hpp.

bool ndn::name::Component::operator< ( const Component other) const
inline

Check if the *this is less than the other in NDN canonical ordering.

Parameters
otherThe other Component to compare with
See also
http://named-data.net/doc/ndn-tlv/name.html#canonical-order

Definition at line 532 of file name-component.hpp.

bool ndn::name::Component::operator<= ( const Component other) const
inline

Check if the *this is less than or equal to the other in NDN canonical ordering.

Parameters
otherThe other Component to compare with
See also
http://named-data.net/doc/ndn-tlv/name.html#canonical-order

Definition at line 520 of file name-component.hpp.

bool ndn::name::Component::operator== ( const Component other) const
inline

Check if this is the same component as other.

Parameters
otherThe other Component to compare with.
Returns
true if the components are equal, otherwise false.

Definition at line 497 of file name-component.hpp.

bool ndn::name::Component::operator> ( const Component other) const
inline

Check if the *this is greater than the other in NDN canonical ordering.

Parameters
otherThe other Component to compare with
See also
http://named-data.net/doc/ndn-tlv/name.html#canonical-order

Definition at line 556 of file name-component.hpp.

bool ndn::name::Component::operator>= ( const Component other) const
inline

Check if the *this is greater or equal than the other in NDN canonical ordering.

Parameters
otherThe other Component to compare with
See also
http://named-data.net/doc/ndn-tlv/name.html#canonical-order

Definition at line 544 of file name-component.hpp.

void ndn::Block::parse ( ) const
inherited

Parse TLV-VALUE into sub elements.

Postcondition
elements() reflects sub elements found in TLV-VALUE
Exceptions
tlv::ErrorTLV-VALUE is not a sequence of TLV elements
Note
This method does not perform recursive parsing.
This method has no effect if elements() is already populated.
This method is not really const, but it does not modify any data.

Definition at line 334 of file block.cpp.

void ndn::Block::push_back ( const Block element)
inherited

Append a sub element.

Definition at line 475 of file block.cpp.

void ndn::Block::remove ( uint32_t  type)
inherited

Remove all sub elements of specified TLV-TYPE.

Precondition
parse() has been executed
Postcondition
find(type) == elements_end()

Definition at line 435 of file block.cpp.

void ndn::Block::reset ( )
inherited

Reset wire buffer of the element.

Postcondition
empty() == true

Definition at line 256 of file block.cpp.

void ndn::Block::resetWire ( )
inherited

Reset wire buffer but keep TLV-TYPE and sub elements (if any)

Postcondition
hasWire() == false
hasValue() == false

Definition at line 265 of file block.cpp.

size_t ndn::Block::size ( ) const
inherited

Get size of encoded wire, including Type-Length-Value.

Precondition
empty() == false

Definition at line 299 of file block.cpp.

uint64_t ndn::name::Component::toNumber ( ) const

Interpret this name component as nonNegativeInteger.

See also
http://named-data.net/doc/ndn-tlv/tlv.html#non-negative-integer-encoding
Returns
The integer number.

Definition at line 238 of file name-component.cpp.

uint64_t ndn::name::Component::toNumberWithMarker ( uint8_t  marker) const

Interpret this name component as NameComponentWithMarker.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Parameters
marker1-byte octet of the marker
Returns
The integer number.
Exceptions
Errorif name component does not have the specified marker. tlv::Error if format does not follow NameComponentWithMarker specification.

Definition at line 247 of file name-component.cpp.

uint64_t ndn::name::Component::toSegment ( ) const

Interpret as segment number component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Exceptions
Errorif name component does not have the specified marker. tlv::Error if format does not follow NameComponentWithMarker specification.

Definition at line 264 of file name-component.cpp.

uint64_t ndn::name::Component::toSegmentOffset ( ) const

Interpret as segment offset component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Exceptions
Errorif name component does not have the specified marker. tlv::Error if format does not follow NameComponentWithMarker specification.

Definition at line 270 of file name-component.cpp.

uint64_t ndn::name::Component::toSequenceNumber ( ) const

Interpret as sequence number component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Exceptions
Errorif name component does not have the specified marker. tlv::Error if format does not follow NameComponentWithMarker specification.

Definition at line 283 of file name-component.cpp.

time::system_clock::TimePoint ndn::name::Component::toTimestamp ( ) const

Interpret as timestamp component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Exceptions
Errorif name component does not have the specified marker. tlv::Error if format does not follow NameComponentWithMarker specification.

Definition at line 276 of file name-component.cpp.

void ndn::name::Component::toUri ( std::ostream &  os) const

Write *this to the output stream, escaping characters according to the NDN URI Scheme.

This also adds "..." to a value with zero or more "."

Parameters
osThe output stream to where write the URI escaped version *this

Definition at line 131 of file name-component.cpp.

std::string ndn::name::Component::toUri ( ) const

Convert *this by escaping characters according to the NDN URI Scheme.

This also adds "..." to a value with zero or more "."

Returns
The escaped string

Definition at line 181 of file name-component.cpp.

uint64_t ndn::name::Component::toVersion ( ) const

Interpret as version component using NDN naming conventions.

See also
http://named-data.net/doc/tech-memos/naming-conventions.pdf
Exceptions
Errorif name component does not have the specified marker. tlv::Error if format does not follow NameComponentWithMarker specification.

Definition at line 258 of file name-component.cpp.

uint32_t ndn::Block::type ( ) const
inlineinherited

Get TLV-TYPE.

Definition at line 235 of file block.hpp.

const uint8_t * ndn::Block::value ( ) const
inherited

Get pointer to TLV-VALUE.

Definition at line 311 of file block.cpp.

Buffer::const_iterator ndn::Block::value_begin ( ) const
inlineinherited

Get begin iterator of TLV-VALUE.

Precondition
hasValue() == true

Definition at line 255 of file block.hpp.

Buffer::const_iterator ndn::Block::value_end ( ) const
inlineinherited

Get end iterator of TLV-VALUE.

Precondition
hasValue() == true

Definition at line 264 of file block.hpp.

size_t ndn::Block::value_size ( ) const
inherited

Get size of TLV-VALUE aka TLV-LENGTH.

Definition at line 317 of file block.cpp.

const uint8_t * ndn::Block::wire ( ) const
inherited

Get pointer to encoded wire.

Precondition
hasWire() == true

Definition at line 290 of file block.cpp.

void ndn::name::Component::wireDecode ( const Block wire)

Decode from the wire format.

Definition at line 478 of file name-component.cpp.

template<encoding::Tag TAG>
size_t ndn::name::Component::wireEncode ( EncodingImpl< TAG > &  encoder) const

Fast encoding or block size estimation.

Definition at line 449 of file name-component.cpp.

const Block & ndn::name::Component::wireEncode ( ) const

Encode to a wire format.

Definition at line 462 of file name-component.cpp.

Member Data Documentation

Buffer::const_iterator ndn::Block::m_begin
protectedinherited
See also
m_buffer

Definition at line 404 of file block.hpp.

shared_ptr<const Buffer> ndn::Block::m_buffer
protectedinherited

underlying buffer storing TLV-VALUE and possibly TLV-TYPE and TLV-LENGTH fields

If m_buffer is nullptr, this is an empty Block with TLV-TYPE given in m_type. Otherwise,

  • [m_valueBegin, m_valueEnd) point to TLV-VALUE within m_buffer.
  • If m_begin != m_end, [m_begin,m_end) point to Type-Length-Value of this Block within m_buffer. Otherwise, m_buffer does not contain TLV-TYPE and TLV-LENGTH fields.

Definition at line 403 of file block.hpp.

element_container ndn::Block::m_elements
mutableprotectedinherited

sub elements

This field is valid only if parse() has been executed.

Definition at line 422 of file block.hpp.

Buffer::const_iterator ndn::Block::m_end
protectedinherited
See also
m_buffer

Definition at line 405 of file block.hpp.

uint32_t ndn::Block::m_size
protectedinherited

total size including Type-Length-Value

This field is valid only if empty() is false.

Definition at line 416 of file block.hpp.

uint32_t ndn::Block::m_type
protectedinherited

TLV-TYPE.

Definition at line 410 of file block.hpp.

Buffer::const_iterator ndn::Block::m_valueBegin
protectedinherited
See also
m_buffer

Definition at line 407 of file block.hpp.

Buffer::const_iterator ndn::Block::m_valueEnd
protectedinherited
See also
m_buffer

Definition at line 408 of file block.hpp.