blob: 7151b41098c5db1cfa3bf74c05b7a6c4a3ee7a45 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
package gitpipe
import (
"context"
"gitlab.com/gitlab-org/gitaly/internal/git"
)
// RevisionIterator is an iterator returned by the Revlist function.
type RevisionIterator interface {
ObjectIterator
// Result returns the current item.
Result() RevisionResult
}
// NewRevisionIterator returns a new RevisionIterator for the given items.
func NewRevisionIterator(ctx context.Context, items []RevisionResult) RevisionIterator {
itemChan := make(chan RevisionResult, len(items))
for _, item := range items {
itemChan <- item
}
close(itemChan)
return &revisionIterator{
ctx: ctx,
ch: itemChan,
}
}
type revisionIterator struct {
ctx context.Context
ch <-chan RevisionResult
result RevisionResult
}
func (it *revisionIterator) Next() bool {
if it.result.err != nil {
return false
}
// Prioritize context cancellation errors so that we don't try to fetch results anymore when
// the context is done.
select {
case <-it.ctx.Done():
it.result = RevisionResult{err: it.ctx.Err()}
return false
default:
}
select {
case <-it.ctx.Done():
it.result = RevisionResult{err: it.ctx.Err()}
return false
case result, ok := <-it.ch:
if !ok {
return false
}
it.result = result
if result.err != nil {
return false
}
return true
}
}
func (it *revisionIterator) Err() error {
return it.result.err
}
func (it *revisionIterator) Result() RevisionResult {
return it.result
}
func (it *revisionIterator) ObjectID() git.ObjectID {
return it.result.OID
}
func (it *revisionIterator) ObjectName() []byte {
return it.result.ObjectName
}
|