You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tea/vendor/gopkg.in/src-d/go-billy.v4
6543 3d128cfc69 changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
..
helper changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
osfs changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
util changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
.gitignore changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
.travis.yml changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
DCO changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
LICENSE changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
MAINTAINERS changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
Makefile changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
README.md changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
appveyor.yml changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
fs.go changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
go.mod changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago
go.sum changed git config determination to go-git (#41) [continue #45] (#62) 5 years ago

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