aboutsummaryrefslogtreecommitdiffstats
path: root/main
diff options
context:
space:
mode:
authortilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2010-05-20 22:24:16 +0000
committertilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2010-05-20 22:24:16 +0000
commit6969d606e349902cf06840f51f9eb0be545d8b3c (patch)
tree2f4b2ddd9c966d5c2bcd37a38a6224ae635ed8a6 /main
parentcb567e23955ec449e1955546b4787674200352ff (diff)
Merged revisions 264779 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk ........ r264779 | tilghman | 2010-05-20 17:23:32 -0500 (Thu, 20 May 2010) | 8 lines Let ExtensionState resolve dynamic hints. (closes issue #16623) Reported by: tilghman Patches: 20100116__issue16623.diff.txt uploaded by tilghman (license 14) Tested by: lmadsen ........ git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.2@264783 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main')
-rw-r--r--main/pbx.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/main/pbx.c b/main/pbx.c
index f454fdbd3..682a17ee8 100644
--- a/main/pbx.c
+++ b/main/pbx.c
@@ -3837,6 +3837,17 @@ int ast_extension_state(struct ast_channel *c, const char *context, const char *
return -1; /* No hint, return -1 */
}
+ if (e->exten[0] == '_') {
+ /* Create this hint on-the-fly */
+ ast_add_extension(e->parent->name, 0, exten, e->priority, e->label,
+ e->matchcid ? e->cidmatch : NULL, e->app, ast_strdup(e->data), ast_free_ptr,
+ e->registrar);
+ if (!(e = ast_hint_extension(c, context, exten))) {
+ /* Improbable, but not impossible */
+ return -1;
+ }
+ }
+
return ast_extension_state2(e); /* Check all devices in the hint */
}