1
0
mirror of https://github.com/MontFerret/ferret.git synced 2025-01-04 03:02:02 +02:00
ferret/pkg/runtime/collections/unique.go
2018-10-28 01:45:26 -04:00

59 lines
962 B
Go

package collections
import (
"context"
"github.com/MontFerret/ferret/pkg/runtime/core"
)
type (
UniqueIterator struct {
values Iterator
hashes map[uint64]bool
hashKey string
}
)
func NewUniqueIterator(values Iterator, hashKey string) (*UniqueIterator, error) {
if values == nil {
return nil, core.Error(core.ErrMissedArgument, "source")
}
return &UniqueIterator{
values: values,
hashes: make(map[uint64]bool),
hashKey: hashKey,
}, nil
}
func (iterator *UniqueIterator) Next(ctx context.Context, scope *core.Scope) (*core.Scope, error) {
for {
nextScope, err := iterator.values.Next(ctx, scope.Fork())
if err != nil {
return nil, err
}
if nextScope == nil {
return nil, nil
}
v, err := nextScope.GetVariable(iterator.hashKey)
if err != nil {
return nil, err
}
h := v.Hash()
_, exists := iterator.hashes[h]
if exists {
continue
}
iterator.hashes[h] = true
return nextScope, nil
}
}