aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authortilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2009-02-18 19:07:05 +0000
committertilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2009-02-18 19:07:05 +0000
commit831735f25fd495e7da231a8f4ddd335736078d85 (patch)
treebfe24cad6ca3f203a4b84e518e4f76049a0e14bd /include
parent2f18cdd20f76bc6c1b7238115931f881649feb59 (diff)
Merged revisions 177098 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk ................ r177098 | tilghman | 2009-02-18 13:05:15 -0600 (Wed, 18 Feb 2009) | 9 lines Merged revisions 177096 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r177096 | tilghman | 2009-02-18 12:30:38 -0600 (Wed, 18 Feb 2009) | 2 lines Document the return value of the update method (as requested on -dev list) ........ ................ git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.0@177099 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'include')
-rw-r--r--include/asterisk/config.h50
1 files changed, 47 insertions, 3 deletions
diff --git a/include/asterisk/config.h b/include/asterisk/config.h
index 793bb89ff..cd5d66250 100644
--- a/include/asterisk/config.h
+++ b/include/asterisk/config.h
@@ -92,7 +92,7 @@ struct ast_config_engine {
* CONFIG_FLAG_FILEUNCHANGED - check the file mtime and return CONFIG_STATUS_FILEUNCHANGED if the mtime is the same; or
* CONFIG_FLAG_NOCACHE - don't cache file mtime (main purpose of this option is to save memory on temporary files).
*
- * \retval an ast_config data structure on success
+ * \return an ast_config data structure on success
* \retval NULL on error
*/
struct ast_config *ast_config_load2(const char *filename, const char *who_asked, struct ast_flags flags);
@@ -181,6 +181,9 @@ int ast_category_exist(const struct ast_config *config, const char *category_nam
* entity in realtime and return a variable list of its parameters. Note
* that unlike the variables in ast_config, the resulting list of variables
* MUST be freed with ast_variables_destroy() as there is no container.
+ *
+ * The difference between these two calls is that ast_load_realtime excludes
+ * fields whose values are NULL, while ast_load_realtime_all loads all columns.
*/
struct ast_variable *ast_load_realtime(const char *family, ...);
struct ast_variable *ast_load_realtime_all(const char *family, ...);
@@ -202,6 +205,7 @@ struct ast_config *ast_load_realtime_multientry(const char *family, ...);
* \param keyfield which field to use as the key
* \param lookup which value to look for in the key field to match the entry.
* This function is used to update a parameter in realtime configuration space.
+ * \return Number of rows affected, or -1 on error.
*
*/
int ast_update_realtime(const char *family, const char *keyfield, const char *lookup, ...);
@@ -210,6 +214,10 @@ int ast_update_realtime(const char *family, const char *keyfield, const char *lo
* \brief Create realtime configuration
* \param family which family/config to be created
* This function is used to create a parameter in realtime configuration space.
+ * \return Number of rows affected, or -1 on error.
+ * On the MySQL engine only, for reasons of backwards compatibility, the return
+ * value is the insert ID. This value is nonportable and may be changed in a
+ * future version to match the other engines.
*
*/
int ast_store_realtime(const char *family, ...);
@@ -221,6 +229,7 @@ int ast_store_realtime(const char *family, ...);
* \param lookup which value to look for in the key field to match the entry.
* This function is used to destroy an entry in realtime configuration space.
* Additional params are used as keys.
+ * \return Number of rows affected, or -1 on error.
*
*/
int ast_destroy_realtime(const char *family, const char *keyfield, const char *lookup, ...);
@@ -241,20 +250,50 @@ int ast_realtime_enabled(void);
*/
void ast_variables_destroy(struct ast_variable *var);
-/*! \brief Register config engine */
+/*! \brief Register config engine
+ * \retval 1 Always
+ */
int ast_config_engine_register(struct ast_config_engine *newconfig);
-/*! \brief Deegister config engine */
+/*! \brief Deregister config engine
+ * \retval 0 Always
+ */
int ast_config_engine_deregister(struct ast_config_engine *del);
+/*!\brief Exposed initialization method for core process
+ * This method is intended for use only with the core initialization and is
+ * not designed to be called from any user applications.
+ */
int register_config_cli(void);
+
+/*!\brief Exposed re-initialization method for core process
+ * This method is intended for use only with the core re-initialization and is
+ * not designed to be called from any user applications.
+ */
int read_config_maps(void);
+/*!\brief Create a new base configuration structure */
struct ast_config *ast_config_new(void);
+
+/*!\brief Retrieve the current category name being built.
+ * API for backend configuration engines while building a configuration set.
+ */
struct ast_category *ast_config_get_current_category(const struct ast_config *cfg);
+
+/*!\brief Set the category within the configuration as being current.
+ * API for backend configuration engines while building a configuration set.
+ */
void ast_config_set_current_category(struct ast_config *cfg, const struct ast_category *cat);
+
+/*!\brief Retrieve a configuration variable within the configuration set.
+ * Retrieves the named variable \p var within category \p cat of configuration
+ * set \p cfg. If not found, attempts to retrieve the named variable \p var
+ * from within category \em general.
+ * \return Value of \p var, or NULL if not found.
+ */
const char *ast_config_option(struct ast_config *cfg, const char *cat, const char *var);
+/*!\brief Create a category structure */
struct ast_category *ast_category_new(const char *name, const char *in_file, int lineno);
void ast_category_append(struct ast_config *config, struct ast_category *cat);
@@ -268,6 +307,11 @@ void ast_category_append(struct ast_config *config, struct ast_category *cat);
*/
void ast_category_insert(struct ast_config *config, struct ast_category *cat, const char *match);
int ast_category_delete(struct ast_config *cfg, const char *category);
+
+/*!\brief Removes and destroys all variables within a category
+ * \retval 0 if the category was found and emptied
+ * \retval -1 if the category was not found
+ */
int ast_category_empty(struct ast_config *cfg, const char *category);
void ast_category_destroy(struct ast_category *cat);
struct ast_variable *ast_category_detach_variables(struct ast_category *cat);