Fix chan_phone error code (bug #3692)
[asterisk/asterisk.git] / chanvars.c
index 6f8e847..2f23c4d 100755 (executable)
  * the GNU General Public License
  */
 
  * the GNU General Public License
  */
 
-#include <malloc.h>
+#include <stdlib.h>
 #include <string.h>
 
 #include <asterisk/chanvars.h>
 #include <asterisk/logger.h>
 
 #include <string.h>
 
 #include <asterisk/chanvars.h>
 #include <asterisk/logger.h>
 
-struct ast_var_t *ast_var_assign(char *name, char *value)
+struct ast_var_t *ast_var_assign(const char *name, const char *value)
 {
        int i;
        struct ast_var_t *var;
 {
        int i;
        struct ast_var_t *var;
+       int len;
        
        
-       var = malloc(sizeof(struct ast_var_t));
+       len = sizeof(struct ast_var_t);
+       
+       len += strlen(name) + 1;
+       len += strlen(value) + 1;
+       
+       var = malloc(len);
 
        if (var == NULL)
        {
 
        if (var == NULL)
        {
@@ -30,46 +36,46 @@ struct ast_var_t *ast_var_assign(char *name, char *value)
                return NULL;
        }
        
                return NULL;
        }
        
-       i = strlen(value);
-       var->value = malloc(i + 1);
-       if (var->value == NULL)
-       {
-               ast_log(LOG_WARNING, "Out of memory\n");
-               free(var);
-               return NULL;
-       }
-
-       strncpy(var->value, value, i);
-       var->value[i] = '\0';
-       
        i = strlen(name);
        i = strlen(name);
-       var->name = malloc(i + 1);
-       if (var->name == NULL)
-       {
-               ast_log(LOG_WARNING, "Out of memory\n");
-               free(var->value);
-               free(var);
-               return NULL;
-       }
-
        strncpy(var->name, name, i); 
        var->name[i] = '\0';
 
        strncpy(var->name, name, i); 
        var->name[i] = '\0';
 
+       var->value = var->name + i + 1;
+
+       i = strlen(value);
+       strncpy(var->value, value, i);
+       var->value[i] = '\0';
+       
        return var;
 }      
        
 void ast_var_delete(struct ast_var_t *var)
 {
        if (var == NULL) return;
        return var;
 }      
        
 void ast_var_delete(struct ast_var_t *var)
 {
        if (var == NULL) return;
-
-       if (var->name != NULL) free(var->name);
-       if (var->value != NULL) free(var->value);
-
        free(var);
 }
 
 char *ast_var_name(struct ast_var_t *var)
 {
        free(var);
 }
 
 char *ast_var_name(struct ast_var_t *var)
 {
+       char *name;
+
+       if (var == NULL)
+               return NULL;
+       if (var->name == NULL)
+               return NULL;
+       /* Return the name without the initial underscores */
+       if ((strlen(var->name) > 0) && (var->name[0] == '_')) {
+               if ((strlen(var->name) > 1) && (var->name[1] == '_'))
+                       name = (char*)&(var->name[2]);
+               else
+                       name = (char*)&(var->name[1]);
+       } else
+               name = var->name;
+       return name;
+}
+
+char *ast_var_full_name(struct ast_var_t *var)
+{
        return (var != NULL ? var->name : NULL);
 }
 
        return (var != NULL ? var->name : NULL);
 }