Codebase list gojq-upstream / run/df2a107e-8e70-46b9-935b-2069922d4135/main stack.go
run/df2a107e-8e70-46b9-935b-2069922d4135/main

Tree @run/df2a107e-8e70-46b9-935b-2069922d4135/main (Download .tar.gz)

stack.go @run/df2a107e-8e70-46b9-935b-2069922d4135/mainraw · history · blame

package gojq

type stack struct {
	data  []block
	index int
	limit int
}

type block struct {
	value interface{}
	next  int
}

func newStack() *stack {
	return &stack{index: -1, limit: -1}
}

func (s *stack) push(v interface{}) {
	b := block{v, s.index}
	i := s.index + 1
	if i <= s.limit {
		i = s.limit + 1
	}
	s.index = i
	if i < len(s.data) {
		s.data[i] = b
	} else {
		s.data = append(s.data, b)
	}
}

func (s *stack) pop() interface{} {
	b := s.data[s.index]
	s.index = b.next
	return b.value
}

func (s *stack) top() interface{} {
	return s.data[s.index].value
}

func (s *stack) empty() bool {
	return s.index < 0
}

func (s *stack) save() (index, limit int) {
	index, limit = s.index, s.limit
	if s.index > s.limit {
		s.limit = s.index
	}
	return
}

func (s *stack) restore(index, limit int) {
	s.index, s.limit = index, limit
}