summaryrefslogtreecommitdiff
path: root/config.c
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2003-04-25 20:33:27 +0000
committerMark Spencer <markster@digium.com>2003-04-25 20:33:27 +0000
commit20e1b9286273082880e5bb33138ca7b581ef71a8 (patch)
tree3e77dcc58ee15d74189768a22d5406b3a582bd06 /config.c
parenta54678d7fafb61ed11080bacda6b10471538d8a0 (diff)
Allocate comments
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@914 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'config.c')
-rwxr-xr-xconfig.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/config.c b/config.c
index 21c8fb9a5..61e77c858 100755
--- a/config.c
+++ b/config.c
@@ -66,7 +66,6 @@ static void free_comments(struct ast_comment *com)
while (com) {
l = com;
com = com->next;
- free(l->comment);
free(l);
}
}
@@ -280,7 +279,7 @@ int ast_category_delete(struct ast_config *cfg, char *category)
struct ast_variable *ast_variable_append_modify(struct ast_config *config, char *category, char *variable, char *value, int newcat, int newvar, int move)
{
- struct ast_variable *v, *pv, *bv, *bpv;
+ struct ast_variable *v, *pv=NULL, *bv, *bpv;
struct ast_category *cat, *pcat;
cat = config->root;
if (!newcat) {
@@ -397,10 +396,13 @@ int ast_category_exist(struct ast_config *config, char *category_name)
static struct ast_comment *build_comment(char *cmt)
{
struct ast_comment *c;
- c = malloc(sizeof(struct ast_comment));
+ int len = strlen(cmt) + 1;
+ c = malloc(sizeof(struct ast_comment) + len);
if (c) {
+ /* Memset the header */
memset(c, 0, sizeof(struct ast_comment));
- c->comment = strdup(cmt);
+ /* Copy the rest */
+ strcpy(c->cmt, cmt);
}
return c;
}
@@ -557,7 +559,7 @@ static int cfg_process(struct ast_config *tmp, struct ast_category **_tmpc, stru
static void dump_comments(FILE *f, struct ast_comment *comment)
{
while (comment) {
- fprintf(f, ";%s", comment->comment);
+ fprintf(f, ";%s", comment->cmt);
comment = comment->next;
}
}
@@ -593,14 +595,14 @@ int ast_save(char *configfile, struct ast_config *cfg, char *generator)
dump_comments(f, cat->precomments);
/* Dump section with any appropriate comment */
if (cat->sameline)
- fprintf(f, "[%s] ; %s\n", cat->name, cat->sameline->comment);
+ fprintf(f, "[%s] ; %s\n", cat->name, cat->sameline->cmt);
else
fprintf(f, "[%s]\n", cat->name);
var = cat->root;
while(var) {
dump_comments(f, var->precomments);
if (var->sameline)
- fprintf(f, "%s %s %s ; %s\n", var->name, (var->object ? "=>" : "="), var->value, var->sameline->comment);
+ fprintf(f, "%s %s %s ; %s\n", var->name, (var->object ? "=>" : "="), var->value, var->sameline->cmt);
else
fprintf(f, "%s %s %s\n", var->name, (var->object ? "=>" : "="), var->value);
if (var->blanklines) {