diff options
author | Tilghman Lesher <tilghman@meg.abyt.es> | 2008-10-10 18:59:58 +0000 |
---|---|---|
committer | Tilghman Lesher <tilghman@meg.abyt.es> | 2008-10-10 18:59:58 +0000 |
commit | 038b588ee898d078e049292bce908ec92d5adfb2 (patch) | |
tree | 2596c29fc8baeed37fc55edc69ae1365208fad83 | |
parent | 5c32f80a61ffccfe2e1c80d019ecc0fcaf1229c8 (diff) |
Reset continuation items at the beginning of each context (suggested by
kpfleming).
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@148329 65c4cc65-6c06-0410-ace0-fbb531ad65f3
-rw-r--r-- | pbx/pbx_config.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/pbx/pbx_config.c b/pbx/pbx_config.c index e2b38c15d..798a098bb 100644 --- a/pbx/pbx_config.c +++ b/pbx/pbx_config.c @@ -1410,7 +1410,7 @@ static int pbx_load_config(const char *config_file) const char *aft; const char *newpm, *ovsw; struct ast_flags config_flags = { 0 }; - char lastextension[256] = ""; + char lastextension[256]; cfg = ast_config_load(config_file, config_flags); if (!cfg) return 0; @@ -1451,11 +1451,19 @@ static int pbx_load_config(const char *config_file) if (con == NULL) continue; + /* Reset continuation items at the beginning of each context */ + lastextension[0] = '\0'; + lastpri = -2; + for (v = ast_variable_browse(cfg, cxt); v; v = v->next) { char *tc = NULL; char realext[256] = ""; char *stringp, *ext; if (!strncasecmp(v->name, "same", 4)) { + if (ast_strlen_zero(lastextension)) { + ast_log(LOG_ERROR, "No previous pattern in the first entry of context '%s' to match '%s'!\n", cxt, v->name); + continue; + } if ((stringp = tc = ast_strdup(v->value))) { ast_copy_string(realext, lastextension, sizeof(realext)); goto copy_last_extension; |