| /** |
| * Copyright (C) 2013 Regents of the University of California. |
| * @author: Jeff Thompson <jefft0@remap.ucla.edu> |
| * See COPYING for copyright and distribution information. |
| */ |
| |
| #ifndef NDN_NAME_H |
| #define NDN_NAME_H |
| |
| #include "errors.h" |
| #include "util/blob.h" |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| /** |
| * An ndn_NameComponent holds a pointer to the component value. |
| */ |
| struct ndn_NameComponent { |
| struct ndn_Blob value; /**< A Blob with a pointer to the pre-allocated buffer for the component value */ |
| }; |
| |
| /** |
| * |
| * @param self pointer to the ndn_NameComponent struct |
| * @param value the pre-allocated buffer for the component value |
| * @param valueLength the number of bytes in value |
| */ |
| static inline void ndn_NameComponent_initialize(struct ndn_NameComponent *self, uint8_t *value, size_t valueLength) |
| { |
| ndn_Blob_initialize(&self->value, value, valueLength); |
| } |
| |
| /** |
| /** |
| * Interpret the name component as a network-ordered number and return an integer. |
| * @param self A pointer to the ndn_NameComponent struct. |
| * @return The integer number. |
| */ |
| uint64_t ndn_NameComponent_toNumber(struct ndn_NameComponent *self); |
| |
| /** |
| * Convert binary blob name component (network-ordered number) to number, using appropriate marker from the naming convention |
| * @param comp name component to be converted |
| * @param marker required marker from the naming convention |
| * |
| * If the required marker does not exist, an exception will be thrown |
| */ |
| |
| /** |
| * Interpret the name component as a network-ordered number with a marker and return an integer. |
| * @param self A pointer to the ndn_NameComponent struct. |
| * @param marker The required first byte of the component. |
| * @param result Return the integer number. |
| * @return 0 for success, or an error code if the first byte of the component does not equal the marker. |
| */ |
| ndn_Error ndn_NameComponent_toNumberWithMarker(struct ndn_NameComponent *self, uint8_t marker, uint64_t *result); |
| |
| /** |
| * An ndn_Name holds an array of ndn_NameComponent. |
| */ |
| struct ndn_Name { |
| struct ndn_NameComponent *components; /**< pointer to the array of components. */ |
| size_t maxComponents; /**< the number of elements in the allocated components array */ |
| size_t nComponents; /**< the number of components in the name */ |
| }; |
| |
| /** |
| * Initialize an ndn_Name struct with the components array. |
| * @param self pointer to the ndn_Name struct |
| * @param components the pre-allocated array of ndn_NameComponent |
| * @param maxComponents the number of elements in the allocated components array |
| */ |
| static inline void ndn_Name_initialize(struct ndn_Name *self, struct ndn_NameComponent *components, size_t maxComponents) |
| { |
| self->components = components; |
| self->maxComponents = maxComponents; |
| self->nComponents = 0; |
| } |
| |
| /** |
| * Return true if the N components of this name are the same as the first N components of the given name. |
| * @param self A pointer to the ndn_Name struct. |
| * @param name A pointer to the other name to match. |
| * @return 1 if this matches the given name, 0 otherwise. This always returns 1 if this name is empty. |
| */ |
| int ndn_Name_match(struct ndn_Name *self, struct ndn_Name *name); |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif |
| |