From 6dc4e20e4ed3352247b3bfa34fdabe4050c935f4 Mon Sep 17 00:00:00 2001 From: arthurkushman Date: Mon, 8 Apr 2024 21:02:48 +0300 Subject: [PATCH] #71: Fix deferred error checks --- files.go | 7 ++++++- request.go | 23 ++++++++++++++++++++--- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/files.go b/files.go index af9e1c9..9c77b7a 100644 --- a/files.go +++ b/files.go @@ -144,7 +144,12 @@ func FilePutContents(fileName, data string, flags ...interface{}) (int, error) { } f, err := os.OpenFile(fileName, v|os.O_WRONLY, 0644) - defer f.Close() + defer func(f *os.File) { + err = f.Close() + if err != nil { + fmt.Println(err) + } + }(f) if err != nil { return -1, err diff --git a/request.go b/request.go index f98621b..c8984fe 100644 --- a/request.go +++ b/request.go @@ -4,6 +4,7 @@ import ( "bytes" "fmt" "io" + "mime/multipart" "net/http" "os" ) @@ -27,7 +28,12 @@ func (c *Context) doRequest(path string) (string, error) { return "", err } - defer resp.Body.Close() + defer func(body io.ReadCloser) { + err = body.Close() + if err != nil { + fmt.Println(err) + } + }(resp.Body) content, cErr := io.ReadAll(resp.Body) @@ -56,7 +62,12 @@ func (c *Context) uploadFile(fieldName, filePath string) bool { return false } - defer file.Close() + defer func(file multipart.File) { + err = file.Close() + if err != nil { + fmt.Println(err) + } + }(file) f, err := os.OpenFile(filePath, os.O_WRONLY|os.O_CREATE, 0666) if err != nil { @@ -64,7 +75,13 @@ func (c *Context) uploadFile(fieldName, filePath string) bool { return false } - defer f.Close() + defer func(f *os.File) { + err = f.Close() + if err != nil { + fmt.Println(err) + } + }(f) + _, err = io.Copy(f, file) if err != nil { fmt.Println(err)