From c52f95e5c59439bb2438b2433e73b112f55318a7 Mon Sep 17 00:00:00 2001 From: dev Date: Mon, 18 Oct 2021 15:41:56 +0000 Subject: [PATCH] Improve error handling for writefile() git-svn-id: file:///srv/svn/repo/marisa/trunk@19 d6811dac-2434-b64a-9ddc-f563ab233461 --- partage.go | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/partage.go b/partage.go index 8f620d6..7af76cd 100644 --- a/partage.go +++ b/partage.go @@ -44,7 +44,7 @@ func contenttype(f *os.File) string { return mime } -func writefile(f *os.File, s io.ReadCloser, contentlength int64) int64 { +func writefile(f *os.File, s io.ReadCloser, contentlength int64) error { buffer := make([]byte, 4096) eof := false sz := int64(0) @@ -54,8 +54,7 @@ func writefile(f *os.File, s io.ReadCloser, contentlength int64) int64 { for !eof { n, err := s.Read(buffer) if err != nil && err != io.EOF { - fmt.Println(err) - return -1 + return err } else if err == io.EOF { eof = true } @@ -69,12 +68,12 @@ func writefile(f *os.File, s io.ReadCloser, contentlength int64) int64 { _, err = f.Write(buffer[:r]) if err != nil { - fmt.Println(err) + return err } sz += r } - return sz + return nil } func servetemplate(w http.ResponseWriter, f string, d templatedata) { @@ -105,8 +104,9 @@ func uploaderPut(w http.ResponseWriter, r *http.Request) { } defer f.Close() - if writefile(f, r.Body, r.ContentLength) < 0 { + if err = writefile(f, r.Body, r.ContentLength); err != nil { w.WriteHeader(http.StatusInternalServerError) + defer os.Remove(tmp.Name()) return } @@ -141,8 +141,9 @@ func uploaderPost(w http.ResponseWriter, r *http.Request) { } defer f.Close() - if writefile(f, post, h.Size) < 0 { + if err = writefile(f, post, h.Size); err != nil { w.WriteHeader(http.StatusInternalServerError) + defer os.Remove(tmp.Name()) return }