summaryrefslogtreecommitdiff
path: root/reference.go
diff options
context:
space:
mode:
authorCarlos Martín Nieto <[email protected]>2014-04-26 20:25:26 +0200
committerCarlos Martín Nieto <[email protected]>2014-04-26 20:25:26 +0200
commit605f942e940a7b69803030e8ca843fa0f94ae7d8 (patch)
tree9333add7e39257a178d56822ef6335b1d2de4b8d /reference.go
parent3cf0b6db80885c63986001f3217019bdf2295b71 (diff)
parenta7d3c5955ac9426dd57bf4d3df87ca1eba049789 (diff)
Merge pull request #66 from jezell/branch-iterator
Add branch iterator
Diffstat (limited to 'reference.go')
-rw-r--r--reference.go68
1 files changed, 29 insertions, 39 deletions
diff --git a/reference.go b/reference.go
index a7cc29e..98facc2 100644
--- a/reference.go
+++ b/reference.go
@@ -22,9 +22,8 @@ type Reference struct {
}
func newReferenceFromC(ptr *C.git_reference) *Reference {
- ref := &Reference{ptr}
+ ref := &Reference{ptr: ptr}
runtime.SetFinalizer(ref, (*Reference).Free)
-
return ref
}
@@ -190,6 +189,10 @@ type ReferenceIterator struct {
repo *Repository
}
+type ReferenceNameIterator struct {
+ *ReferenceIterator
+}
+
// NewReferenceIterator creates a new iterator over reference names
func (repo *Repository) NewReferenceIterator() (*ReferenceIterator, error) {
var ptr *C.git_reference_iterator
@@ -202,11 +205,28 @@ func (repo *Repository) NewReferenceIterator() (*ReferenceIterator, error) {
return nil, MakeGitError(ret)
}
- iter := &ReferenceIterator{repo: repo, ptr: ptr}
+ iter := &ReferenceIterator{ptr: ptr, repo: repo}
runtime.SetFinalizer(iter, (*ReferenceIterator).Free)
return iter, nil
}
+// NewReferenceIterator creates a new branch iterator over reference names
+func (repo *Repository) NewReferenceNameIterator() (*ReferenceNameIterator, error) {
+ var ptr *C.git_reference_iterator
+
+ runtime.LockOSThread()
+ defer runtime.UnlockOSThread()
+
+ ret := C.git_reference_iterator_new(&ptr, repo.ptr)
+ if ret < 0 {
+ return nil, MakeGitError(ret)
+ }
+
+ iter := &ReferenceIterator{ptr: ptr, repo: repo}
+ runtime.SetFinalizer(iter, (*ReferenceIterator).Free)
+ return iter.Names(), nil
+}
+
// NewReferenceIteratorGlob creates an iterator over reference names
// that match the speicified glob. The glob is of the usual fnmatch
// type.
@@ -223,14 +243,18 @@ func (repo *Repository) NewReferenceIteratorGlob(glob string) (*ReferenceIterato
return nil, MakeGitError(ret)
}
- iter := &ReferenceIterator{repo: repo, ptr: ptr}
+ iter := &ReferenceIterator{ptr: ptr}
runtime.SetFinalizer(iter, (*ReferenceIterator).Free)
return iter, nil
}
+func (i *ReferenceIterator) Names() *ReferenceNameIterator {
+ return &ReferenceNameIterator{i}
+}
+
// NextName retrieves the next reference name. If the iteration is over,
// the returned error is git.ErrIterOver
-func (v *ReferenceIterator) NextName() (string, error) {
+func (v *ReferenceNameIterator) Next() (string, error) {
var ptr *C.char
runtime.LockOSThread()
@@ -244,23 +268,6 @@ func (v *ReferenceIterator) NextName() (string, error) {
return C.GoString(ptr), nil
}
-// Create a channel from the iterator. You can use range on the
-// returned channel to iterate over all the references names. The channel
-// will be closed in case any error is found.
-func (v *ReferenceIterator) NameIter() <-chan string {
- ch := make(chan string)
- go func() {
- defer close(ch)
- name, err := v.NextName()
- for err == nil {
- ch <- name
- name, err = v.NextName()
- }
- }()
-
- return ch
-}
-
// Next retrieves the next reference. If the iterationis over, the
// returned error is git.ErrIterOver
func (v *ReferenceIterator) Next() (*Reference, error) {
@@ -273,23 +280,6 @@ func (v *ReferenceIterator) Next() (*Reference, error) {
return newReferenceFromC(ptr), nil
}
-// Create a channel from the iterator. You can use range on the
-// returned channel to iterate over all the references names. The channel
-// will be closed in case any error is found.
-func (v *ReferenceIterator) Iter() <-chan *Reference {
- ch := make(chan *Reference)
- go func() {
- defer close(ch)
- name, err := v.Next()
- for err == nil {
- ch <- name
- name, err = v.Next()
- }
- }()
-
- return ch
-}
-
// Free the reference iterator
func (v *ReferenceIterator) Free() {
runtime.SetFinalizer(v, nil)