Fixed Read, removed ReadAt

ReadAt should be replaced by Seek when the fs interface provides it.
This commit is contained in:
Dave Cheney 2013-11-15 22:04:14 +11:00
parent fd27263026
commit b8aa2fe3d1
2 changed files with 11 additions and 47 deletions

View File

@ -493,18 +493,17 @@ func (f *File) Close() error {
// bytes read and an error, if any. EOF is signaled by a zero count with // bytes read and an error, if any. EOF is signaled by a zero count with
// err set to io.EOF. // err set to io.EOF.
func (f *File) Read(b []byte) (int, error) { func (f *File) Read(b []byte) (int, error) {
n, err := f.c.readAt(f.handle, f.offset, b) var read int
f.offset += uint64(n) for len(b) > 0 {
return int(n), err n, err := f.c.readAt(f.handle, f.offset, b[:min(len(b), maxWritePacket)])
} f.offset += uint64(n)
read += int(n)
// ReadAt reads len(b) bytes from the File starting at byte offset off. It if err != nil {
// returns the number of bytes read and the error, if any. ReadAt always return read, err
// returns a non-nil error when n < len(b). At end of file, that error is }
// io.EOF. b = b[n:]
func (f *File) ReadAt(b []byte, off int64) (int, error) { }
n, err := f.c.readAt(f.handle, uint64(off), b) return read, nil
return int(n), err
} }
// Stat returns the FileInfo structure describing file. If there is an // Stat returns the FileInfo structure describing file. If there is an

View File

@ -146,41 +146,6 @@ var readAtTests = []struct {
{"Hello world!", 12, "", io.EOF}, {"Hello world!", 12, "", io.EOF},
} }
func TestClientReadAt(t *testing.T) {
sftp, cmd := testClient(t, READONLY)
defer cmd.Wait()
defer sftp.Close()
for _, tt := range readAtTests {
f, err := ioutil.TempFile("", "sftptest")
if err != nil {
t.Fatal(err)
}
defer os.Remove(f.Name())
if _, err := f.WriteString(tt.s); err != nil {
t.Fatal(err)
}
if err := f.Close(); err != nil {
t.Fatal(err)
}
got, err := sftp.Open(f.Name())
if err != nil {
t.Fatal(err)
}
defer got.Close()
var b = make([]byte, 100)
n, err := got.ReadAt(b, tt.at)
b = b[:n]
if want, got := tt.want, string(b); got != want || tt.err != err {
t.Fatalf("Read(): want %q %v, got %q %v", want, tt.err, got, err)
}
}
}
func TestClientCreate(t *testing.T) { func TestClientCreate(t *testing.T) {
sftp, cmd := testClient(t, READWRITE) sftp, cmd := testClient(t, READWRITE)
defer cmd.Wait() defer cmd.Wait()