diff --git a/src/include/switch_event.h b/src/include/switch_event.h index d19b47ca6f..587926b33a 100644 --- a/src/include/switch_event.h +++ b/src/include/switch_event.h @@ -60,6 +60,8 @@ struct switch_event_node { 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_init(switch_memory_pool *pool); SWITCH_DECLARE(switch_status) switch_event_fire_subclass(switch_event_t event, char *subclass_name, char *data); diff --git a/src/mod/mod_event_test/mod_event_test.c b/src/mod/mod_event_test/mod_event_test.c index 613e451145..63d20ae66b 100644 --- a/src/mod/mod_event_test/mod_event_test.c +++ b/src/mod/mod_event_test/mod_event_test.c @@ -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!"); 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 */ return SWITCH_STATUS_SUCCESS; diff --git a/src/switch_event.c b/src/switch_event.c index 908f2c8248..4fc79b6a6d 100644 --- a/src/switch_event.c +++ b/src/switch_event.c @@ -64,22 +64,25 @@ static int switch_events_match(switch_event *event, switch_event_node *node) 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) { - match = (event->subclass && strstr(event->subclass->name, node->subclass->name)); - } else if (event->subclass) { + if (event->subclass && node->subclass) { + match = strstr(event->subclass->name, node->subclass->name) ? 1 : 0; + } else if (event->subclass && !node->subclass) { + match = 1; + } else { match = 0; } - } - return match; - } static void * SWITCH_THREAD_FUNC switch_event_thread(switch_thread *thread, void *obj)