blob: 3adf841735dd3ada54d2364f1d9778e2a59b9629 [file] [log] [blame]
Jeff Thompson47eecfc2013-07-07 22:56:46 -07001/**
Jeff Thompson7687dc02013-09-13 11:54:07 -07002 * Copyright (C) 2013 Regents of the University of California.
3 * @author: Jeff Thompson <jefft0@remap.ucla.edu>
Jeff Thompsonec39fbd2013-10-04 10:56:23 -07004 * @author: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
5 * @author: Zhenkai Zhu <zhenkai@cs.ucla.edu>
Jeff Thompson47eecfc2013-07-07 22:56:46 -07006 * See COPYING for copyright and distribution information.
Jeff Thompson9c41dfe2013-06-27 12:10:25 -07007 */
8
9#ifndef NDN_NAME_HPP
Jeff Thompson2d27e2f2013-08-09 12:55:00 -070010#define NDN_NAME_HPP
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070011
12#include <vector>
Jeff Thompson443398d2013-07-02 19:45:46 -070013#include <string>
Jeff Thompsonec7789a2013-08-21 11:08:36 -070014#include <sstream>
Jeff Thompson53412192013-08-06 13:35:50 -070015#include "c/name.h"
16#include "encoding/binary-xml-wire-format.hpp"
Jeff Thompson995aba52013-09-12 12:04:52 -070017#include "util/blob.hpp"
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070018
19namespace ndn {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070020
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070021class Name {
22public:
Jeff Thompsonc1c12e42013-09-13 19:08:45 -070023 /**
Jeff Thompson46411c92013-09-13 19:31:25 -070024 * A Name::Component is holds a read-only name component value.
Jeff Thompsonc1c12e42013-09-13 19:08:45 -070025 */
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070026 class Component {
27 public:
28 /**
Jeff Thompson46411c92013-09-13 19:31:25 -070029 * Create a new Name::Component with a null value.
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070030 */
31 Component()
32 {
33 }
34
35 /**
36 * Create a new Name::Component, copying the given value.
37 * @param value The value byte array.
38 */
Jeff Thompson10ad12a2013-09-24 16:19:11 -070039 Component(const std::vector<uint8_t>& value)
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070040 : value_(value)
41 {
42 }
43
44 /**
45 * Create a new Name::Component, copying the given value.
46 * @param value Pointer to the value byte array.
47 * @param valueLen Length of value.
48 */
Jeff Thompson97223af2013-09-24 17:01:27 -070049 Component(const uint8_t *value, size_t valueLen)
Jeff Thompson995aba52013-09-12 12:04:52 -070050 : value_(value, valueLen)
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070051 {
52 }
Jeff Thompson0f743452013-09-12 14:23:18 -070053
54 /**
55 * Create a new Name::Component, taking another pointer to the Blob value.
56 * @param value A blob with a pointer to an immutable array. The pointer is copied.
57 */
58 Component(const Blob &value)
59 : value_(value)
60 {
61 }
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070062
63 /**
64 * Set the componentStruct to point to this component, without copying any memory.
65 * WARNING: The resulting pointer in componentStruct is invalid after a further use of this object which could reallocate memory.
66 * @param componentStruct The C ndn_NameComponent struct to receive the pointer.
67 */
Jeff Thompson0050abe2013-09-17 12:50:25 -070068 void
69 get(struct ndn_NameComponent& componentStruct) const
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070070 {
Jeff Thompson93034532013-10-08 11:52:43 -070071 value_.get(componentStruct.value);
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070072 }
73
Jeff Thompson0050abe2013-09-17 12:50:25 -070074 const Blob&
75 getValue() const { return value_; }
Jeff Thompson6653b0b2013-09-23 12:32:39 -070076
77 /**
78 * Write this component value to result, escaping characters according to the NDN URI Scheme.
79 * This also adds "..." to a value with zero or more ".".
80 * @param value the buffer with the value to escape
81 * @param result the string stream to write to.
82 */
83 void
Jeff Thompsond0159d72013-09-23 13:34:15 -070084 toEscapedString(std::ostringstream& result) const
Jeff Thompson6653b0b2013-09-23 12:32:39 -070085 {
86 Name::toEscapedString(*value_, result);
87 }
88
89 /**
90 * Convert this component value by escaping characters according to the NDN URI Scheme.
91 * This also adds "..." to a value with zero or more ".".
92 * @return The escaped string.
93 */
94 std::string
Jeff Thompsond0159d72013-09-23 13:34:15 -070095 toEscapedString() const
Jeff Thompson6653b0b2013-09-23 12:32:39 -070096 {
97 return Name::toEscapedString(*value_);
98 }
Jeff Thompson9bdb3b22013-09-12 12:42:13 -070099
Jeff Thompson50b37912013-10-08 13:39:33 -0700100 /**
101 * Interpret this name component as a network-ordered number and return an integer.
102 * @return The integer number.
103 */
104 uint64_t
105 toNumber() const
Jeff Thompson27cae532013-10-08 12:52:41 -0700106 {
107 struct ndn_NameComponent componentStruct;
108 get(componentStruct);
109 return ndn_NameComponent_toNumber(&componentStruct);
110 }
111
Jeff Thompson50b37912013-10-08 13:39:33 -0700112 /**
113 * Interpret this name component as a network-ordered number with a marker and return an integer.
114 * @param marker The required first byte of the component.
115 * @return The integer number.
116 * @throw runtime_error If the first byte of the component does not equal the marker.
117 */
118 uint64_t
119 toNumberWithMarker(uint8_t marker) const;
120
121 /**
122 * Interpret this name component as a segment number according to NDN name conventions (a network-ordered number
123 * where the first byte is the marker 0x00).
124 * @return The integer segment number.
125 * @throw runtime_error If the first byte of the component is not the expected marker.
126 */
127 uint64_t
128 toSegment() const
129 {
130 return toNumberWithMarker(0x00);
131 }
132
133 /**
134 * @deprecated Use toSegment.
135 */
136 uint64_t
137 toSeqNum() const
138 {
139 return toSegment();
140 }
141
142 /**
143 * Interpret this name component as a version number according to NDN name conventions (a network-ordered number
144 * where the first byte is the marker 0xFD). Note that this returns the exact number from the component
145 * without converting it to a time representation.
146 * @return The integer segment number.
147 * @throw runtime_error If the first byte of the component is not the expected marker.
148 */
149 uint64_t
150 toVersion() const
151 {
152 return toNumberWithMarker(0xFD);
153 }
Jeff Thompson27cae532013-10-08 12:52:41 -0700154
Jeff Thompsonc1c12e42013-09-13 19:08:45 -0700155 /**
Jeff Thompson46411c92013-09-13 19:31:25 -0700156 * Make a component value by decoding the escapedString between beginOffset and endOffset according to the NDN URI Scheme.
157 * If the escaped string is "", "." or ".." then return a Blob with a null pointer, which means this component value was not changed, and
Jeff Thompsonc1c12e42013-09-13 19:08:45 -0700158 * the component should be skipped in a URI name.
159 * @param escapedString The escaped string. It does not need to be null-terminated because we only scan to endOffset.
160 * @param beginOffset The offset in escapedString of the beginning of the portion to decode.
161 * @param endOffset The offset in escapedString of the end of the portion to decode.
Jeff Thompson46411c92013-09-13 19:31:25 -0700162 * @return The component value as a Blob, or a Blob with a null pointer if escapedString is not a valid escaped component.
Jeff Thompsonc1c12e42013-09-13 19:08:45 -0700163 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700164 static Blob
Jeff Thompson97223af2013-09-24 17:01:27 -0700165 makeFromEscapedString(const char *escapedString, size_t beginOffset, size_t endOffset);
Jeff Thompson8aac1992013-08-12 17:26:02 -0700166
167 /**
Jeff Thompson46411c92013-09-13 19:31:25 -0700168 * Make a component as the encoded segment number.
Jeff Thompson8aac1992013-08-12 17:26:02 -0700169 * @param segment The segment number.
Jeff Thompson46411c92013-09-13 19:31:25 -0700170 * @return The component value as a Blob.
Jeff Thompson8aac1992013-08-12 17:26:02 -0700171 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700172 static Blob
173 makeSegment(unsigned long segment);
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700174
175 private:
Jeff Thompson995aba52013-09-12 12:04:52 -0700176 Blob value_;
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700177 };
178
Jeff Thompson443398d2013-07-02 19:45:46 -0700179 /**
180 * Create a new Name with no components.
181 */
Jeff Thompson016ed642013-07-02 14:39:06 -0700182 Name() {
183 }
Jeff Thompson443398d2013-07-02 19:45:46 -0700184
185 /**
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700186 * Create a new Name, copying the name components.
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700187 * @param components A vector of Component
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700188 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700189 Name(const std::vector<Component>& components)
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700190 : components_(components)
191 {
192 }
193
194 /**
Jeff Thompson443398d2013-07-02 19:45:46 -0700195 * Parse the uri according to the NDN URI Scheme and create the name with the components.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700196 * @param uri The URI string.
Jeff Thompson443398d2013-07-02 19:45:46 -0700197 */
Jeff Thompson3549ef32013-09-25 14:05:17 -0700198 Name(const char* uri)
Jeff Thompson67515bd2013-08-15 17:43:22 -0700199 {
200 set(uri);
201 }
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700202
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700203 /**
Jeff Thompson3549ef32013-09-25 14:05:17 -0700204 * Parse the uri according to the NDN URI Scheme and create the name with the components.
205 * @param uri The URI string.
206 */
207 Name(const std::string& uri)
208 {
209 set(uri.c_str());
210 }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700211
Jeff Thompson3549ef32013-09-25 14:05:17 -0700212 /**
Jeff Thompson016ed642013-07-02 14:39:06 -0700213 * Set the nameStruct to point to the components in this name, without copying any memory.
214 * WARNING: The resulting pointers in nameStruct are invalid after a further use of this object which could reallocate memory.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700215 * @param nameStruct A C ndn_Name struct where the components array is already allocated.
Jeff Thompson016ed642013-07-02 14:39:06 -0700216 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700217 void
218 get(struct ndn_Name& nameStruct) const;
Jeff Thompson016ed642013-07-02 14:39:06 -0700219
220 /**
Jeff Thompson8b27e3a2013-07-03 18:19:53 -0700221 * Clear this name, and set the components by copying from the name struct.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700222 * @param nameStruct A C ndn_Name struct
Jeff Thompsonb468c312013-07-01 17:50:14 -0700223 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700224 void
225 set(const struct ndn_Name& nameStruct);
Jeff Thompsonb468c312013-07-01 17:50:14 -0700226
227 /**
Jeff Thompson67515bd2013-08-15 17:43:22 -0700228 * Parse the uri according to the NDN URI Scheme and set the name with the components.
229 * @param uri The URI string.
230 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700231 void
232 set(const char *uri);
Jeff Thompson67515bd2013-08-15 17:43:22 -0700233
234 /**
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700235 * Append a new component, copying from value of length valueLength.
Jeff Thompson26b0d792013-09-23 16:19:01 -0700236 * @return This name so that you can chain calls to append.
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700237 */
Jeff Thompson26b0d792013-09-23 16:19:01 -0700238 Name&
Jeff Thompson97223af2013-09-24 17:01:27 -0700239 append(const uint8_t *value, size_t valueLength)
Jeff Thompson0f743452013-09-12 14:23:18 -0700240 {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700241 components_.push_back(Component(value, valueLength));
Jeff Thompson26b0d792013-09-23 16:19:01 -0700242 return *this;
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700243 }
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700244
245 /**
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700246 * Append a new component, copying from value.
Jeff Thompson26b0d792013-09-23 16:19:01 -0700247 * @return This name so that you can chain calls to append.
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700248 */
Jeff Thompson26b0d792013-09-23 16:19:01 -0700249 Name&
Jeff Thompson10ad12a2013-09-24 16:19:11 -0700250 append(const std::vector<uint8_t>& value)
Jeff Thompson0f743452013-09-12 14:23:18 -0700251 {
252 components_.push_back(value);
Jeff Thompson26b0d792013-09-23 16:19:01 -0700253 return *this;
Jeff Thompson0f743452013-09-12 14:23:18 -0700254 }
255
Jeff Thompson26b0d792013-09-23 16:19:01 -0700256 Name&
257 append(const Blob &value)
Jeff Thompson0f743452013-09-12 14:23:18 -0700258 {
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700259 components_.push_back(value);
Jeff Thompson26b0d792013-09-23 16:19:01 -0700260 return *this;
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700261 }
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700262
Jeff Thompson21eb7212013-09-26 09:05:40 -0700263 Name&
264 append(const Component &value)
265 {
266 components_.push_back(value);
267 return *this;
268 }
269
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700270 /**
Jeff Thompson26b0d792013-09-23 16:19:01 -0700271 * Append the components of the given name to this name.
272 * @param name The Name with components to append.
273 * @return This name so that you can chain calls to append.
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700274 */
Jeff Thompson26b0d792013-09-23 16:19:01 -0700275 Name&
276 append(const Name& name);
277
278 /**
279 * @deprecated Use append.
280 */
281 Name&
Jeff Thompson97223af2013-09-24 17:01:27 -0700282 appendComponent(const uint8_t *value, size_t valueLength)
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700283 {
Jeff Thompson26b0d792013-09-23 16:19:01 -0700284 return append(value, valueLength);
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700285 }
286
287 /**
Jeff Thompson26b0d792013-09-23 16:19:01 -0700288 * @deprecated Use append.
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700289 */
Jeff Thompson26b0d792013-09-23 16:19:01 -0700290 Name&
Jeff Thompson10ad12a2013-09-24 16:19:11 -0700291 appendComponent(const std::vector<uint8_t>& value)
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700292 {
Jeff Thompson26b0d792013-09-23 16:19:01 -0700293 return append(value);
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700294 }
295
296 /**
Jeff Thompson26b0d792013-09-23 16:19:01 -0700297 * @deprecated Use append.
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700298 */
Jeff Thompson26b0d792013-09-23 16:19:01 -0700299 Name&
300 appendComponent(const Blob &value)
301 {
302 return append(value);
303 }
304
305 /**
306 * @deprecated Use append.
307 */
308 Name&
Jeff Thompson97223af2013-09-24 17:01:27 -0700309 addComponent(const uint8_t *value, size_t valueLength)
Jeff Thompson26b0d792013-09-23 16:19:01 -0700310 {
311 return append(value, valueLength);
312 }
313
314 /**
315 * @deprecated Use append.
316 */
317 Name&
Jeff Thompson10ad12a2013-09-24 16:19:11 -0700318 addComponent(const std::vector<uint8_t>& value)
Jeff Thompson26b0d792013-09-23 16:19:01 -0700319 {
320 return append(value);
321 }
322
323 /**
324 * @deprecated Use append.
325 */
326 Name&
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700327 addComponent(const Blob &value)
328 {
Jeff Thompson26b0d792013-09-23 16:19:01 -0700329 return append(value);
Jeff Thompson0aa66f22013-09-23 13:02:13 -0700330 }
331
332 /**
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700333 * Clear all the components.
334 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700335 void
336 clear() {
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700337 components_.clear();
338 }
339
340 /**
341 * Get the number of components.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700342 * @return The number of components.
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700343 */
Jeff Thompson97223af2013-09-24 17:01:27 -0700344 size_t
Jeff Thompson0050abe2013-09-17 12:50:25 -0700345 getComponentCount() const {
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700346 return components_.size();
347 }
348
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700349 /**
350 * Get the component at the given index.
351 * @param i The index of the component, starting from 0.
352 * @return The name component at the index.
353 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700354 const Component&
Jeff Thompson97223af2013-09-24 17:01:27 -0700355 getComponent(size_t i) const { return components_[i]; }
Jeff Thompson443398d2013-07-02 19:45:46 -0700356
Jeff Thompsone6063512013-07-01 15:11:28 -0700357 /**
Jeff Thompsond0159d72013-09-23 13:34:15 -0700358 * Get a new name, constructed as a subset of components.
359 * @param iStartComponent The index if the first component to get.
360 * @param nComponents The number of components starting at iStartComponent.
361 * @return A new name.
362 */
363 Name
364 getSubName(size_t iStartComponent, size_t nComponents) const;
365
366 /**
367 * Get a new name, constructed as a subset of components starting at iStartComponent until the end of the name.
368 * @param iStartComponent The index if the first component to get.
369 * @return A new name.
370 */
371 Name
372 getSubName(size_t iStartComponent) const;
373
374 /**
375 * Return a new Name with the first nComponents components of this Name.
376 * @param nComponents The number of prefix components.
377 * @return A new Name.
378 */
379 Name
380 getPrefix(size_t nComponents) const
381 {
382 return getSubName(0, nComponents);
383 }
384
385 /**
Jeff Thompsone6063512013-07-01 15:11:28 -0700386 * Encode this name as a URI.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700387 * @return The encoded URI.
Jeff Thompsone6063512013-07-01 15:11:28 -0700388 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700389 std::string
390 toUri() const;
Jeff Thompsone6063512013-07-01 15:11:28 -0700391
Jeff Thompson21844fc2013-08-08 14:52:51 -0700392 /**
393 * @deprecated Use toUri().
394 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700395 std::string
396 to_uri() const
Jeff Thompson21844fc2013-08-08 14:52:51 -0700397 {
398 return toUri();
399 }
Jeff Thompson26b0d792013-09-23 16:19:01 -0700400
Jeff Thompson8aac1992013-08-12 17:26:02 -0700401 /**
402 * Append a component with the encoded segment number.
403 * @param segment The segment number.
Jeff Thompson26b0d792013-09-23 16:19:01 -0700404 * @return This name so that you can chain calls to append.
405 */
406 Name&
Jeff Thompson0050abe2013-09-17 12:50:25 -0700407 appendSegment(unsigned long segment)
Jeff Thompson8aac1992013-08-12 17:26:02 -0700408 {
Jeff Thompson46411c92013-09-13 19:31:25 -0700409 components_.push_back(Component(Component::makeSegment(segment)));
Jeff Thompson26b0d792013-09-23 16:19:01 -0700410 return *this;
Jeff Thompson8aac1992013-08-12 17:26:02 -0700411 }
Jeff Thompsoncc35cd42013-08-20 12:23:14 -0700412
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700413 /**
Jeff Thompson3c2ab012013-10-02 14:18:16 -0700414 * Check if this name has the same component count and components as the given name.
415 * @param name The Name to check.
416 * @return true if the names are equal, otherwise false.
417 */
418 bool
419 equals(const Name& name) const;
420
421 /**
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700422 * Check if the N components of this name are the same as the first N components of the given name.
423 * @param name The Name to check.
424 * @return true if this matches the given name, otherwise false. This always returns true if this name is empty.
425 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700426 bool
427 match(const Name& name) const;
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700428
429 /**
430 * Write the value to result, escaping characters according to the NDN URI Scheme.
431 * This also adds "..." to a value with zero or more ".".
432 * @param value the buffer with the value to escape
433 * @param result the string stream to write to.
434 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700435 static void
Jeff Thompson10ad12a2013-09-24 16:19:11 -0700436 toEscapedString(const std::vector<uint8_t>& value, std::ostringstream& result);
Jeff Thompson21844fc2013-08-08 14:52:51 -0700437
Jeff Thompson6653b0b2013-09-23 12:32:39 -0700438 /**
439 * Convert the value by escaping characters according to the NDN URI Scheme.
440 * This also adds "..." to a value with zero or more ".".
441 * @param value the buffer with the value to escape
442 * @return The escaped string.
443 */
444 static std::string
Jeff Thompson10ad12a2013-09-24 16:19:11 -0700445 toEscapedString(const std::vector<uint8_t>& value);
Jeff Thompson6653b0b2013-09-23 12:32:39 -0700446
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700447 //
448 // vector equivalent interface.
449 //
450
451 /**
452 * Get the number of components.
453 * @return The number of components.
454 */
455 size_t
456 size() const {
457 return getComponentCount();
458 }
459
460 /**
461 * Get the component at the given index.
462 * @param i The index of the component, starting from 0.
463 * @return The name component at the index.
464 */
465 const Component&
466 get(size_t i) const { return getComponent(i); }
467
468
469 const Component&
470 operator [] (int i) const
471 {
472 return get(i);
473 }
474
475 /**
476 * Append the component
477 * @param component The component of type T.
478 */
479 template<class T> void
480 push_back(const T &component)
481 {
482 append(component);
483 }
484
Jeff Thompson91737f52013-10-04 11:07:24 -0700485 /**
486 * Check if this name has the same component count and components as the given name.
487 * @param name The Name to check.
488 * @return true if the names are equal, otherwise false.
489 */
490 bool
491 operator == (const Name &name) const { return equals(name); }
492
493 /**
494 * Check if this name has the same component count and components as the given name.
495 * @param name The Name to check.
496 * @return true if the names are not equal, otherwise false.
497 */
498 bool
499 operator != (const Name &name) const { return !equals(name); }
500
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700501 //
502 // Iterator interface to name components.
503 //
504 typedef std::vector<Component>::iterator iterator;
505 typedef std::vector<Component>::const_iterator const_iterator;
506 typedef std::vector<Component>::reverse_iterator reverse_iterator;
507 typedef std::vector<Component>::const_reverse_iterator const_reverse_iterator;
508 typedef std::vector<Component>::reference reference;
509 typedef std::vector<Component>::const_reference const_reference;
510
511 typedef Component partial_type;
512
513 /**
514 * Begin iterator (const).
515 */
516 const_iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700517 begin() const { return components_.begin(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700518
519 /**
520 * Begin iterator.
521 */
522 iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700523 begin() { return components_.begin(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700524
525 /**
526 * End iterator (const).
527 */
528 const_iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700529 end() const { return components_.end(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700530
531 /**
532 * End iterator.
533 */
534 iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700535 end() { return components_.end(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700536
537 /**
538 * Reverse begin iterator (const).
539 */
540 const_reverse_iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700541 rbegin() const { return components_.rbegin(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700542
543 /**
544 * Reverse begin iterator.
545 */
546 reverse_iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700547 rbegin() { return components_.rbegin(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700548
549 /**
550 * Reverse end iterator (const).
551 */
552 const_reverse_iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700553 rend() const { return components_.rend(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700554
555 /**
556 * Reverse end iterator.
557 */
558 reverse_iterator
Jeff Thompson91737f52013-10-04 11:07:24 -0700559 rend() { return components_.rend(); }
Jeff Thompsonec39fbd2013-10-04 10:56:23 -0700560
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700561private:
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700562 std::vector<Component> components_;
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700563};
564
Jeff Thompson49e321a2013-10-04 17:35:59 -0700565inline std::ostream&
566operator << (std::ostream& os, const Name& name)
567{
568 os << name.toUri();
569 return os;
570}
571
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700572}
573
574#endif
575