提交 b09fedf7 authored 作者: Anthony Minessale's avatar Anthony Minessale

update

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@158 d0543943-73ff-0310-b7d9-9358b9ac24b2
上级 48e62491
...@@ -60,6 +60,8 @@ struct switch_event_node { ...@@ -60,6 +60,8 @@ struct switch_event_node {
struct switch_event_node *next; struct switch_event_node *next;
}; };
#define SWITCH_EVENT_SUBCLASS_ANY NULL
SWITCH_DECLARE(switch_status) switch_event_shutdown(void); SWITCH_DECLARE(switch_status) switch_event_shutdown(void);
SWITCH_DECLARE(switch_status) switch_event_init(switch_memory_pool *pool); SWITCH_DECLARE(switch_status) switch_event_init(switch_memory_pool *pool);
SWITCH_DECLARE(switch_status) switch_event_fire_subclass(switch_event_t event, char *subclass_name, char *data); SWITCH_DECLARE(switch_status) switch_event_fire_subclass(switch_event_t event, char *subclass_name, char *data);
......
...@@ -61,7 +61,11 @@ SWITCH_MOD_DECLARE(switch_status) switch_module_load(switch_loadable_module_inte ...@@ -61,7 +61,11 @@ SWITCH_MOD_DECLARE(switch_status) switch_module_load(switch_loadable_module_inte
switch_console_printf(SWITCH_CHANNEL_CONSOLE, "Couldn't register subclass!"); switch_console_printf(SWITCH_CHANNEL_CONSOLE, "Couldn't register subclass!");
return SWITCH_STATUS_GENERR; return SWITCH_STATUS_GENERR;
} }
switch_event_bind((char *)modname, SWITCH_EVENT_ALL, NULL, event_handler, NULL);
if (switch_event_bind((char *)modname, SWITCH_EVENT_ALL, SWITCH_EVENT_SUBCLASS_ANY, event_handler, NULL) != SWITCH_STATUS_SUCCESS) {
switch_console_printf(SWITCH_CHANNEL_CONSOLE, "Couldn't bind!\n");
return SWITCH_STATUS_GENERR;
}
/* indicate that the module should continue to be loaded */ /* indicate that the module should continue to be loaded */
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
......
...@@ -64,22 +64,25 @@ static int switch_events_match(switch_event *event, switch_event_node *node) ...@@ -64,22 +64,25 @@ static int switch_events_match(switch_event *event, switch_event_node *node)
if (node->event == SWITCH_EVENT_ALL) { if (node->event == SWITCH_EVENT_ALL) {
return 1; match++;
if (!node->subclass) {
return match;
}
} }
if (event->event == node->event) { if (match || event->event == node->event) {
if (node->subclass) { if (event->subclass && node->subclass) {
match = (event->subclass && strstr(event->subclass->name, node->subclass->name)); match = strstr(event->subclass->name, node->subclass->name) ? 1 : 0;
} else if (event->subclass) { } else if (event->subclass && !node->subclass) {
match = 1;
} else {
match = 0; match = 0;
} }
} }
return match; return match;
} }
static void * SWITCH_THREAD_FUNC switch_event_thread(switch_thread *thread, void *obj) static void * SWITCH_THREAD_FUNC switch_event_thread(switch_thread *thread, void *obj)
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论