Merge pull request #6 from SunRunAway/feature/fix_ReadCodeLine

doing ReadCodeLine in Close() @ ReadCloser
This commit is contained in:
Julien Laffaye 2013-07-10 11:23:31 -07:00
commit 188465df99
2 changed files with 14 additions and 7 deletions

View File

@ -57,6 +57,13 @@ func TestConn(t *testing.T) {
r.Close() r.Close()
} }
r, err = c.Retr("tset")
if err != nil {
t.Error(err)
} else {
r.Close()
}
err = c.Delete("tset") err = c.Delete("tset")
if err != nil { if err != nil {
t.Error(err) t.Error(err)

14
ftp.go
View File

@ -405,16 +405,16 @@ func (c *ServerConn) Quit() error {
// Read implements the io.Reader interface on a FTP data connection. // Read implements the io.Reader interface on a FTP data connection.
func (r *response) Read(buf []byte) (int, error) { func (r *response) Read(buf []byte) (int, error) {
n, err := r.conn.Read(buf) n, err := r.conn.Read(buf)
if err == io.EOF {
_, _, err2 := r.c.conn.ReadCodeLine(StatusClosingDataConnection)
if err2 != nil {
err = err2
}
}
return n, err return n, err
} }
// Close implements the io.Closer interface on a FTP data connection. // Close implements the io.Closer interface on a FTP data connection.
func (r *response) Close() error { func (r *response) Close() error {
return r.conn.Close() err := r.conn.Close()
_, _, err2 := r.c.conn.ReadCodeLine(StatusClosingDataConnection)
if err2 != nil {
err = err2
} }
return err
}