(***********************************************************************) (* v * The Coq Proof Assistant / The Coq Development Team *) (* 'a t (* build a node given a label and the vector of sons *) val mk_node : 'a -> 'a t array -> 'a t (* build mutually dependent trees *) val mk_rec : 'a t array -> 'a t array (* [lift k t] increases of [k] the free parameters of [t]. Needed to avoid captures when a tree appears under mk_rec *) val lift : int -> 'a t -> 'a t (* Destructors (recursive calls are expanded) *) val dest_param : 'a t -> int val dest_node : 'a t -> 'a * 'a t array (* Tells if a tree has an infinite branch *) val is_infinite : 'a t -> bool (* A rather simple minded pretty-printer *) val pp_tree : ('a -> Pp.std_ppcmds) -> 'a t -> Pp.std_ppcmds