Skip to content

Commit

Permalink
Fix hook reader to seek source and hook appropriately (#1070)
Browse files Browse the repository at this point in the history
  • Loading branch information
harshavardhana authored and kannappanr committed Feb 7, 2019
1 parent a46b067 commit 34f2b94
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions hook-reader.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,10 @@

package minio

import "io"
import (
"fmt"
"io"
)

// hookReader hooks additional reader in the source stream. It is
// useful for making progress bars. Second reader is appropriately
Expand All @@ -34,12 +37,23 @@ func (hr *hookReader) Seek(offset int64, whence int) (n int64, err error) {
// Verify for source has embedded Seeker, use it.
sourceSeeker, ok := hr.source.(io.Seeker)
if ok {
return sourceSeeker.Seek(offset, whence)
n, err = sourceSeeker.Seek(offset, whence)
if err != nil {
return 0, err
}
}

// Verify if hook has embedded Seeker, use it.
hookSeeker, ok := hr.hook.(io.Seeker)
if ok {
return hookSeeker.Seek(offset, whence)
var m int64
m, err = hookSeeker.Seek(offset, whence)
if err != nil {
return 0, err
}
if n != m {
return 0, fmt.Errorf("hook seeker seeked %d bytes, expected source %d bytes", m, n)
}
}
return n, nil
}
Expand Down

0 comments on commit 34f2b94

Please sign in to comment.