Last-in first-out stacks.
This module implements stacks (LIFOs), with in-place modification.
val pop : 'a t -> 'apop s removes and returns the topmost element in stack s,
or raises Empty if the stack is empty.
val top : 'a t -> 'atop s returns the topmost element in stack s,
or raises Empty if the stack is empty.
val iter : ('a -> unit) -> 'a t -> unititer 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.
val fold : ('b -> 'a -> 'b) -> 'b -> 'a t -> 'bfold 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.