[asterisk-commits] alecdavis: branch 1.6.0 r249846 - /branches/1.6.0/apps/app_echo.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Tue Mar 2 03:16:06 CST 2010
Author: alecdavis
Date: Tue Mar 2 03:16:02 2010
New Revision: 249846
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=249846
Log:
fixes ability to exit echo app
when called from a ISDN channel, null frames prevent '#' exit.
Now only echo back VOICE and DTMF frames
(closes issue #16880)
Reported by: alecdavis
Patches:
based on echo_exit_1-6-1.diff.txt uploaded by alecdavis (license 585)
Tested by: alecdavis
Modified:
branches/1.6.0/apps/app_echo.c
Modified: branches/1.6.0/apps/app_echo.c
URL: http://svnview.digium.com/svn/asterisk/branches/1.6.0/apps/app_echo.c?view=diff&rev=249846&r1=249845&r2=249846
==============================================================================
--- branches/1.6.0/apps/app_echo.c (original)
+++ branches/1.6.0/apps/app_echo.c Tue Mar 2 03:16:02 2010
@@ -54,18 +54,26 @@
while (ast_waitfor(chan, -1) > -1) {
struct ast_frame *f = ast_read(chan);
- if (!f)
+ if (!f) {
break;
- f->delivery.tv_sec = 0;
- f->delivery.tv_usec = 0;
- if (ast_write(chan, f)) {
- ast_frfree(f);
- goto end;
}
- if ((f->frametype == AST_FRAME_DTMF) && (f->subclass == '#')) {
- res = 0;
- ast_frfree(f);
- goto end;
+ switch (f->frametype) {
+ case AST_FRAME_VOICE:
+ case AST_FRAME_DTMF:
+ f->delivery.tv_sec = 0;
+ f->delivery.tv_usec = 0;
+ if (ast_write(chan, f)) {
+ ast_frfree(f);
+ goto end;
+ }
+ if ((f->frametype == AST_FRAME_DTMF) && (f->subclass == '#')) {
+ res = 0;
+ ast_frfree(f);
+ goto end;
+ }
+ break;
+ default:
+ break;
}
ast_frfree(f);
}
More information about the asterisk-commits
mailing list