Merge "res_calendar: Specialized calendars depend on symbols of general calendar."
[asterisk/asterisk.git] / main / chanvars.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 1999 - 2005, Digium, Inc.
5  *
6  * Mark Spencer <markster@digium.com>
7  *
8  * See http://www.asterisk.org for more information about
9  * the Asterisk project. Please do not directly contact
10  * any of the maintainers of this project for assistance;
11  * the project provides a web site, mailing lists and IRC
12  * channels for your use.
13  *
14  * This program is free software, distributed under the terms of
15  * the GNU General Public License Version 2. See the LICENSE file
16  * at the top of the source tree.
17  */
18
19 /*! \file
20  *
21  * \brief Channel Variables
22  *
23  * \author Mark Spencer <markster@digium.com>
24  */
25
26 /*** MODULEINFO
27         <support_level>core</support_level>
28  ***/
29
30 #include "asterisk.h"
31
32 #include "asterisk/chanvars.h"
33 #include "asterisk/strings.h"
34 #include "asterisk/utils.h"
35
36 #ifdef __AST_DEBUG_MALLOC
37 struct ast_var_t *_ast_var_assign(const char *name, const char *value, const char *file, int lineno, const char *function)
38 #else
39 struct ast_var_t *ast_var_assign(const char *name, const char *value)
40 #endif
41 {
42         struct ast_var_t *var;
43         int name_len = strlen(name) + 1;
44         int value_len = strlen(value) + 1;
45
46 #ifdef __AST_DEBUG_MALLOC
47         if (!(var = __ast_calloc(sizeof(*var) + name_len + value_len, sizeof(char), file, lineno, function))) {
48 #else
49         if (!(var = ast_calloc(sizeof(*var) + name_len + value_len, sizeof(char)))) {
50 #endif
51                 return NULL;
52         }
53
54         ast_copy_string(var->name, name, name_len);
55         var->value = var->name + name_len;
56         ast_copy_string(var->value, value, value_len);
57
58         return var;
59 }
60
61 void ast_var_delete(struct ast_var_t *var)
62 {
63         ast_free(var);
64 }
65
66 const char *ast_var_name(const struct ast_var_t *var)
67 {
68         const char *name;
69
70         if (var == NULL || (name = var->name) == NULL)
71                 return NULL;
72         /* Return the name without the initial underscores */
73         if (name[0] == '_') {
74                 name++;
75                 if (name[0] == '_')
76                         name++;
77         }
78         return name;
79 }
80
81 const char *ast_var_full_name(const struct ast_var_t *var)
82 {
83         return (var ? var->name : NULL);
84 }
85
86 const char *ast_var_value(const struct ast_var_t *var)
87 {
88         return (var ? var->value : NULL);
89 }
90
91 char *ast_var_find(const struct varshead *head, const char *name)
92 {
93         struct ast_var_t *var;
94
95         AST_LIST_TRAVERSE(head, var, entries) {
96                 if (!strcmp(name, var->name)) {
97                         return var->value;
98                 }
99         }
100         return NULL;
101 }
102
103 struct varshead *ast_var_list_create(void)
104 {
105         struct varshead *head;
106
107         head = ast_calloc(1, sizeof(*head));
108         if (!head) {
109                 return NULL;
110         }
111         AST_LIST_HEAD_INIT_NOLOCK(head);
112         return head;
113 }
114
115 void ast_var_list_destroy(struct varshead *head)
116 {
117         struct ast_var_t *var;
118
119         if (!head) {
120                 return;
121         }
122
123         while ((var = AST_LIST_REMOVE_HEAD(head, entries))) {
124                 ast_var_delete(var);
125         }
126
127         ast_free(head);
128 }
129
130 struct varshead *ast_var_list_clone(struct varshead *head)
131 {
132         struct varshead *clone;
133         struct ast_var_t *var, *newvar;
134
135         if (!head) {
136                 return NULL;
137         }
138
139         clone = ast_var_list_create();
140         if (!clone) {
141                 return NULL;
142         }
143
144         AST_VAR_LIST_TRAVERSE(head, var) {
145                 newvar = ast_var_assign(var->name, var->value);
146                 if (!newvar) {
147                         ast_var_list_destroy(clone);
148                         return NULL;
149                 }
150                 AST_VAR_LIST_INSERT_TAIL(clone, newvar);
151         }
152
153         return clone;
154 }