74 uint32_t obj_type = GET_UINT32(object_data,
"type_id");
75 amxc_var_t* attrs = GET_ARG(object_data,
"attributes");
77 if(GET_BOOL(attrs,
"read-only")) {
82 amxc_var_add_key(uint32_t, retval,
"access", access);
88 amxc_var_t* attrs = GET_ARG(param_data,
"attributes");
89 amxc_var_t* name = GET_ARG(param_data,
"name");
90 uint32_t param_type = GET_UINT32(param_data,
"type_id");
92 amxc_var_set_key(retval,
"param_name", name, AMXC_VAR_FLAG_DEFAULT);
93 if(GET_BOOL(attrs,
"read-only") || (GET_BOOL(attrs,
"key") && !GET_BOOL(attrs,
"mutable"))) {
94 amxc_var_add_key(uint32_t, retval,
"access", 0);
96 amxc_var_add_key(uint32_t, retval,
"access", 1);
98 amxc_var_add_key(uint32_t, retval,
"type", param_type);
99 amxc_var_add_key(uint32_t, retval,
"value_change", GET_BOOL(attrs,
"volatile")? 2:1);
101 amxc_var_delete(&attrs);
105 amxc_var_t* retval) {
106 amxc_string_t* name = amxc_var_take(amxc_string_t, GET_ARG(func_data,
"name"));
107 amxc_var_t* args = GET_ARG(func_data,
"arguments");
108 amxc_var_t* out_args = NULL;
109 amxc_var_t* in_args = NULL;
111 amxc_string_append(name,
"()", 2);
112 amxc_var_add_key(uint32_t, retval,
"command_type",
113 GETP_BOOL(func_data,
"attributes.asynchronous")? 2:1);
114 amxc_var_add_key(cstring_t, retval,
"command_name", amxc_string_get(name, 0));
115 out_args = amxc_var_add_key(amxc_llist_t, retval,
"output_arg_names", NULL);
116 in_args = amxc_var_add_key(amxc_llist_t, retval,
"input_arg_names", NULL);
117 amxc_var_for_each(arg, args) {
118 amxc_var_t* arg_attrs = GET_ARG(arg,
"attributes");
119 if(GET_BOOL(arg_attrs,
"out")) {
120 amxc_var_add(cstring_t, out_args, GET_CHAR(arg,
"name"));
122 if(GET_BOOL(arg_attrs,
"in")) {
123 amxc_var_add(cstring_t, in_args, GET_CHAR(arg,
"name"));
126 amxc_string_delete(&name);
133 amxc_var_t object_data;
135 amxc_var_init(&object_data);
150 const amxc_var_t* params = GET_ARG(&object_data,
"parameters");
151 amxc_var_t* usp_params
152 = amxc_var_add_key(amxc_llist_t, data,
"supported_params", NULL);
153 amxc_var_for_each(param, params) {
154 amxc_var_t* usp_param = amxc_var_add(amxc_htable_t, usp_params, NULL);
160 const amxc_var_t* funcs = GET_ARG(&object_data,
"functions");
161 amxc_var_t* usp_funcs
162 = amxc_var_add_key(amxc_llist_t, data,
"supported_commands", NULL);
163 amxc_var_for_each(func, funcs) {
164 amxc_var_t* usp_func = amxc_var_add(amxc_htable_t, usp_funcs, NULL);
170 const amxc_var_t* events = GET_ARG(&object_data,
"events");
171 amxc_var_t* usp_events
172 = amxc_var_add_key(amxc_llist_t, data,
"supported_events", NULL);
173 amxc_var_copy(usp_events, events);
176 amxc_var_clean(&object_data);
180 UNUSED int32_t depth,
204 amxc_var_t* data = amxc_var_add_key(amxc_htable_t, sup->
ret, sup_path, NULL);
218 amxc_var_set_type(sup->
ret, AMXC_VAR_ID_HTABLE);
236 amxc_var_t* var_rel_path = GET_ARG(args,
"rel_path");
237 const char* rel_path = GET_CHAR(var_rel_path, NULL);
240 sup.
functions = GET_BOOL(args,
"functions");
241 sup.
params = GET_BOOL(args,
"parameters");
242 sup.
events = GET_BOOL(args,
"events");
243 sup.
first_lvl = GET_BOOL(args,
"first_level_only");
247 amxc_var_take_it(var_rel_path);
248 if((rel_path != NULL) && (*rel_path != 0)) {
250 char* obj_path = NULL;
254 if(obj_path != NULL) {
261 char* obj_path = NULL;
272 amxc_var_delete(&var_rel_path);
Ambiorix Data Model API header file.
amxd_object_t * amxd_dm_findf(amxd_dm_t *const dm, const char *abs_path,...) __attribute__((format(printf
amxd_status_t amxd_object_func_get_supported(amxd_object_t *object, UNUSED amxd_function_t *func, amxc_var_t *args, amxc_var_t *ret)
static void amxd_describe_param_usp(amxc_var_t *param_data, amxc_var_t *retval)
static bool amxd_get_supported_filter(amxd_object_t *const object, UNUSED int32_t depth, UNUSED void *priv)
static void amxd_describe_func_usp(amxc_var_t *func_data, amxc_var_t *retval)
static void amxd_get_supported_impl(amxd_object_t *const object, int32_t depth, void *priv)
static amxd_status_t amxd_get_supported(amxd_object_t *object, get_supported_args_t *sup)
static void amxd_describe_object_usp(amxc_var_t *object_data, amxc_var_t *retval)
static void amxd_get_supported_add_data(amxd_object_t *const object, amxc_var_t *data, get_supported_args_t *sup)
Ambiorix Data Model API header file.
#define AMXD_OBJECT_EVENT
amxd_status_t amxd_object_describe(amxd_object_t *const object, amxc_var_t *const value, uint32_t flags, amxd_dm_access_t access)
Ambiorix path API header file.
Ambiorix Data Model API header file.
enum _amxd_status amxd_status_t
@ amxd_status_invalid_path
@ amxd_status_object_not_found
@ amxd_status_unknown_error
#define AMXD_OBJECT_SUPPORTED
Path format flag - adds {i} as placeholder for an instance object.
#define AMXD_TEMPLATE_INFO
List and describe flag.
#define AMXD_OBJECT_NO_BASE
List and describe flag.
#define AMXD_OBJECT_FUNC
List and describe flag.
enum _amxd_dm_access amxd_dm_access_t
Access level.
#define AMXD_OBJECT_PARAM
List and describe flag.
#define AMXD_OBJECT_TERMINATE
Path format flag - when set the object path is terminated with a dot.
amxd_object_t amxd_status_t amxd_status_t char * amxd_object_get_path(const amxd_object_t *object, const uint32_t flags)
Get the full path of the object.
void amxd_object_hierarchy_walk(amxd_object_t *const object, const amxd_direction_t direction, amxd_object_filter_fn_t filter, amxd_object_cb_fn_t cb, int32_t depth, void *priv)
Iterates over all objects in the data model tree.
amxd_object_t * amxd_object_findf(amxd_object_t *object, const char *rel_path,...) __attribute__((format(printf
Find an object in the data model tree, starting from an object.
amxd_dm_t * amxd_object_get_dm(const amxd_object_t *const object)
Get the data model.
static amxd_object_type_t amxd_object_get_type(const amxd_object_t *const object)
Returns the object type.
bool amxd_object_is_attr_set(const amxd_object_t *const object, const amxd_oattr_id_t attr)
Checks if an attribute is set.
amxd_status_t amxd_path_init(amxd_path_t *path, const char *object_path)
Initializes an amxd_path_t structure.
char * amxd_path_get_supported_path(amxd_path_t *path)
Translates the path into a path that can be used to fetch the object definition.
void amxd_path_clean(amxd_path_t *path)
Cleans an amxd_path_t structure.
static amxd_status_t status