+ match obj with
+ `WellTyped o -> o
+ | `Exn e -> raise e
+;;
+
+let get_checked_decl = function
+ | Ref.Ref (uri, Ref.Decl) ->
+ (match get_checked_obj uri with
+ | _,height,_,_, C.Constant (rlv,name,None,ty,att) ->
+ rlv,name,ty,att,height
+ | _,_,_,_, C.Constant (_,_,Some _,_,_) ->
+ prerr_endline "get_checked_decl on a definition"; assert false
+ | _ -> prerr_endline "get_checked_decl on a non decl 2"; assert false)
+ | _ -> prerr_endline "get_checked_decl on a non decl"; assert false
+;;
+
+let get_checked_def = function
+ | Ref.Ref (uri, Ref.Def _) ->
+ (match get_checked_obj uri with
+ | _,height,_,_, C.Constant (rlv,name,Some bo,ty,att) ->
+ rlv,name,bo,ty,att,height
+ | _,_,_,_, C.Constant (_,_,None,_,_) ->
+ prerr_endline "get_checked_def on an axiom"; assert false
+ | _ -> prerr_endline "get_checked_def on a non def 2"; assert false)
+ | _ -> prerr_endline "get_checked_def on a non def"; assert false
+;;
+
+let get_checked_indtys = function
+ | Ref.Ref (uri, (Ref.Ind (_,n,_)|Ref.Con (n,_,_))) ->
+ (match get_checked_obj uri with
+ | _,_,_,_, C.Inductive (inductive,leftno,tys,att) ->
+ inductive,leftno,tys,att,n
+ | _ -> prerr_endline "get_checked_indtys on a non ind 2"; assert false)
+ | _ -> prerr_endline "get_checked_indtys on a non ind"; assert false
+;;
+
+let get_checked_fixes_or_cofixes = function
+ | Ref.Ref (uri, (Ref.Fix _|Ref.CoFix _))->
+ (match get_checked_obj uri with
+ | _,height,_,_, C.Fixpoint (_,funcs,att) ->
+ funcs, att, height
+ | _ ->prerr_endline "get_checked_(co)fix on a non (co)fix 2";assert false)
+ | _ -> prerr_endline "get_checked_(co)fix on a non (co)fix"; assert false
+;;
+
+let get_relevance (Ref.Ref (_, infos) as r) =
+ match infos with
+ Ref.Def _ -> let res,_,_,_,_,_ = get_checked_def r in res
+ | Ref.Decl -> let res,_,_,_,_ = get_checked_decl r in res
+ | Ref.Ind _ ->
+ let _,_,tl,_,n = get_checked_indtys r in
+ let res,_,_,_ = List.nth tl n in
+ res
+ | Ref.Con (_,i,_) ->
+ let _,_,tl,_,n = get_checked_indtys r in
+ let _,_,_,cl = List.nth tl n in
+ let res,_,_ = List.nth cl (i - 1) in
+ res
+ | Ref.Fix (fixno,_,_)
+ | Ref.CoFix fixno ->
+ let fl,_,_ = get_checked_fixes_or_cofixes r in
+ let res,_,_,_,_ = List.nth fl fixno in
+ res
+;;
+
+
+let invalidate _ =
+ assert (!frozen_list = []);
+ NUri.UriHash.clear cache
+;;