package ocaml-compiler
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=6fcf1b192e389e54c4f5cb51306ab2baee2a54a25b1770366de5a8b42695996e
doc/stdlib/Stdlib/Stack/index.html
Module Stdlib.StackSource
Last-in first-out stacks.
This module implements stacks (LIFOs), with in-place modification.
Unsynchronized accesses
Unsynchronized accesses to a stack may lead to an invalid queue state. Thus, concurrent accesses to stacks must be synchronized (for instance with a Mutex.t).
The type of stacks containing elements of type 'a.
pop s removes and returns the topmost element in stack s, or raises Empty if the stack is empty.
pop_opt s removes and returns the topmost element in stack s, or returns None if the stack is empty.
drop s removes the topmost element in stack s, or raises Empty if the stack is empty.
top s returns the topmost element in stack s, or raises Empty if the stack is empty.
top_opt s returns the topmost element in stack s, or None if the stack is empty.
iter f s applies f in turn to all elements of s, from the element at the top of the stack to the element at the bottom of the stack. The stack itself is unchanged.
fold f accu s is (f (... (f (f accu x1) x2) ...) xn) where x1 is the top of the stack, x2 the second element, and xn the bottom element. The stack is unchanged.
Stacks and Sequences
Iterate on the stack, top to bottom. It is safe to modify the stack during iteration.
Add the elements from the sequence on the top of the stack.