mirror of
https://github.com/emirpasic/gods.git
synced 2026-06-15 16:16:35 +03:00
- add iterator to array stack
This commit is contained in:
@@ -32,6 +32,7 @@ package arraystack
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"github.com/emirpasic/gods/containers"
|
||||
"github.com/emirpasic/gods/lists/arraylist"
|
||||
"github.com/emirpasic/gods/stacks"
|
||||
"strings"
|
||||
@@ -39,6 +40,7 @@ import (
|
||||
|
||||
func assertInterfaceImplementation() {
|
||||
var _ stacks.Stack = (*Stack)(nil)
|
||||
var _ containers.Iterator = (*Iterator)(nil)
|
||||
}
|
||||
|
||||
type Stack struct {
|
||||
@@ -94,6 +96,29 @@ func (stack *Stack) Values() []interface{} {
|
||||
return elements
|
||||
}
|
||||
|
||||
type Iterator struct {
|
||||
stack *Stack
|
||||
index int
|
||||
}
|
||||
|
||||
func (stack *Stack) Iterator() Iterator {
|
||||
return Iterator{stack: stack, index: -1}
|
||||
}
|
||||
|
||||
func (iterator *Iterator) Next() bool {
|
||||
iterator.index += 1
|
||||
return iterator.stack.withinRange(iterator.index)
|
||||
}
|
||||
|
||||
func (iterator *Iterator) Value() interface{} {
|
||||
value, _ := iterator.stack.list.Get(iterator.stack.list.Size() - iterator.index - 1) // in reverse (LIFO)
|
||||
return value
|
||||
}
|
||||
|
||||
func (iterator *Iterator) Index() interface{} {
|
||||
return iterator.index
|
||||
}
|
||||
|
||||
func (stack *Stack) String() string {
|
||||
str := "ArrayStack\n"
|
||||
values := []string{}
|
||||
@@ -103,3 +128,8 @@ func (stack *Stack) String() string {
|
||||
str += strings.Join(values, ", ")
|
||||
return str
|
||||
}
|
||||
|
||||
// Check that the index is withing bounds of the list
|
||||
func (stack *Stack) withinRange(index int) bool {
|
||||
return index >= 0 && index < stack.list.Size()
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user