aboutsummaryrefslogtreecommitdiffstats
path: root/main/config.c
diff options
context:
space:
mode:
authorrbrindley <rbrindley@f38db490-d61c-443f-a65b-d21fe96a405b>2009-06-23 21:26:47 +0000
committerrbrindley <rbrindley@f38db490-d61c-443f-a65b-d21fe96a405b>2009-06-23 21:26:47 +0000
commitf8806fc84268c3d552bdb129889796597a3e4b8f (patch)
treebeb8b75d2d492de2be4ae63f6aa6552e65e9cded /main/config.c
parent6ac25ad06a461c575e894a299e790998f13aa9f5 (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 #14509) 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.0@202754 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main/config.c')
-rw-r--r--main/config.c29
1 files changed, 24 insertions, 5 deletions
diff --git a/main/config.c b/main/config.c
index 7a9aea5dd..dd8ad66f0 100644
--- a/main/config.c
+++ b/main/config.c
@@ -721,6 +721,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
@@ -1511,11 +1519,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)