mark2web/vendor/github.com/otiai10/copy
Sebastian Frank a781485c0a
Some checks failed
continuous-integration/drone/push Build is failing
no git submodules
2022-02-28 10:28:34 +01:00
..
.gitignore no git submodules 2022-02-28 10:28:34 +01:00
copy_namedpipes_x.go no git submodules 2022-02-28 10:28:34 +01:00
copy_namedpipes.go no git submodules 2022-02-28 10:28:34 +01:00
copy.go no git submodules 2022-02-28 10:28:34 +01:00
fileinfo.go no git submodules 2022-02-28 10:28:34 +01:00
go.mod no git submodules 2022-02-28 10:28:34 +01:00
go.sum no git submodules 2022-02-28 10:28:34 +01:00
LICENSE no git submodules 2022-02-28 10:28:34 +01:00
options.go no git submodules 2022-02-28 10:28:34 +01:00
preserve_owner_windows.go no git submodules 2022-02-28 10:28:34 +01:00
preserve_owner.go no git submodules 2022-02-28 10:28:34 +01:00
preserve_times.go no git submodules 2022-02-28 10:28:34 +01:00
README.md no git submodules 2022-02-28 10:28:34 +01:00
stat_times_darwin.go no git submodules 2022-02-28 10:28:34 +01:00
stat_times_freebsd.go no git submodules 2022-02-28 10:28:34 +01:00
stat_times_windows.go no git submodules 2022-02-28 10:28:34 +01:00
stat_times_x.go no git submodules 2022-02-28 10:28:34 +01:00
stat_times.go no git submodules 2022-02-28 10:28:34 +01:00
test_setup_x.go no git submodules 2022-02-28 10:28:34 +01:00
test_setup.go no git submodules 2022-02-28 10:28:34 +01:00

copy

Go Reference Actions Status codecov License: MIT FOSSA Status CodeQL Go Report Card GitHub tag (latest SemVer) Docker Test Vagrant Test

copy copies directories recursively.

Example Usage

err := Copy("your/directory", "your/directory.copy")

Advanced Usage

// 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

	// Skip can specify which files should be skipped
	Skip func(src string) (bool, error)

	// AddPermission to every entry,
	// NO MORE THAN 0777
	AddPermission os.FileMode

	// 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
}
// For example...
opt := Options{
	Skip: func(src string) (bool, error) {
		return strings.HasSuffix(src, ".git"), nil
	},
}
err := Copy("your/directory", "your/directory.copy", opt)

Issues

License

FOSSA Status