From 939b71c6c73b4f633d34c8e0c77e8a49b94ae0cc Mon Sep 17 00:00:00 2001 From: tongjingran Date: Wed, 23 Dec 2020 20:19:56 +0800 Subject: [PATCH] add fileinfo to skip function --- all_test.go | 2 +- copy.go | 2 +- options.go | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/all_test.go b/all_test.go index 1dff150..d33e64d 100644 --- a/all_test.go +++ b/all_test.go @@ -152,7 +152,7 @@ func TestOptions_OnSymlink(t *testing.T) { } func TestOptions_Skip(t *testing.T) { - opt := Options{Skip: func(src string) (bool, error) { + opt := Options{Skip: func(src string, info os.FileInfo) (bool, error) { switch { case strings.HasSuffix(src, "_skip"): return true, nil diff --git a/copy.go b/copy.go index f2a6e12..fea6a52 100644 --- a/copy.go +++ b/copy.go @@ -60,7 +60,7 @@ func switchboard(src, dest string, info os.FileInfo, opt Options) (err error) { // Because this "copy" could be called recursively, // "info" MUST be given here, NOT nil. func copy(src, dest string, info os.FileInfo, opt Options) error { - skip, err := opt.Skip(src) + skip, err := opt.Skip(src, info) if err != nil { return err } diff --git a/options.go b/options.go index 88b9f5d..77587c1 100644 --- a/options.go +++ b/options.go @@ -12,7 +12,7 @@ type Options struct { OnDirExists func(src, dest string) DirExistsAction // Skip can specify which files should be skipped - Skip func(src string) (bool, error) + Skip func(src string, info os.FileInfo) (bool, error) // AddPermission to every entities, // NO MORE THAN 0777 @@ -66,7 +66,7 @@ func getDefaultOptions(src, dest string) Options { return Shallow // Do shallow copy }, OnDirExists: nil, // Default behavior is "Merge". - Skip: func(string) (bool, error) { + Skip: func(string, os.FileInfo) (bool, error) { return false, nil // Don't skip }, AddPermission: 0, // Add nothing