git migration: Refactor the ASTERISK_FILE_VERSION macro
[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 ASTERISK_REGISTER_FILE()
33
34 #include "asterisk/chanvars.h"
35 #include "asterisk/strings.h"
36 #include "asterisk/utils.h"
37
38 #ifdef MALLOC_DEBUG
39 struct ast_var_t *_ast_var_assign(const char *name, const char *value, const char *file, int lineno, const char *function)
40 #else
41 struct ast_var_t *ast_var_assign(const char *name, const char *value)
42 #endif
43 {
44         struct ast_var_t *var;
45         int name_len = strlen(name) + 1;
46         int value_len = strlen(value) + 1;
47
48 #ifdef MALLOC_DEBUG
49         if (!(var = __ast_calloc(sizeof(*var) + name_len + value_len, sizeof(char), file, lineno, function))) {
50 #else
51         if (!(var = ast_calloc(sizeof(*var) + name_len + value_len, sizeof(char)))) {
52 #endif
53                 return NULL;
54         }
55
56         ast_copy_string(var->name, name, name_len);
57         var->value = var->name + name_len;
58         ast_copy_string(var->value, value, value_len);
59
60         return var;
61 }
62
63 void ast_var_delete(struct ast_var_t *var)
64 {
65         ast_free(var);
66 }
67
68 const char *ast_var_name(const struct ast_var_t *var)
69 {
70         const char *name;
71
72         if (var == NULL || (name = var->name) == NULL)
73                 return NULL;
74         /* Return the name without the initial underscores */
75         if (name[0] == '_') {
76                 name++;
77                 if (name[0] == '_')
78                         name++;
79         }
80         return name;
81 }
82
83 const char *ast_var_full_name(const struct ast_var_t *var)
84 {
85         return (var ? var->name : NULL);
86 }
87
88 const char *ast_var_value(const struct ast_var_t *var)
89 {
90         return (var ? var->value : NULL);
91 }
92
93 char *ast_var_find(const struct varshead *head, const char *name)
94 {
95         struct ast_var_t *var;
96
97         AST_LIST_TRAVERSE(head, var, entries) {
98                 if (!strcmp(name, var->name)) {
99                         return var->value;
100                 }
101         }
102         return NULL;
103 }
104
105 struct varshead *ast_var_list_create(void)
106 {
107         struct varshead *head;
108
109         head = ast_calloc(1, sizeof(*head));
110         if (!head) {
111                 return NULL;
112         }
113         AST_LIST_HEAD_INIT_NOLOCK(head);
114         return head;
115 }
116
117 void ast_var_list_destroy(struct varshead *head)
118 {
119         struct ast_var_t *var;
120
121         if (!head) {
122                 return;
123         }
124
125         while ((var = AST_LIST_REMOVE_HEAD(head, entries))) {
126                 ast_var_delete(var);
127         }
128
129         ast_free(head);
130 }
131
132 struct varshead *ast_var_list_clone(struct varshead *head)
133 {
134         struct varshead *clone;
135         struct ast_var_t *var, *newvar;
136
137         if (!head) {
138                 return NULL;
139         }
140
141         clone = ast_var_list_create();
142         if (!clone) {
143                 return NULL;
144         }
145
146         AST_VAR_LIST_TRAVERSE(head, var) {
147                 newvar = ast_var_assign(var->name, var->value);
148                 if (!newvar) {
149                         ast_var_list_destroy(clone);
150                         return NULL;
151                 }
152                 AST_VAR_LIST_INSERT_TAIL(clone, newvar);
153         }
154
155         return clone;
156 }