blob: ade193a6ca8b2118a859e3ce8f5558eddb183bd2 [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 Thompson5d89cb92013-06-27 15:57:15 -07005 */
6
7#ifndef NDN_NAME_H
Jeff Thompson2d27e2f2013-08-09 12:55:00 -07008#define NDN_NAME_H
Jeff Thompson5d89cb92013-06-27 15:57:15 -07009
Jeff Thompson2d27e2f2013-08-09 12:55:00 -070010#ifdef __cplusplus
Jeff Thompson5d89cb92013-06-27 15:57:15 -070011extern "C" {
12#endif
13
Jeff Thompson2934a5b2013-07-03 17:45:53 -070014/**
15 * An ndn_NameComponent holds a pointer to the component value.
16 */
Jeff Thompsonb0fd64f2013-06-27 16:02:36 -070017struct ndn_NameComponent {
Jeff Thompson2934a5b2013-07-03 17:45:53 -070018 unsigned char *value; /**< pointer to the pre-allocated buffer for the component value */
Jeff Thompson08d56292013-06-27 18:20:44 -070019 unsigned int valueLength; /**< the number of bytes in value */
Jeff Thompson5d89cb92013-06-27 15:57:15 -070020};
21
Jeff Thompson2934a5b2013-07-03 17:45:53 -070022/**
23 *
24 * @param self pointer to the ndn_NameComponent struct
25 * @param value the pre-allocated buffer for the component value
26 * @param valueLength the number of bytes in value
27 */
Jeff Thompsond1427fb2013-08-29 17:20:32 -070028static inline void ndn_NameComponent_initialize(struct ndn_NameComponent *self, unsigned char *value, unsigned int valueLength)
Jeff Thompsonb0fd64f2013-06-27 16:02:36 -070029{
30 self->value = value;
31 self->valueLength = valueLength;
32}
Jeff Thompson5d89cb92013-06-27 15:57:15 -070033
Jeff Thompson2934a5b2013-07-03 17:45:53 -070034/**
35 * An ndn_Name holds an array of ndn_NameComponent.
36 */
Jeff Thompson5d89cb92013-06-27 15:57:15 -070037struct ndn_Name {
Jeff Thompson08d56292013-06-27 18:20:44 -070038 struct ndn_NameComponent *components; /**< pointer to the array of components. */
39 unsigned int maxComponents; /**< the number of elements in the allocated components array */
40 unsigned int nComponents; /**< the number of components in the name */
Jeff Thompson5d89cb92013-06-27 15:57:15 -070041};
42
Jeff Thompson08d56292013-06-27 18:20:44 -070043/**
44 * Initialize an ndn_Name struct with the components array.
45 * @param self pointer to the ndn_Name struct
Jeff Thompson2934a5b2013-07-03 17:45:53 -070046 * @param components the pre-allocated array of ndn_NameComponent
Jeff Thompson08d56292013-06-27 18:20:44 -070047 * @param maxComponents the number of elements in the allocated components array
48 */
Jeff Thompsond1427fb2013-08-29 17:20:32 -070049static inline void ndn_Name_initialize(struct ndn_Name *self, struct ndn_NameComponent *components, unsigned int maxComponents)
Jeff Thompsonb0fd64f2013-06-27 16:02:36 -070050{
Jeff Thompson08d56292013-06-27 18:20:44 -070051 self->components = components;
52 self->maxComponents = maxComponents;
Jeff Thompsonb0fd64f2013-06-27 16:02:36 -070053 self->nComponents = 0;
54}
Jeff Thompson5d89cb92013-06-27 15:57:15 -070055
Jeff Thompsonf1ba9bd2013-08-12 17:43:08 -070056/**
57 * Return true if the N components of this name are the same as the first N components of the given name.
58 * @param self A pointer to the ndn_Name struct.
59 * @param name A pointer to the other name to match.
60 * @return 1 if this matches the given name, 0 otherwise. This always returns 1 if this name is empty.
61 */
62int ndn_Name_match(struct ndn_Name *self, struct ndn_Name *name);
63
Jeff Thompson2d27e2f2013-08-09 12:55:00 -070064#ifdef __cplusplus
Jeff Thompson5d89cb92013-06-27 15:57:15 -070065}
66#endif
67
Jeff Thompson08d56292013-06-27 18:20:44 -070068#endif
Jeff Thompson5d89cb92013-06-27 15:57:15 -070069