diff options
author | rbrindley <rbrindley@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-07-06 14:24:54 +0000 |
---|---|---|
committer | rbrindley <rbrindley@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-07-06 14:24:54 +0000 |
commit | 8eb1e1143a5757b5cb379c6dfa2d99b6efd94b0e (patch) | |
tree | 9e082f980af58b2379cffa8324facd0e29b6c209 /main | |
parent | 2dcac9436df62f51f252742bce6fea49b50da740 (diff) |
Merged revisions 202753 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk
........
r202753 | rbrindley | 2009-06-23 16:25:17 -0500 (Tue, 23 Jun 2009) | 9 lines
If we delete the info, lets also delete the lines
(closes issue 0014509)
Reported by: timeshell
Patches:
20090504__bug14509.diff.txt uploaded by tilghman (license 14)
Tested by: awk, timeshell
........
git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.1@204976 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main')
-rw-r--r-- | main/config.c | 29 |
1 files changed, 24 insertions, 5 deletions
diff --git a/main/config.c b/main/config.c index fdc1e7a4f..a1cc003b6 100644 --- a/main/config.c +++ b/main/config.c @@ -737,6 +737,14 @@ int ast_variable_update(struct ast_category *category, const char *variable, newer->next = cur->next; newer->object = cur->object || object; + + /* Preserve everything */ + newer->lineno = cur->lineno; + newer->blanklines = cur->blanklines; + newer->precomments = cur->precomments; cur->precomments = NULL; + newer->sameline = cur->sameline; cur->sameline = NULL; + newer->trailing = cur->trailing; cur->trailing = NULL; + if (prev) prev->next = newer; else @@ -1551,11 +1559,22 @@ static void insert_leading_blank_lines(FILE *fp, struct inclfile *fi, struct ast the ;! header comments were not also deleted in the process */ if (lineno - precomment_lines - fi->lineno < 0) { /* insertions can mess up the line numbering and produce negative numbers that mess things up */ return; - } - for (i=fi->lineno; i<lineno - precomment_lines; i++) { - fprintf(fp,"\n"); - } - fi->lineno = lineno+1; /* Advance the file lineno */ + } else if (lineno == 0) { + /* Line replacements also mess things up */ + return; + } else if (lineno - precomment_lines - fi->lineno < 5) { + /* Only insert less than 5 blank lines; if anything more occurs, + * it's probably due to context deletion. */ + for (i = fi->lineno; i < lineno - precomment_lines; i++) { + fprintf(fp, "\n"); + } + } else { + /* Deletion occurred - insert a single blank line, for separation of + * contexts. */ + fprintf(fp, "\n"); + } + + fi->lineno = lineno + 1; /* Advance the file lineno */ } int config_text_file_save(const char *configfile, const struct ast_config *cfg, const char *generator) |