aboutsummaryrefslogtreecommitdiffstats
path: root/file.go
diff options
context:
space:
mode:
authorSantiago M. Mola <santi@mola.io>2016-12-14 23:12:44 +0100
committerMáximo Cuadros <mcuadros@gmail.com>2016-12-14 23:12:44 +0100
commit0af572dd21c0aa79d13745b633ee24ba6c4d6cf1 (patch)
tree49e81e74e82d84fd88b2fc1e4b0dc7c7bfe9c40f /file.go
parentdf0f38af83f972f026d7e14150f3d37b95f13484 (diff)
downloadgo-git-0af572dd21c0aa79d13745b633ee24ba6c4d6cf1.tar.gz
move plumbing from top level package to plumbing (#183)
* plumbing: rename Object -> EncodedObject. * plumbing/storer: rename ObjectStorer -> EncodedObjectStorer. * move difftree to plumbing/difftree. * move diff -> utils/diff * make Object/Tag/Blob/Tree/Commit/File depend on storer. * Object and its implementations now depend only on storer.EncodedObjectStorer, not git.Repository. * Tests are decoupled accordingly. * move Object/Commit/File/Tag/Tree to plumbing/object. * move Object/Commit/File/Tag/Tree to plumbing/object. * move checkClose to utils/ioutil. * move RevListObjects to plumbing/revlist.Objects. * move DiffTree to plumbing/difftree package. * rename files with plural nouns to singular * plumbing/object: add GetBlob/GetCommit/GetTag/GetTree.
Diffstat (limited to 'file.go')
-rw-r--r--file.go115
1 files changed, 0 insertions, 115 deletions
diff --git a/file.go b/file.go
deleted file mode 100644
index e735723..0000000
--- a/file.go
+++ /dev/null
@@ -1,115 +0,0 @@
-package git
-
-import (
- "bytes"
- "io"
- "os"
- "strings"
-
- "gopkg.in/src-d/go-git.v4/plumbing/storer"
-)
-
-// File represents git file objects.
-type File struct {
- Name string
- Mode os.FileMode
- Blob
-}
-
-// NewFile returns a File based on the given blob object
-func NewFile(name string, m os.FileMode, b *Blob) *File {
- return &File{Name: name, Mode: m, Blob: *b}
-}
-
-// Contents returns the contents of a file as a string.
-func (f *File) Contents() (content string, err error) {
- reader, err := f.Reader()
- if err != nil {
- return "", err
- }
- defer checkClose(reader, &err)
-
- buf := new(bytes.Buffer)
- if _, err := buf.ReadFrom(reader); err != nil {
- return "", err
- }
-
- return buf.String(), nil
-}
-
-// Lines returns a slice of lines from the contents of a file, stripping
-// all end of line characters. If the last line is empty (does not end
-// in an end of line), it is also stripped.
-func (f *File) Lines() ([]string, error) {
- content, err := f.Contents()
- if err != nil {
- return nil, err
- }
-
- splits := strings.Split(content, "\n")
- // remove the last line if it is empty
- if splits[len(splits)-1] == "" {
- return splits[:len(splits)-1], nil
- }
-
- return splits, nil
-}
-
-type FileIter struct {
- r *Repository
- w TreeWalker
-}
-
-func NewFileIter(r *Repository, t *Tree) *FileIter {
- return &FileIter{r: r, w: *NewTreeWalker(r, t, true)}
-}
-
-func (iter *FileIter) Next() (*File, error) {
- for {
- name, entry, err := iter.w.Next()
- if err != nil {
- return nil, err
- }
-
- if entry.Mode.IsDir() {
- continue
- }
-
- blob, err := iter.r.Blob(entry.Hash)
- if err != nil {
- return nil, err
- }
-
- return NewFile(name, entry.Mode, blob), nil
- }
-}
-
-// ForEach call the cb function for each file contained on this iter until
-// an error happends or the end of the iter is reached. If plumbing.ErrStop is sent
-// the iteration is stop but no error is returned. The iterator is closed.
-func (iter *FileIter) ForEach(cb func(*File) error) error {
- defer iter.Close()
-
- for {
- f, err := iter.Next()
- if err != nil {
- if err == io.EOF {
- return nil
- }
-
- return err
- }
-
- if err := cb(f); err != nil {
- if err == storer.ErrStop {
- return nil
- }
-
- return err
- }
- }
-}
-
-func (iter *FileIter) Close() {
- iter.w.Close()
-}