diff options
author | martinp <martinp@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-08-28 20:02:10 +0000 |
---|---|---|
committer | martinp <martinp@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-08-28 20:02:10 +0000 |
commit | 0f7540708770a2ddd4c5afcb057e9ab89e658d3b (patch) | |
tree | 457a4a3e8dec7fcff81b0a750356704758734e0c /formats/format_pcm_alaw.c | |
parent | a5c52defec739c228fbc6e9c9bbfd79bbf57c04e (diff) |
Fix synchronization of recorded files when using Monitor application
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1446 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'formats/format_pcm_alaw.c')
-rwxr-xr-x | formats/format_pcm_alaw.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/formats/format_pcm_alaw.c b/formats/format_pcm_alaw.c index 8e96b41af..54d79bb29 100755 --- a/formats/format_pcm_alaw.c +++ b/formats/format_pcm_alaw.c @@ -242,14 +242,16 @@ static int pcm_seek(struct ast_filestream *fs, long sample_offset, int whence) min = 0; cur = lseek(fs->fd, 0, SEEK_CUR); max = lseek(fs->fd, 0, SEEK_END); - if(whence == SEEK_SET) + if (whence == SEEK_SET) offset = sample_offset; - if(whence == SEEK_CUR) + else if (whence == SEEK_CUR || whence == SEEK_FORCECUR) offset = sample_offset + cur; - if(whence == SEEK_END) + else if (whence == SEEK_END) offset = max - sample_offset; - offset = (offset > max)?max:offset; - offset = (offset < min)?min:offset; + if (whence != SEEK_FORCECUR) { + offset = (offset > max)?max:offset; + offset = (offset < min)?min:offset; + } return lseek(fs->fd, offset, SEEK_SET); } |