| commit | 5ef5923d6ff098ea7a51792c1ec963d04fad9794 | [log] [tgz] |
|---|---|---|
| author | Hiromu OCHIAI <otiai10@gmail.com> | Sun Jan 05 09:27:25 2025 |
| committer | Hiromu OCHIAI <otiai10@gmail.com> | Sun Jan 05 09:29:22 2025 |
| tree | e7d31e623dab35021540a760b166b118a7e1e628 | |
| parent | 49b0b590f1e1dce6302b9015a46ea0de5d93c78f [diff] |
Revert "CopyMethod" since it's not ready Revert "ci: Allow triggering Go workflow manually" This reverts commit f530620eff26f3b41da4b39cf1644fd2b2077a81. Revert "refactor: Split common code out of CopyBytes" This reverts commit b4dd78950409e635a944027f57004cb58416e9eb. Revert "feat: Add FileCopyMethod option / API" This reverts commit 920581318a1a1b5f4cedabc45dd0eef30382f5fe.
copy copies directories recursively.
package main import ( "fmt" cp "github.com/otiai10/copy" ) func main() { err := cp.Copy("your/src", "your/dest") fmt.Println(err) // nil }
// Options specifies optional actions on copying. type Options struct { // OnSymlink can specify what to do on symlink OnSymlink func(src string) SymlinkAction // OnDirExists can specify what to do when there is a directory already existing in destination. OnDirExists func(src, dest string) DirExistsAction // OnError can let users decide how to handle errors (e.g., you can suppress specific error). OnError func(src, dest, string, err error) error // Skip can specify which files should be skipped Skip func(srcinfo os.FileInfo, src, dest string) (bool, error) // RenameDestination can rename destination. // If not set, nil, it does nothing. RenameDestination func(src, dest string) (string, error) // PermissionControl can control permission of // every entry. // When you want to add permission 0222, do like // // PermissionControl = AddPermission(0222) // // or if you even don't want to touch permission, // // PermissionControl = DoNothing // // By default, PermissionControl = PreservePermission PermissionControl PermissionControlFunc // Sync file after copy. // Useful in case when file must be on the disk // (in case crash happens, for example), // at the expense of some performance penalty Sync bool // Preserve the atime and the mtime of the entries // On linux we can preserve only up to 1 millisecond accuracy PreserveTimes bool // Preserve the uid and the gid of all entries. PreserveOwner bool // The byte size of the buffer to use for copying files. // If zero, the internal default buffer of 32KB is used. // See https://golang.org/pkg/io/#CopyBuffer for more information. CopyBufferSize uint // If you want to add some limitation on reading src file, // you can wrap the src and provide new reader, // such as `RateLimitReader` in the test case. WrapReader func(src io.Reader) io.Reader // If given, copy.Copy refers to this fs.FS instead of the OS filesystem. // e.g., You can use embed.FS to copy files from embedded filesystem. FS fs.FS // NumOfWorkers represents the number of workers used for // concurrent copying contents of directories. // If 0 or 1, it does not use goroutine for copying directories. // Please refer to https://pkg.go.dev/golang.org/x/sync/semaphore for more details. NumOfWorkers int64 // PreferConcurrent is a function to determine whether or not // to use goroutine for copying contents of directories. // If PreferConcurrent is nil, which is default, it does concurrent // copying for all directories. // If NumOfWorkers is 0 or 1, this function will be ignored. PreferConcurrent func(srcdir, destdir string) (bool, error) }
// For example... opt := Options{ Skip: func(info os.FileInfo, src, dest string) (bool, error) { return strings.HasSuffix(src, ".git"), nil }, } err := Copy("your/directory", "your/directory.copy", opt)