mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2024-12-28 10:06:31 +00:00
9b76afc851
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
40 lines
955 B
Go
40 lines
955 B
Go
package genstack
|
|
|
|
// stack is a wrapper around an array implementing a stack.
|
|
//
|
|
// We cannot use slice to represent the stack because append might change the
|
|
// pointer value of the slice. That would be an issue in GenStack
|
|
// implementation.
|
|
type stack[T any] struct {
|
|
arr []T
|
|
}
|
|
|
|
// push pushes a new element at the top of a stack.
|
|
func (s *stack[T]) push(vs ...T) { s.arr = append(s.arr, vs...) }
|
|
|
|
// pop pops the stack top-most element.
|
|
//
|
|
// If stack length is zero, this method panics.
|
|
func (s *stack[T]) pop() T {
|
|
idx := s.len() - 1
|
|
val := s.arr[idx]
|
|
|
|
// Avoid memory leak
|
|
var zero T
|
|
s.arr[idx] = zero
|
|
|
|
s.arr = s.arr[:idx]
|
|
return val
|
|
}
|
|
|
|
// takeAll returns all elements in the stack in order as they are stored - i.e.
|
|
// the top-most stack element is the last one.
|
|
func (s *stack[T]) takeAll() []T {
|
|
arr := s.arr
|
|
s.arr = nil
|
|
return arr
|
|
}
|
|
|
|
// len returns number of elements in the stack.
|
|
func (s *stack[T]) len() int { return len(s.arr) }
|