From 73de59a615256579502f27f360ee358c7e3d9119 Mon Sep 17 00:00:00 2001 From: klauspost Date: Mon, 17 Aug 2015 11:01:24 +0200 Subject: [PATCH] Make check for non-existing paths OS independent. --- restorer.go | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/restorer.go b/restorer.go index 524a9c734..d9c6ba0e3 100644 --- a/restorer.go +++ b/restorer.go @@ -4,7 +4,6 @@ import ( "fmt" "os" "path/filepath" - "syscall" "github.com/restic/restic/backend" "github.com/restic/restic/debug" @@ -96,16 +95,13 @@ func (res *Restorer) restoreNodeTo(node *Node, dir string, dst string) error { } // Did it fail because of ENOENT? - if pe, ok := errors.Cause(err).(*os.PathError); ok { - errn, ok := pe.Err.(syscall.Errno) - if ok && errn == syscall.ENOENT { - debug.Log("Restorer.restoreNodeTo", "create intermediate paths") + if err != nil && os.IsNotExist(errors.Cause(err)) { + debug.Log("Restorer.restoreNodeTo", "create intermediate paths") - // Create parent directories and retry - err = os.MkdirAll(filepath.Dir(dstPath), 0700) - if err == nil || err == os.ErrExist { - err = node.CreateAt(dstPath, res.repo) - } + // Create parent directories and retry + err = os.MkdirAll(filepath.Dir(dstPath), 0700) + if err == nil || err == os.ErrExist { + err = node.CreateAt(dstPath, res.repo) } }