(************************************************************************) (* v * The Coq Proof Assistant / The Coq Development Team *) (* None | Some (c,l) -> Some(c,List.map (fun c -> (c,depth-1)) l) let bounded_constr_val_discr (t,depth) = if depth = 0 then None else match constr_val_discr t with | None -> None | Some (c,l) -> Some(c,List.map (fun c -> (c,depth-1)) l) type 'a t = (constr_label,constr_pattern * int,'a) Dn.t let create = Dn.create let add dn (c,v) = Dn.add dn bounded_constr_pat_discr ((c,!dnet_depth),v) let rmv dn (c,v) = Dn.rmv dn bounded_constr_pat_discr ((c,!dnet_depth),v) let lookup dn t = List.map (fun ((c,_),v) -> (c,v)) (Dn.lookup dn bounded_constr_val_discr (t,!dnet_depth)) let app f dn = Dn.app (fun ((c,_),v) -> f(c,v)) dn