2020-05-18 10:19:01 +00:00
|
|
|
/*
|
|
|
|
Package enumerator provides functions to work with enumerators.
|
|
|
|
*/
|
2018-08-31 08:23:57 +00:00
|
|
|
package enumerator
|
|
|
|
|
2020-05-18 10:19:01 +00:00
|
|
|
// Enumerator represents NEO enumerator type, it's an opaque data structure
|
|
|
|
// that can be used with functions from this package. It's similar to more
|
|
|
|
// widely used Iterator (see `iterator` package), but ranging over arrays
|
|
|
|
// or structures that have values with no explicit keys.
|
2018-08-31 08:23:57 +00:00
|
|
|
type Enumerator struct{}
|
|
|
|
|
2020-07-20 13:30:19 +00:00
|
|
|
// Create creates a new enumerator from the given items (slice, structure, byte
|
|
|
|
// array and integer or boolean converted to byte array). New enumerator points
|
|
|
|
// at index -1 of its items, so the user of it has to advance it first with Next.
|
|
|
|
// This function uses `System.Enumerator.Create` syscall.
|
|
|
|
func Create(items interface{}) Enumerator {
|
2018-08-31 08:23:57 +00:00
|
|
|
return Enumerator{}
|
|
|
|
}
|
|
|
|
|
2020-05-18 10:19:01 +00:00
|
|
|
// Next moves position of the given enumerator by one and returns a bool that
|
|
|
|
// tells whether there is a new value present in this new position. If it is,
|
|
|
|
// you can use Value to get it, if not then there are no more values in this
|
2020-06-10 08:49:39 +00:00
|
|
|
// enumerator. This function uses `System.Enumerator.Next` syscall.
|
2020-05-18 10:19:01 +00:00
|
|
|
func Next(e Enumerator) bool {
|
|
|
|
return true
|
2018-08-31 08:23:57 +00:00
|
|
|
}
|
|
|
|
|
2020-05-18 10:19:01 +00:00
|
|
|
// Value returns current enumerator's item value, it's only valid to call it
|
2020-06-10 08:49:39 +00:00
|
|
|
// after Next returning true. This function uses `System.Enumerator.Value` syscall.
|
2018-08-31 08:23:57 +00:00
|
|
|
func Value(e Enumerator) interface{} {
|
|
|
|
return nil
|
|
|
|
}
|