summaryrefslogtreecommitdiff
path: root/formats/format_pcm.c
diff options
context:
space:
mode:
authorMartin Pycko <martinp@digium.com>2003-08-28 20:02:10 +0000
committerMartin Pycko <martinp@digium.com>2003-08-28 20:02:10 +0000
commitf14004abfd974a328736442971caee22053cfeec (patch)
tree457a4a3e8dec7fcff81b0a750356704758734e0c /formats/format_pcm.c
parent3ee27a8a8992dce78c0bf062d32ef7034d98b555 (diff)
Fix synchronization of recorded files when using Monitor application
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1446 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'formats/format_pcm.c')
-rwxr-xr-xformats/format_pcm.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/formats/format_pcm.c b/formats/format_pcm.c
index ebc9bf87a..038de171d 100755
--- a/formats/format_pcm.c
+++ b/formats/format_pcm.c
@@ -163,14 +163,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);
}