From 2afa4302ea52b2f14b5250490eb47b138d7cf267 Mon Sep 17 00:00:00 2001 From: Kit Patella Date: Tue, 1 Oct 2024 14:15:49 -0700 Subject: [PATCH] fix: if the file is already closed, don't join to err return Signed-off-by: Kit Patella --- src/pkg/layout/split.go | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/pkg/layout/split.go b/src/pkg/layout/split.go index 97a322d7e3..3354a66038 100644 --- a/src/pkg/layout/split.go +++ b/src/pkg/layout/split.go @@ -26,7 +26,10 @@ func splitFile(srcPath string, chunkSize int) (err error) { // Ensure we close our sourcefile, even if we error out. defer func() { err2 := srcFile.Close() - err = errors.Join(err, err2) + // Ignore if file is already closed + if !errors.Is(err2, os.ErrClosed) { + err = errors.Join(err, err2) + } }() fi, err := srcFile.Stat() @@ -53,7 +56,10 @@ func splitFile(srcPath string, chunkSize int) (err error) { } defer func(dstFile *os.File) { err2 := dstFile.Close() - err = errors.Join(err, err2) + // Ignore if file is already closed + if !errors.Is(err2, os.ErrClosed) { + err = errors.Join(err, err2) + } }(dstFile) written, copyErr := io.CopyN(dstFile, srcFile, int64(chunkSize))