ALSA project - the C library reference
conf.h
Go to the documentation of this file.
1 
11 /*
12  * This library is free software; you can redistribute it and/or modify
13  * it under the terms of the GNU Lesser General Public License as
14  * published by the Free Software Foundation; either version 2.1 of
15  * the License, or (at your option) any later version.
16  *
17  * This program is distributed in the hope that it will be useful,
18  * but WITHOUT ANY WARRANTY; without even the implied warranty of
19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20  * GNU Lesser General Public License for more details.
21  *
22  * You should have received a copy of the GNU Lesser General Public
23  * License along with this library; if not, write to the Free Software
24  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
25  *
26  */
27 
28 #ifndef __ALSA_CONF_H
29 #define __ALSA_CONF_H
30 
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34 
43 #define SND_CONFIG_DLSYM_VERSION_EVALUATE _dlsym_config_evaluate_001
44 
45 #define SND_CONFIG_DLSYM_VERSION_HOOK _dlsym_config_hook_001
46 
48 typedef enum _snd_config_type {
61 } snd_config_type_t;
62 
69 typedef struct _snd_config snd_config_t;
77 typedef struct _snd_config_iterator *snd_config_iterator_t;
83 typedef struct _snd_config_update snd_config_update_t;
84 
85 extern snd_config_t *snd_config;
86 
87 const char *snd_config_topdir(void);
88 
89 int snd_config_top(snd_config_t **config);
90 
91 int snd_config_load(snd_config_t *config, snd_input_t *in);
92 int snd_config_load_string(snd_config_t **config, const char *s, size_t size);
94 int snd_config_save(snd_config_t *config, snd_output_t *out);
95 int snd_config_update(void);
96 int snd_config_update_r(snd_config_t **top, snd_config_update_t **update, const char *path);
99 
101 void snd_config_ref(snd_config_t *top);
102 void snd_config_unref(snd_config_t *top);
103 
104 int snd_config_search(snd_config_t *config, const char *key,
105  snd_config_t **result);
106 int snd_config_searchv(snd_config_t *config,
107  snd_config_t **result, ...);
109  const char *base, const char *key,
110  snd_config_t **result);
111 
112 typedef int (*snd_config_expand_fcn_t)(snd_config_t **dst, const char *s, void *private_data);
113 
115  snd_config_expand_fcn_t fcn, void *private_data,
116  snd_config_t **result);
117 int snd_config_expand(snd_config_t *config, snd_config_t *root,
118  const char *args, snd_config_t *private_data,
119  snd_config_t **result);
121  snd_config_t *private_data, snd_config_t **result);
122 int snd_config_evaluate_string(snd_config_t **dst, const char *s,
123  snd_config_expand_fcn_t fcn, void *private_data);
124 
125 int snd_config_add(snd_config_t *config, snd_config_t *child);
126 int snd_config_add_before(snd_config_t *before, snd_config_t *child);
128 int snd_config_remove(snd_config_t *config);
129 int snd_config_delete(snd_config_t *config);
131 int snd_config_copy(snd_config_t **dst, snd_config_t *src);
132 int snd_config_merge(snd_config_t *dst, snd_config_t *src, int override);
133 
134 int snd_config_make(snd_config_t **config, const char *key,
135  snd_config_type_t type);
136 int snd_config_make_integer(snd_config_t **config, const char *key);
137 int snd_config_make_integer64(snd_config_t **config, const char *key);
138 int snd_config_make_real(snd_config_t **config, const char *key);
139 int snd_config_make_string(snd_config_t **config, const char *key);
140 int snd_config_make_pointer(snd_config_t **config, const char *key);
141 int snd_config_make_compound(snd_config_t **config, const char *key, int join);
142 int snd_config_make_path(snd_config_t **config, snd_config_t *root, const char *key,
143  int join, int override);
144 
145 int snd_config_imake_integer(snd_config_t **config, const char *key, const long value);
146 int snd_config_imake_integer64(snd_config_t **config, const char *key, const long long value);
147 int snd_config_imake_real(snd_config_t **config, const char *key, const double value);
148 int snd_config_imake_string(snd_config_t **config, const char *key, const char *ascii);
149 int snd_config_imake_safe_string(snd_config_t **config, const char *key, const char *ascii);
150 int snd_config_imake_pointer(snd_config_t **config, const char *key, const void *ptr);
151 
152 snd_config_type_t snd_config_get_type(const snd_config_t *config);
153 int snd_config_is_array(const snd_config_t *config);
154 int snd_config_is_empty(const snd_config_t *config);
155 
156 int snd_config_set_id(snd_config_t *config, const char *id);
157 int snd_config_set_integer(snd_config_t *config, long value);
158 int snd_config_set_integer64(snd_config_t *config, long long value);
159 int snd_config_set_real(snd_config_t *config, double value);
160 int snd_config_set_string(snd_config_t *config, const char *value);
161 int snd_config_set_ascii(snd_config_t *config, const char *ascii);
162 int snd_config_set_pointer(snd_config_t *config, const void *ptr);
163 int snd_config_get_id(const snd_config_t *config, const char **value);
164 int snd_config_get_integer(const snd_config_t *config, long *value);
165 int snd_config_get_integer64(const snd_config_t *config, long long *value);
166 int snd_config_get_real(const snd_config_t *config, double *value);
167 int snd_config_get_ireal(const snd_config_t *config, double *value);
168 int snd_config_get_string(const snd_config_t *config, const char **value);
169 int snd_config_get_ascii(const snd_config_t *config, char **value);
170 int snd_config_get_pointer(const snd_config_t *config, const void **value);
171 int snd_config_test_id(const snd_config_t *config, const char *id);
172 
177 
195 #define snd_config_for_each(pos, next, node) \
196  for (pos = snd_config_iterator_first(node), next = snd_config_iterator_next(pos); pos != snd_config_iterator_end(node); pos = next, next = snd_config_iterator_next(pos))
197 
198 /* Misc functions */
199 
200 int snd_config_get_bool_ascii(const char *ascii);
201 int snd_config_get_bool(const snd_config_t *conf);
202 int snd_config_get_card(const snd_config_t *conf);
203 int snd_config_get_ctl_iface_ascii(const char *ascii);
204 int snd_config_get_ctl_iface(const snd_config_t *conf);
205 
206 /* Names functions */
207 
211 typedef struct snd_devname snd_devname_t;
212 
216 struct snd_devname {
217  char *name;
218  char *comment;
219  snd_devname_t *next;
220 };
221 
222 int snd_names_list(const char *iface, snd_devname_t **list);
223 void snd_names_list_free(snd_devname_t *list);
224 
227 #ifdef __cplusplus
228 }
229 #endif
230 
231 #endif /* __ALSA_CONF_H */
snd_config_update_free
int snd_config_update_free(snd_config_update_t *update)
Frees a private update structure.
Definition: conf.c:4732
snd_config_get_id
int snd_config_get_id(const snd_config_t *config, const char **value)
Returns the id of a configuration node.
Definition: conf.c:1879
snd_config_load
int snd_config_load(snd_config_t *config, snd_input_t *in)
Loads a configuration tree.
Definition: conf.c:2048
snd_config_make_integer
int snd_config_make_integer(snd_config_t **config, const char *key)
Creates an integer configuration node.
Definition: conf.c:2501
snd_config_imake_integer64
int snd_config_imake_integer64(snd_config_t **config, const char *key, const long long value)
Creates a 64-bit-integer configuration node with the given initial value.
Definition: conf.c:2795
snd_config_make
int snd_config_make(snd_config_t **config, const char *key, snd_config_type_t type)
Creates a configuration node.
Definition: conf.c:2467
snd_names_list
int snd_names_list(const char *iface, snd_devname_t **list)
This function is unimplemented.
Definition: names.c:42
snd_config_is_empty
int snd_config_is_empty(const snd_config_t *config)
Returns if the compound has no fields (is empty).
Definition: conf.c:1855
snd_config_get_integer
int snd_config_get_integer(const snd_config_t *config, long *value)
Returns the value of an integer configuration node.
Definition: conf.c:3140
snd_config_make_string
int snd_config_make_string(snd_config_t **config, const char *key)
Creates a string configuration node.
Definition: conf.c:2573
snd_devname::comment
char * comment
Definition: conf.h:218
SND_CONFIG_TYPE_POINTER
@ SND_CONFIG_TYPE_POINTER
Definition: conf.h:58
snd_config_remove
int snd_config_remove(snd_config_t *config)
Removes a configuration node from its tree.
Definition: conf.c:2343
snd_config_set_integer64
int snd_config_set_integer64(snd_config_t *config, long long value)
Changes the value of a 64-bit-integer configuration node.
Definition: conf.c:2969
snd_config_update_t
struct _snd_config_update snd_config_update_t
Internal structure for a configuration private update object.
Definition: conf.h:83
snd_config_load_override
int snd_config_load_override(snd_config_t *config, snd_input_t *in)
Loads a configuration tree and overrides existing configuration nodes.
Definition: conf.c:2106
snd_config_imake_pointer
int snd_config_imake_pointer(snd_config_t **config, const char *key, const void *ptr)
Creates a pointer configuration node with the given initial value.
Definition: conf.c:2921
snd_config_ref
void snd_config_ref(snd_config_t *top)
Take the reference of the config tree.
Definition: conf.c:4699
snd_config_unref
void snd_config_unref(snd_config_t *top)
Unreference the config tree.
Definition: conf.c:4719
snd_config_iterator_end
snd_config_iterator_t snd_config_iterator_end(const snd_config_t *node)
Returns an iterator that ends a node's children list.
Definition: conf.c:4824
snd_config_set_pointer
int snd_config_set_pointer(snd_config_t *config, const void *ptr)
Changes the value of a pointer configuration node.
Definition: conf.c:3046
snd_devname::name
char * name
Definition: conf.h:217
snd_config_make_real
int snd_config_make_real(snd_config_t **config, const char *key)
Creates a real number configuration node.
Definition: conf.c:2548
snd_config_t
struct _snd_config snd_config_t
Internal structure for a configuration node object.
Definition: conf.h:69
snd_output_t
struct _snd_output snd_output_t
Internal structure for an output object.
Definition: output.h:54
snd_config_update
int snd_config_update(void)
Updates snd_config by rereading the global configuration files (if needed).
Definition: conf.c:4649
snd_config_add
int snd_config_add(snd_config_t *config, snd_config_t *child)
Adds a child to a compound configuration node.
Definition: conf.c:2135
snd_config_make_integer64
int snd_config_make_integer64(snd_config_t **config, const char *key)
Creates a 64-bit-integer configuration node.
Definition: conf.c:2526
SND_CONFIG_TYPE_INTEGER64
@ SND_CONFIG_TYPE_INTEGER64
Definition: conf.h:52
snd_config_get_pointer
int snd_config_get_pointer(const snd_config_t *config, const void **value)
Returns the value of a pointer configuration node.
Definition: conf.c:3262
snd_config
snd_config_t * snd_config
Configuration top-level node (the global configuration).
Definition: conf.c:3916
snd_config_save
int snd_config_save(snd_config_t *config, snd_output_t *out)
Dumps the contents of a configuration node or tree.
Definition: conf.c:3399
snd_config_search
int snd_config_search(snd_config_t *config, const char *key, snd_config_t **result)
Searches for a node in a configuration tree.
Definition: conf.c:3600
snd_config_expand
int snd_config_expand(snd_config_t *config, snd_config_t *root, const char *args, snd_config_t *private_data, snd_config_t **result)
Expands a configuration node, applying arguments and functions.
Definition: conf.c:5660
SND_CONFIG_TYPE_COMPOUND
@ SND_CONFIG_TYPE_COMPOUND
Definition: conf.h:60
snd_config_get_integer64
int snd_config_get_integer64(const snd_config_t *config, long long *value)
Returns the value of a 64-bit-integer configuration node.
Definition: conf.c:3163
snd_input_t
struct _snd_input snd_input_t
Internal structure for an input object.
Definition: input.h:54
snd_config_delete
int snd_config_delete(snd_config_t *config)
Frees a configuration node.
Definition: conf.c:2374
snd_config_get_string
int snd_config_get_string(const snd_config_t *config, const char **value)
Returns the value of a string configuration node.
Definition: conf.c:3241
snd_config_make_pointer
int snd_config_make_pointer(snd_config_t **config, const char *key)
Creates a pointer configuration node.
Definition: conf.c:2595
snd_config_iterator_t
struct _snd_config_iterator * snd_config_iterator_t
Type for a configuration compound iterator.
Definition: conf.h:77
snd_config_update_free_global
int snd_config_update_free_global(void)
Frees the global configuration tree in snd_config.
Definition: conf.c:4754
snd_config_get_type
snd_config_type_t snd_config_get_type(const snd_config_t *config)
Returns the type of a configuration node.
Definition: conf.c:1805
snd_config_get_ctl_iface_ascii
int snd_config_get_ctl_iface_ascii(const char *ascii)
Gets the control interface index from the given ASCII string.
Definition: confmisc.c:180
snd_config_add_before
int snd_config_add_before(snd_config_t *before, snd_config_t *child)
Adds a child before another child configuration node.
Definition: conf.c:2214
SND_CONFIG_TYPE_STRING
@ SND_CONFIG_TYPE_STRING
Definition: conf.h:56
snd_config_test_id
int snd_config_test_id(const snd_config_t *config, const char *id)
Compares the id of a configuration node to a given string.
Definition: conf.c:3372
snd_config_update_r
int snd_config_update_r(snd_config_t **top, snd_config_update_t **update, const char *path)
Updates a configuration tree by rereading the configuration files (if needed).
Definition: conf.c:4488
snd_config_get_ctl_iface
int snd_config_get_ctl_iface(const snd_config_t *conf)
Gets the control interface index from a configuration node.
Definition: confmisc.c:203
snd_config_get_ireal
int snd_config_get_ireal(const snd_config_t *config, double *value)
Returns the value of a real or integer configuration node.
Definition: conf.c:3206
snd_config_set_ascii
int snd_config_set_ascii(snd_config_t *config, const char *ascii)
Changes the value of a configuration node.
Definition: conf.c:3080
snd_config_set_real
int snd_config_set_real(snd_config_t *config, double value)
Changes the value of a real-number configuration node.
Definition: conf.c:2989
snd_config_imake_real
int snd_config_imake_real(snd_config_t **config, const char *key, const double value)
Creates a real number configuration node with the given initial value.
Definition: conf.c:2822
ptr
void * ptr
Definition: seq_event.h:199
snd_config_get_card
int snd_config_get_card(const snd_config_t *conf)
Gets the card number from a configuration node.
Definition: confmisc.c:151
snd_config_imake_integer
int snd_config_imake_integer(snd_config_t **config, const char *key, const long value)
Creates an integer configuration node with the given initial value.
Definition: conf.c:2765
snd_config_update_ref
int snd_config_update_ref(snd_config_t **top)
Updates snd_config and takes its reference.
Definition: conf.c:4670
snd_config_merge
int snd_config_merge(snd_config_t *dst, snd_config_t *src, int override)
In-place merge of two config handles.
Definition: conf.c:2283
snd_config_delete_compound_members
int snd_config_delete_compound_members(const snd_config_t *config)
Deletes the children of a node.
Definition: conf.c:2428
snd_devname
Definition: conf.h:216
snd_config_iterator_first
snd_config_iterator_t snd_config_iterator_first(const snd_config_t *node)
Returns an iterator pointing to a node's first child.
Definition: conf.c:4786
snd_config_imake_string
int snd_config_imake_string(snd_config_t **config, const char *key, const char *ascii)
Creates a string configuration node with the given initial value.
Definition: conf.c:2852
snd_config_evaluate
int snd_config_evaluate(snd_config_t *config, snd_config_t *root, snd_config_t *private_data, snd_config_t **result)
Evaluates a configuration node at runtime.
Definition: conf.c:5203
snd_config_set_id
int snd_config_set_id(snd_config_t *config, const char *id)
Sets the id of a configuration node.
Definition: conf.c:1901
snd_config_set_string
int snd_config_set_string(snd_config_t *config, const char *value)
Changes the value of a string configuration node.
Definition: conf.c:3015
snd_config_expand_custom
int snd_config_expand_custom(snd_config_t *config, snd_config_t *root, snd_config_expand_fcn_t fcn, void *private_data, snd_config_t **result)
Expands a configuration node, applying arguments and functions.
Definition: conf.c:5627
snd_config_add_after
int snd_config_add_after(snd_config_t *after, snd_config_t *child)
Adds a child after another child configuration node.
Definition: conf.c:2173
snd_config_get_ascii
int snd_config_get_ascii(const snd_config_t *config, char **value)
Returns the value of a configuration node as a string.
Definition: conf.c:3298
snd_config_make_compound
int snd_config_make_compound(snd_config_t **config, const char *key, int join)
Creates an empty compound configuration node.
Definition: conf.c:2638
snd_config_load_string
int snd_config_load_string(snd_config_t **config, const char *s, size_t size)
Loads a configuration tree from a string.
Definition: conf.c:2069
snd_config_search_definition
int snd_config_search_definition(snd_config_t *config, const char *base, const char *key, snd_config_t **result)
Searches for a definition in a configuration tree, using aliases and expanding hooks and arguments.
Definition: conf.c:5742
snd_config_copy
int snd_config_copy(snd_config_t **dst, snd_config_t *src)
Creates a copy of a configuration node.
Definition: conf.c:4988
snd_config_get_bool
int snd_config_get_bool(const snd_config_t *conf)
Gets the boolean value from a configuration node.
Definition: confmisc.c:117
snd_config_set_integer
int snd_config_set_integer(snd_config_t *config, long value)
Changes the value of an integer configuration node.
Definition: conf.c:2946
snd_names_list_free
void snd_names_list_free(snd_devname_t *list)
This function is unimplemented.
Definition: names.c:53
snd_devname::next
snd_devname_t * next
Definition: conf.h:219
snd_config_is_array
int snd_config_is_array(const snd_config_t *config)
Returns if the compound is an array (and count of items).
Definition: conf.c:1831
snd_config_get_bool_ascii
int snd_config_get_bool_ascii(const char *ascii)
Gets the boolean value from the given ASCII string.
Definition: confmisc.c:89
snd_config_iterator_next
snd_config_iterator_t snd_config_iterator_next(const snd_config_iterator_t iterator)
Returns an iterator pointing to the next sibling.
Definition: conf.c:4806
snd_config_make_path
int snd_config_make_path(snd_config_t **config, snd_config_t *root, const char *key, int join, int override)
Creates an empty compound configuration node in the path.
Definition: conf.c:2690
snd_config_searchv
int snd_config_searchv(snd_config_t *config, snd_config_t **result,...)
Searches for a node in a configuration tree.
Definition: conf.c:3691
snd_config_iterator_entry
snd_config_t * snd_config_iterator_entry(const snd_config_iterator_t iterator)
Returns the configuration node handle pointed to by an iterator.
Definition: conf.c:4838
snd_config_get_real
int snd_config_get_real(const snd_config_t *config, double *value)
Returns the value of a real-number configuration node.
Definition: conf.c:3183
_snd_config_type
_snd_config_type
Configuration node type.
Definition: conf.h:48
SND_CONFIG_TYPE_INTEGER
@ SND_CONFIG_TYPE_INTEGER
Definition: conf.h:50
SND_CONFIG_TYPE_REAL
@ SND_CONFIG_TYPE_REAL
Definition: conf.h:54
snd_config_top
int snd_config_top(snd_config_t **config)
Creates a top level configuration node.
Definition: conf.c:1943