diff options
author | file <file@f38db490-d61c-443f-a65b-d21fe96a405b> | 2007-05-24 22:16:58 +0000 |
---|---|---|
committer | file <file@f38db490-d61c-443f-a65b-d21fe96a405b> | 2007-05-24 22:16:58 +0000 |
commit | 1984fd50d376d55715e71ecbf0bb088ac918ed5a (patch) | |
tree | 023084fc00e3250c5672565cfbe2b1f87415d30f /main/slinfactory.c | |
parent | 0c084811efd1bba517e754aec36123eefccca669 (diff) |
Fix slinfactory logic when dealing with frames coming in that may already be in the signed linear format.
git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.4@66074 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main/slinfactory.c')
-rw-r--r-- | main/slinfactory.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/main/slinfactory.c b/main/slinfactory.c index 6171eb2e2..5061a609e 100644 --- a/main/slinfactory.c +++ b/main/slinfactory.c @@ -72,11 +72,13 @@ int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f) sf->format = f->subclass; } } + if (!(begin_frame = ast_translate(sf->trans, f, 0)) || !(duped_frame = ast_frdup(begin_frame))) + return 0; + } else { + if (!(duped_frame = ast_frdup(f))) + return 0; } - if ((sf->trans && (!(begin_frame = ast_translate(sf->trans, f, 0)))) || (!(duped_frame = ast_frdup(begin_frame)))) - return 0; - x = 0; AST_LIST_TRAVERSE(&sf->queue, frame_ptr, frame_list) x++; |