blob: 5657efa608963b3f66c5720ca78340ec58961481 [file] [log] [blame]
Jeff Thompson47eecfc2013-07-07 22:56:46 -07001/**
2 * @author: Jeff Thompson
3 * See COPYING for copyright and distribution information.
Jeff Thompson9c41dfe2013-06-27 12:10:25 -07004 */
5
6#ifndef NDN_NAME_HPP
Jeff Thompson2d27e2f2013-08-09 12:55:00 -07007#define NDN_NAME_HPP
Jeff Thompson9c41dfe2013-06-27 12:10:25 -07008
9#include <vector>
Jeff Thompson443398d2013-07-02 19:45:46 -070010#include <string>
Jeff Thompsonec7789a2013-08-21 11:08:36 -070011#include <sstream>
Jeff Thompson53412192013-08-06 13:35:50 -070012#include "c/name.h"
13#include "encoding/binary-xml-wire-format.hpp"
Jeff Thompson995aba52013-09-12 12:04:52 -070014#include "util/blob.hpp"
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070015
16namespace ndn {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070017
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070018class Name {
19public:
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070020 class Component {
21 public:
22 /**
23 * Create a new Name::Component with an empty value.
24 */
25 Component()
26 {
27 }
28
29 /**
30 * Create a new Name::Component, copying the given value.
31 * @param value The value byte array.
32 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -070033 Component(const std::vector<unsigned char>& value)
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070034 : value_(value)
35 {
36 }
37
38 /**
39 * Create a new Name::Component, copying the given value.
40 * @param value Pointer to the value byte array.
41 * @param valueLen Length of value.
42 */
Jeff Thompsona166b732013-08-27 16:09:29 -070043 Component(const unsigned char *value, unsigned int valueLen)
Jeff Thompson995aba52013-09-12 12:04:52 -070044 : value_(value, valueLen)
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070045 {
46 }
Jeff Thompson0f743452013-09-12 14:23:18 -070047
48 /**
49 * Create a new Name::Component, taking another pointer to the Blob value.
50 * @param value A blob with a pointer to an immutable array. The pointer is copied.
51 */
52 Component(const Blob &value)
53 : value_(value)
54 {
55 }
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070056
57 /**
58 * Set the componentStruct to point to this component, without copying any memory.
59 * WARNING: The resulting pointer in componentStruct is invalid after a further use of this object which could reallocate memory.
60 * @param componentStruct The C ndn_NameComponent struct to receive the pointer.
61 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -070062 void get(struct ndn_NameComponent& componentStruct) const
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070063 {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070064 componentStruct.valueLength = value_.size();
Jeff Thompson38d0e082013-08-12 18:07:44 -070065 if (value_.size() > 0)
Jeff Thompson995aba52013-09-12 12:04:52 -070066 componentStruct.value = (unsigned char*)value_.buf();
Jeff Thompson05c8c1b2013-09-12 12:47:57 -070067 else
68 componentStruct.value = 0;
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070069 }
70
71 /**
72 * Set this component value by decoding the escapedString between first and last according to the NDN URI Scheme.
73 * If the escaped string is "", "." or ".." then return false, which means this component value was not changed, and
74 * the component should be skipped in a URI name.
75 * @param first Pointer to the beginning of the escaped string
76 * @param last Pointer to the first character past the end of the escaped string
77 * @return True for success, false if escapedString is not a valid escaped component.
78 */
79 bool setFromEscapedString(const char *first, const char *last);
80
Jeff Thompson9bdb3b22013-09-12 12:42:13 -070081 const Blob& getValue() const { return value_; }
82
83 void setValue(const Blob& value) { value_ = value; }
Jeff Thompson8aac1992013-08-12 17:26:02 -070084
85 /**
86 * Set this component to the encoded segment number.
87 * @param segment The segment number.
88 */
89 void setSegment(unsigned long segment);
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070090
91 private:
Jeff Thompson995aba52013-09-12 12:04:52 -070092 Blob value_;
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070093 };
94
Jeff Thompson443398d2013-07-02 19:45:46 -070095 /**
96 * Create a new Name with no components.
97 */
Jeff Thompson016ed642013-07-02 14:39:06 -070098 Name() {
99 }
Jeff Thompson443398d2013-07-02 19:45:46 -0700100
101 /**
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700102 * Create a new Name, copying the name components.
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700103 * @param components A vector of Component
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700104 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700105 Name(const std::vector<Component>& components)
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700106 : components_(components)
107 {
108 }
109
110 /**
Jeff Thompson443398d2013-07-02 19:45:46 -0700111 * Parse the uri according to the NDN URI Scheme and create the name with the components.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700112 * @param uri The URI string.
Jeff Thompson443398d2013-07-02 19:45:46 -0700113 */
Jeff Thompson67515bd2013-08-15 17:43:22 -0700114 Name(const char *uri)
115 {
116 set(uri);
117 }
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700118
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700119 /**
Jeff Thompson016ed642013-07-02 14:39:06 -0700120 * Set the nameStruct to point to the components in this name, without copying any memory.
121 * 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 -0700122 * @param nameStruct A C ndn_Name struct where the components array is already allocated.
Jeff Thompson016ed642013-07-02 14:39:06 -0700123 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700124 void get(struct ndn_Name& nameStruct) const;
Jeff Thompson016ed642013-07-02 14:39:06 -0700125
126 /**
Jeff Thompson8b27e3a2013-07-03 18:19:53 -0700127 * Clear this name, and set the components by copying from the name struct.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700128 * @param nameStruct A C ndn_Name struct
Jeff Thompsonb468c312013-07-01 17:50:14 -0700129 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700130 void set(const struct ndn_Name& nameStruct);
Jeff Thompsonb468c312013-07-01 17:50:14 -0700131
132 /**
Jeff Thompson67515bd2013-08-15 17:43:22 -0700133 * Parse the uri according to the NDN URI Scheme and set the name with the components.
134 * @param uri The URI string.
135 */
136 void set(const char *uri);
137
138 /**
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700139 * Add a new component, copying from value of length valueLength.
140 */
Jeff Thompson0f743452013-09-12 14:23:18 -0700141 void addComponent(const unsigned char *value, unsigned int valueLength)
142 {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700143 components_.push_back(Component(value, valueLength));
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700144 }
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700145
146 /**
147 * Add a new component, copying from value.
148 */
Jeff Thompson0f743452013-09-12 14:23:18 -0700149 void addComponent(const std::vector<unsigned char>& value)
150 {
151 components_.push_back(value);
152 }
153
154 void addComponent(const Blob &value)
155 {
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700156 components_.push_back(value);
157 }
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700158
159 /**
160 * Clear all the components.
161 */
162 void clear() {
163 components_.clear();
164 }
165
166 /**
167 * Get the number of components.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700168 * @return The number of components.
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700169 */
Jeff Thompsond345a5b2013-07-08 16:18:23 -0700170 unsigned int getComponentCount() const {
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700171 return components_.size();
172 }
173
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700174 const Component& getComponent(unsigned int i) const { return components_[i]; }
Jeff Thompson443398d2013-07-02 19:45:46 -0700175
Jeff Thompsone6063512013-07-01 15:11:28 -0700176 /**
177 * Encode this name as a URI.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700178 * @return The encoded URI.
Jeff Thompsone6063512013-07-01 15:11:28 -0700179 */
Jeff Thompson21844fc2013-08-08 14:52:51 -0700180 std::string toUri() const;
Jeff Thompsone6063512013-07-01 15:11:28 -0700181
Jeff Thompson21844fc2013-08-08 14:52:51 -0700182 /**
183 * @deprecated Use toUri().
184 */
185 std::string to_uri() const
186 {
187 return toUri();
188 }
Jeff Thompson8aac1992013-08-12 17:26:02 -0700189
190 /**
191 * Append a component with the encoded segment number.
192 * @param segment The segment number.
193 */
194 void appendSegment(unsigned long segment)
195 {
196 components_.push_back(Component());
197 components_.back().setSegment(segment);
198 }
Jeff Thompsoncc35cd42013-08-20 12:23:14 -0700199
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700200 /**
201 * Check if the N components of this name are the same as the first N components of the given name.
202 * @param name The Name to check.
203 * @return true if this matches the given name, otherwise false. This always returns true if this name is empty.
204 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700205 bool match(const Name& name) const;
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700206
207 /**
208 * Write the value to result, escaping characters according to the NDN URI Scheme.
209 * This also adds "..." to a value with zero or more ".".
210 * @param value the buffer with the value to escape
211 * @param result the string stream to write to.
212 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700213 static void toEscapedString(const std::vector<unsigned char>& value, std::ostringstream& result);
Jeff Thompson21844fc2013-08-08 14:52:51 -0700214
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700215private:
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700216 std::vector<Component> components_;
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700217};
218
219}
220
221#endif
222