libyang  2.0.7
libyang is YANG data modelling language parser and toolkit written (and providing API) in C.
set.h
Go to the documentation of this file.
1 
15 #ifndef LY_SET_H_
16 #define LY_SET_H_
17 
18 #include <stdint.h>
19 
20 #include "log.h"
21 
22 #ifdef __cplusplus
23 extern "C" {
24 #endif
25 
46 struct ly_set
47 {
48  uint32_t size;
49  uint32_t count;
50  union {
51  struct lyd_node **dnodes;
52  struct lysc_node **snodes;
53  void **objs;
54  };
55 };
56 
65 LY_ERR ly_set_new(struct ly_set **set_p);
66 
79 LY_ERR ly_set_dup(const struct ly_set *set, void *(*duplicator)(void *obj), struct ly_set **newset_p);
80 
94 LY_ERR ly_set_add(struct ly_set *set, void *object, ly_bool list, uint32_t *index_p);
95 
111 LY_ERR ly_set_merge(struct ly_set *trg, const struct ly_set *src, ly_bool list, void *(*duplicator)(void *obj));
112 
121 ly_bool ly_set_contains(const struct ly_set *set, void *object, uint32_t *index_p);
122 
129 void ly_set_clean(struct ly_set *set, void (*destructor)(void *obj));
130 
142 LY_ERR ly_set_rm(struct ly_set *set, void *object, void (*destructor)(void *obj));
143 
155 LY_ERR ly_set_rm_index(struct ly_set *set, uint32_t index, void (*destructor)(void *obj));
156 
164 void ly_set_free(struct ly_set *set, void (*destructor)(void *obj));
165 
173 void ly_set_erase(struct ly_set *set, void (*destructor)(void *obj));
174 
177 #ifdef __cplusplus
178 }
179 #endif
180 
181 #endif /* LY_SET_H_ */
LY_ERR
libyang's error codes returned by the libyang functions.
Definition: log.h:242
uint32_t count
Definition: set.h:49
uint32_t size
Definition: set.h:48
LY_ERR ly_set_new(struct ly_set **set_p)
Create and initiate new ly_set structure.
LY_ERR ly_set_add(struct ly_set *set, void *object, ly_bool list, uint32_t *index_p)
Add an object into the set.
void ly_set_free(struct ly_set *set, void(*destructor)(void *obj))
Free the ly_set data. If the destructor is not provided, it frees only the set structure content,...
ly_bool ly_set_contains(const struct ly_set *set, void *object, uint32_t *index_p)
Learn whether the set contains the specified object.
void ly_set_erase(struct ly_set *set, void(*destructor)(void *obj))
Alternative to the ly_set_free() for static ly_set objects - in contrast to ly_set_free() it does not...
LY_ERR ly_set_rm(struct ly_set *set, void *object, void(*destructor)(void *obj))
Remove an object from the set.
void ly_set_clean(struct ly_set *set, void(*destructor)(void *obj))
Remove all objects from the set, but keep the set container for further use.
LY_ERR ly_set_dup(const struct ly_set *set, void *(*duplicator)(void *obj), struct ly_set **newset_p)
Duplicate the existing set.
LY_ERR ly_set_rm_index(struct ly_set *set, uint32_t index, void(*destructor)(void *obj))
Remove an object on the specific set index.
LY_ERR ly_set_merge(struct ly_set *trg, const struct ly_set *src, ly_bool list, void *(*duplicator)(void *obj))
Add all objects from src to trg.
Structure to hold a set of (not necessary somehow connected) objects. Usually used for lyd_node,...
Definition: set.h:47
Compiled YANG data node.
Definition: tree_schema.h:1644
Logger manipulation routines and error definitions.
uint8_t ly_bool
Type to indicate boolean value.
Definition: log.h:25
Generic structure for a data node.
Definition: tree_data.h:754