blob: cd80fac349608b350bc9e33be2647abfb63e837e [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 Thompson47eecfc2013-07-07 22:56:46 -07004 * See COPYING for copyright and distribution information.
Jeff Thompson9c41dfe2013-06-27 12:10:25 -07005 */
6
7#ifndef NDN_NAME_HPP
Jeff Thompson2d27e2f2013-08-09 12:55:00 -07008#define NDN_NAME_HPP
Jeff Thompson9c41dfe2013-06-27 12:10:25 -07009
10#include <vector>
Jeff Thompson443398d2013-07-02 19:45:46 -070011#include <string>
Jeff Thompsonec7789a2013-08-21 11:08:36 -070012#include <sstream>
Jeff Thompson53412192013-08-06 13:35:50 -070013#include "c/name.h"
14#include "encoding/binary-xml-wire-format.hpp"
Jeff Thompson995aba52013-09-12 12:04:52 -070015#include "util/blob.hpp"
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070016
17namespace ndn {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070018
Jeff Thompson9c41dfe2013-06-27 12:10:25 -070019class Name {
20public:
Jeff Thompsonc1c12e42013-09-13 19:08:45 -070021 /**
Jeff Thompson46411c92013-09-13 19:31:25 -070022 * A Name::Component is holds a read-only name component value.
Jeff Thompsonc1c12e42013-09-13 19:08:45 -070023 */
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070024 class Component {
25 public:
26 /**
Jeff Thompson46411c92013-09-13 19:31:25 -070027 * Create a new Name::Component with a null value.
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070028 */
29 Component()
30 {
31 }
32
33 /**
34 * Create a new Name::Component, copying the given value.
35 * @param value The value byte array.
36 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -070037 Component(const std::vector<unsigned char>& value)
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070038 : value_(value)
39 {
40 }
41
42 /**
43 * Create a new Name::Component, copying the given value.
44 * @param value Pointer to the value byte array.
45 * @param valueLen Length of value.
46 */
Jeff Thompsona166b732013-08-27 16:09:29 -070047 Component(const unsigned char *value, unsigned int valueLen)
Jeff Thompson995aba52013-09-12 12:04:52 -070048 : value_(value, valueLen)
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070049 {
50 }
Jeff Thompson0f743452013-09-12 14:23:18 -070051
52 /**
53 * Create a new Name::Component, taking another pointer to the Blob value.
54 * @param value A blob with a pointer to an immutable array. The pointer is copied.
55 */
56 Component(const Blob &value)
57 : value_(value)
58 {
59 }
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070060
61 /**
62 * Set the componentStruct to point to this component, without copying any memory.
63 * WARNING: The resulting pointer in componentStruct is invalid after a further use of this object which could reallocate memory.
64 * @param componentStruct The C ndn_NameComponent struct to receive the pointer.
65 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -070066 void get(struct ndn_NameComponent& componentStruct) const
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070067 {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070068 componentStruct.valueLength = value_.size();
Jeff Thompson38d0e082013-08-12 18:07:44 -070069 if (value_.size() > 0)
Jeff Thompson995aba52013-09-12 12:04:52 -070070 componentStruct.value = (unsigned char*)value_.buf();
Jeff Thompson05c8c1b2013-09-12 12:47:57 -070071 else
72 componentStruct.value = 0;
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070073 }
74
Jeff Thompson9bdb3b22013-09-12 12:42:13 -070075 const Blob& getValue() const { return value_; }
76
Jeff Thompsonc1c12e42013-09-13 19:08:45 -070077 /**
Jeff Thompson46411c92013-09-13 19:31:25 -070078 * Make a component value by decoding the escapedString between beginOffset and endOffset according to the NDN URI Scheme.
79 * 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 -070080 * the component should be skipped in a URI name.
81 * @param escapedString The escaped string. It does not need to be null-terminated because we only scan to endOffset.
82 * @param beginOffset The offset in escapedString of the beginning of the portion to decode.
83 * @param endOffset The offset in escapedString of the end of the portion to decode.
Jeff Thompson46411c92013-09-13 19:31:25 -070084 * @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 -070085 */
Jeff Thompson46411c92013-09-13 19:31:25 -070086 static Blob makeFromEscapedString(const char *escapedString, unsigned int beginOffset, unsigned int endOffset);
Jeff Thompson8aac1992013-08-12 17:26:02 -070087
88 /**
Jeff Thompson46411c92013-09-13 19:31:25 -070089 * Make a component as the encoded segment number.
Jeff Thompson8aac1992013-08-12 17:26:02 -070090 * @param segment The segment number.
Jeff Thompson46411c92013-09-13 19:31:25 -070091 * @return The component value as a Blob.
Jeff Thompson8aac1992013-08-12 17:26:02 -070092 */
Jeff Thompson46411c92013-09-13 19:31:25 -070093 static Blob makeSegment(unsigned long segment);
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070094
95 private:
Jeff Thompson995aba52013-09-12 12:04:52 -070096 Blob value_;
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -070097 };
98
Jeff Thompson443398d2013-07-02 19:45:46 -070099 /**
100 * Create a new Name with no components.
101 */
Jeff Thompson016ed642013-07-02 14:39:06 -0700102 Name() {
103 }
Jeff Thompson443398d2013-07-02 19:45:46 -0700104
105 /**
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700106 * Create a new Name, copying the name components.
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700107 * @param components A vector of Component
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700108 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700109 Name(const std::vector<Component>& components)
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700110 : components_(components)
111 {
112 }
113
114 /**
Jeff Thompson443398d2013-07-02 19:45:46 -0700115 * Parse the uri according to the NDN URI Scheme and create the name with the components.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700116 * @param uri The URI string.
Jeff Thompson443398d2013-07-02 19:45:46 -0700117 */
Jeff Thompson67515bd2013-08-15 17:43:22 -0700118 Name(const char *uri)
119 {
120 set(uri);
121 }
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700122
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700123 /**
Jeff Thompson016ed642013-07-02 14:39:06 -0700124 * Set the nameStruct to point to the components in this name, without copying any memory.
125 * 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 -0700126 * @param nameStruct A C ndn_Name struct where the components array is already allocated.
Jeff Thompson016ed642013-07-02 14:39:06 -0700127 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700128 void get(struct ndn_Name& nameStruct) const;
Jeff Thompson016ed642013-07-02 14:39:06 -0700129
130 /**
Jeff Thompson8b27e3a2013-07-03 18:19:53 -0700131 * Clear this name, and set the components by copying from the name struct.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700132 * @param nameStruct A C ndn_Name struct
Jeff Thompsonb468c312013-07-01 17:50:14 -0700133 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700134 void set(const struct ndn_Name& nameStruct);
Jeff Thompsonb468c312013-07-01 17:50:14 -0700135
136 /**
Jeff Thompson67515bd2013-08-15 17:43:22 -0700137 * Parse the uri according to the NDN URI Scheme and set the name with the components.
138 * @param uri The URI string.
139 */
140 void set(const char *uri);
141
142 /**
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700143 * Add a new component, copying from value of length valueLength.
144 */
Jeff Thompson0f743452013-09-12 14:23:18 -0700145 void addComponent(const unsigned char *value, unsigned int valueLength)
146 {
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700147 components_.push_back(Component(value, valueLength));
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700148 }
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700149
150 /**
151 * Add a new component, copying from value.
152 */
Jeff Thompson0f743452013-09-12 14:23:18 -0700153 void addComponent(const std::vector<unsigned char>& value)
154 {
155 components_.push_back(value);
156 }
157
158 void addComponent(const Blob &value)
159 {
Jeff Thompsonf72b1ac2013-08-16 16:44:41 -0700160 components_.push_back(value);
161 }
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700162
163 /**
164 * Clear all the components.
165 */
166 void clear() {
167 components_.clear();
168 }
169
170 /**
171 * Get the number of components.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700172 * @return The number of components.
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700173 */
Jeff Thompsond345a5b2013-07-08 16:18:23 -0700174 unsigned int getComponentCount() const {
Jeff Thompsone5f839b2013-06-28 12:50:38 -0700175 return components_.size();
176 }
177
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700178 const Component& getComponent(unsigned int i) const { return components_[i]; }
Jeff Thompson443398d2013-07-02 19:45:46 -0700179
Jeff Thompsone6063512013-07-01 15:11:28 -0700180 /**
181 * Encode this name as a URI.
Jeff Thompson3f2175b2013-07-31 17:12:47 -0700182 * @return The encoded URI.
Jeff Thompsone6063512013-07-01 15:11:28 -0700183 */
Jeff Thompson21844fc2013-08-08 14:52:51 -0700184 std::string toUri() const;
Jeff Thompsone6063512013-07-01 15:11:28 -0700185
Jeff Thompson21844fc2013-08-08 14:52:51 -0700186 /**
187 * @deprecated Use toUri().
188 */
189 std::string to_uri() const
190 {
191 return toUri();
192 }
Jeff Thompson8aac1992013-08-12 17:26:02 -0700193
194 /**
195 * Append a component with the encoded segment number.
196 * @param segment The segment number.
197 */
198 void appendSegment(unsigned long segment)
199 {
Jeff Thompson46411c92013-09-13 19:31:25 -0700200 components_.push_back(Component(Component::makeSegment(segment)));
Jeff Thompson8aac1992013-08-12 17:26:02 -0700201 }
Jeff Thompsoncc35cd42013-08-20 12:23:14 -0700202
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700203 /**
204 * Check if the N components of this name are the same as the first N components of the given name.
205 * @param name The Name to check.
206 * @return true if this matches the given name, otherwise false. This always returns true if this name is empty.
207 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700208 bool match(const Name& name) const;
Jeff Thompsonec7789a2013-08-21 11:08:36 -0700209
210 /**
211 * Write the value to result, escaping characters according to the NDN URI Scheme.
212 * This also adds "..." to a value with zero or more ".".
213 * @param value the buffer with the value to escape
214 * @param result the string stream to write to.
215 */
Jeff Thompson1656e6a2013-08-29 18:01:48 -0700216 static void toEscapedString(const std::vector<unsigned char>& value, std::ostringstream& result);
Jeff Thompson21844fc2013-08-08 14:52:51 -0700217
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700218private:
Jeff Thompson5a6b5ab2013-08-05 15:43:47 -0700219 std::vector<Component> components_;
Jeff Thompson9c41dfe2013-06-27 12:10:25 -0700220};
221
222}
223
224#endif
225