summaryrefslogtreecommitdiff
path: root/pbx.c
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2003-04-03 07:35:14 +0000
committerMark Spencer <markster@digium.com>2003-04-03 07:35:14 +0000
commit9b675251440b5b7a7a2ec742098c10185fbb62d0 (patch)
tree49d5e1a620332ed0e3dad359dca22b9c51d235b3 /pbx.c
parentcb87c27bfdce6483f356f6fc6bd1226888c90602 (diff)
State change patch
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@740 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'pbx.c')
-rwxr-xr-xpbx.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/pbx.c b/pbx.c
index 9a41ce218..011bd2687 100755
--- a/pbx.c
+++ b/pbx.c
@@ -1245,18 +1245,21 @@ int ast_extension_state_add(char *context, char *exten,
struct ast_notify_cb *cblist;
struct ast_exten *e;
+ e = ast_hint_extension(NULL, context, exten);
+ if (!e) {
+ return -1;
+ }
+
pthread_mutex_lock(&notifylock);
list = notifys;
while (list) {
- if (!strcmp(list->exten->parent->name, context) &&
- !strcmp(list->exten->exten, exten))
+ if (list->exten == e)
break;
list = list->next;
}
if (!list) {
- e = ast_hint_extension(NULL, context, exten);
if (!e) {
pthread_mutex_unlock(&notifylock);
return -1;
@@ -1267,9 +1270,9 @@ int ast_extension_state_add(char *context, char *exten,
return -1;
}
/* Initialize and insert new item */
- memset(list, 0, sizeof(struct ast_notify));
+ memset(list, 0, sizeof(struct ast_notify));
list->exten = e;
- list->laststate = -1;
+ list->laststate = ast_extension_state2(e);
list->next = notifys;
notifys = list;
}