From 911de8d19662d1a3afa65f40fb05f40715a997c6 Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Sun, 3 Apr 2016 03:08:45 +0900 Subject: [PATCH] audio: Refactoring: Remove Loop.pos --- exp/audio/loop.go | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/exp/audio/loop.go b/exp/audio/loop.go index 955025af2..fb1a8f603 100644 --- a/exp/audio/loop.go +++ b/exp/audio/loop.go @@ -21,7 +21,6 @@ import ( type Loop struct { stream ReadSeekCloser size int64 - pos int64 } func NewLoop(stream ReadSeekCloser, size int64) ReadSeekCloser { @@ -33,8 +32,6 @@ func NewLoop(stream ReadSeekCloser, size int64) ReadSeekCloser { func (l *Loop) Read(b []byte) (int, error) { n, err := l.stream.Read(b) - l.pos += int64(n) - l.pos %= l.size if err == io.EOF { if _, err := l.Seek(0, 0); err != nil { return 0, err @@ -50,7 +47,11 @@ func (l *Loop) Seek(offset int64, whence int) (int64, error) { case 0: next = offset case 1: - next = int64(l.pos) + offset + current, err := l.stream.Seek(0, 1) + if err != nil { + return 0, err + } + next = current + offset case 2: panic("audio: whence must be 0 or 1 for a loop stream") } @@ -59,8 +60,7 @@ func (l *Loop) Seek(offset int64, whence int) (int64, error) { if err != nil { return 0, err } - l.pos = pos - return l.pos, nil + return pos, nil } func (l *Loop) Close() error {