[Freeswitch-svn] [commit] r7618 - in freeswitch/trunk/src: . include mod/applications/mod_fifo

Freeswitch SVN anthm at freeswitch.org
Fri Feb 15 11:01:12 EST 2008


Author: anthm
Date: Fri Feb 15 11:01:12 2008
New Revision: 7618

Modified:
   freeswitch/trunk/src/include/switch_core.h
   freeswitch/trunk/src/mod/applications/mod_fifo/mod_fifo.c
   freeswitch/trunk/src/switch_core_session.c

Log:
update

Modified: freeswitch/trunk/src/include/switch_core.h
==============================================================================
--- freeswitch/trunk/src/include/switch_core.h	(original)
+++ freeswitch/trunk/src/include/switch_core.h	Fri Feb 15 11:01:12 2008
@@ -779,6 +779,7 @@
 */
 SWITCH_DECLARE(switch_status_t) switch_core_session_dequeue_private_event(_In_ switch_core_session_t *session, _Out_ switch_event_t **event);
 
+SWITCH_DECLARE(uint32_t) switch_core_session_flush_private_events(switch_core_session_t *session);
 
 /*! 
   \brief Read a frame from a session

Modified: freeswitch/trunk/src/mod/applications/mod_fifo/mod_fifo.c
==============================================================================
--- freeswitch/trunk/src/mod/applications/mod_fifo/mod_fifo.c	(original)
+++ freeswitch/trunk/src/mod/applications/mod_fifo/mod_fifo.c	Fri Feb 15 11:01:12 2008
@@ -268,7 +268,7 @@
             switch_event_add_header(event, SWITCH_STACK_BOTTOM, "FIFO-Action", "push");
 			switch_event_fire(&event);
 		}
-
+		
         switch_ivr_park(session, NULL);
 
 		if (switch_channel_ready(channel)) {
@@ -393,6 +393,7 @@
 
                 if (switch_channel_test_flag(other_channel, CF_TAGGED)) {
                     switch_channel_clear_flag(other_channel, CF_CONTROLLED);
+					switch_core_session_flush_private_events(other_session);
                     switch_channel_stop_broadcast(other_channel);
                     switch_core_session_kill_channel(other_session, SWITCH_SIG_BREAK);
                     while (switch_channel_test_flag(other_channel, CF_TAGGED)) {

Modified: freeswitch/trunk/src/switch_core_session.c
==============================================================================
--- freeswitch/trunk/src/switch_core_session.c	(original)
+++ freeswitch/trunk/src/switch_core_session.c	Fri Feb 15 11:01:12 2008
@@ -563,6 +563,21 @@
 	return status;
 }
 
+SWITCH_DECLARE(uint32_t) switch_core_session_flush_private_events(switch_core_session_t *session)
+{
+	switch_status_t status = SWITCH_STATUS_FALSE;
+	int x = 0;
+	void *pop;
+
+	if (session->private_event_queue) {
+		while ((status = (switch_status_t) switch_queue_trypop(session->private_event_queue, &pop)) == SWITCH_STATUS_SUCCESS) {
+			x++;
+		}
+	}
+	
+	return x;
+}
+
 SWITCH_DECLARE(void) switch_core_session_reset(switch_core_session_t *session, switch_bool_t flush_dtmf)
 {
 	switch_channel_t *channel = switch_core_session_get_channel(session);



More information about the Freeswitch-svn mailing list