git-sync/vendor/gopkg.in/src-d/go-billy.v4
Tim Hockin b161f3f0c7 Add infrastructure for build tools
As per discussion with Go team.  it's hacky but it works.

create tools.go
git add tools.go
go mod vendor
git add vendor
go mod tidy
go mod vendor # again
2021-03-29 16:35:13 -07:00
..
helper Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
osfs Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
util Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
.gitignore Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
.travis.yml Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
DCO Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
LICENSE Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
MAINTAINERS Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
Makefile Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
README.md Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
appveyor.yml Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
fs.go Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
go.mod Add infrastructure for build tools 2021-03-29 16:35:13 -07:00
go.sum Add infrastructure for build tools 2021-03-29 16:35:13 -07:00

README.md

go-billy GoDoc Build Status Build status codecov

The missing interface filesystem abstraction for Go. Billy implements an interface based on the os standard library, allowing to develop applications without dependency on the underlying storage. Makes it virtually free to implement mocks and testing over filesystem operations.

Billy was born as part of src-d/go-git project.

Installation

go get -u gopkg.in/src-d/go-billy.v4/...

Usage

Billy exposes filesystems using the Filesystem interface. Each filesystem implementation gives you a New method, whose arguments depend on the implementation itself, that returns a new Filesystem.

The following example caches in memory all readable files in a directory from any billy's filesystem implementation.

func LoadToMemory(origin billy.Filesystem, path string) (*memory.Memory, error) {
	memory := memory.New()

	files, err := origin.ReadDir("/")
	if err != nil {
		return nil, err
	}

	for _, file := range files {
		if file.IsDir() {
			continue
		}

		src, err := origin.Open(file.Name())
		if err != nil {
			return nil, err
		}

		dst, err := memory.Create(file.Name())
		if err != nil {
			return nil, err
		}

		if _, err = io.Copy(dst, src); err != nil {
			return nil, err
		}

		if err := dst.Close(); err != nil {
			return nil, err
		}

		if err := src.Close(); err != nil {
			return nil, err
		}
	}

	return memory, nil
}

Why billy?

The library billy deals with storage systems and Billy is the name of a well-known, IKEA bookcase. That's it.

License

Apache License Version 2.0, see LICENSE