| Def
| Fix of int * int (* fixno, recparamno *)
| CoFix of int
- | Ind of int
+ | Ind of bool * int (* inductive, indtyno *)
| Con of int * int (* indtyno, constrno *)
type reference = Ref of int * NUri.uri * spec
*)
let uri_suffix_of_ref_suffix = function
- | "dec"
- | "def" -> "con"
- | "ind"
- | "con" -> "ind"
- | _ -> assert false
+ | "dec" | "fix" | "cfx" | "def" -> "con"
+ | "ind" | "con" -> "ind"
+ | x -> prerr_endline (x ^ " not a valid suffix"); assert false
;;
let reference_of_string =
i,j
in
let get1 s dot =
- let i = int_of_string (String.sub s (dot+5) (String.length s-1)) in
+ let i = int_of_string (String.sub s (dot+5) (String.length s-1-dot-5)) in
i
in
fun s ->
| "def" -> Ref (c (), u, Def)
| "fix" -> let i,j = get2 s dot in Ref (c (), u, Fix (i,j))
| "cfx" -> let i = get1 s dot in Ref (c (), u, CoFix (i))
- | "ind" -> let i = get1 s dot in Ref (c (), u, Ind (i))
+ | "ind" -> let b,i = get2 s dot in Ref (c (), u, Ind (b=1,i))
| "con" -> let i,j = get2 s dot in Ref (c (), u, Con (i,j))
| _ -> raise Not_found
with Not_found -> raise (IllFormedReference (lazy s))
| Def -> s2 ^ ".def"
| Fix (i,j) -> s2 ^ ".fix(" ^ string_of_int i ^ "," ^ string_of_int j ^ ")"
| CoFix i -> s2 ^ ".cfx(" ^ string_of_int i ^ ")"
- | Ind i -> s2 ^ ".ind(" ^ string_of_int i ^ ")"
+ | Ind (b,i)->s2 ^".ind(" ^(if b then "1" else "0")^ "," ^ string_of_int i ^")"
| Con (i,j) -> s2 ^ ".con(" ^ string_of_int i ^ "," ^ string_of_int j ^ ")"
;;
+let mk_constructor j = function
+ | Ref (d, u, Ind (_,i)) ->
+ reference_of_string (string_of_reference (Ref (d, u, Con (i,j))))
+ | _ -> assert false
+;;
+
+let mk_fix i j = function
+ | Ref (d, u, Fix _) ->
+ reference_of_string (string_of_reference (Ref (d, u, Fix (i,j))))
+ | _ -> assert false
+;;
+
+let mk_cofix i = function
+ | Ref (d, u, CoFix _) ->
+ reference_of_string (string_of_reference (Ref (d, u, CoFix i)))
+ | _ -> assert false
+;;
+
let reference_of_ouri u indinfo =
let u = NUri.nuri_of_ouri u in
- reference_of_string (string_of_reference (Ref (~-1,u,indinfo)))
+ reference_of_string (string_of_reference (Ref (max_int,u,indinfo)))
;;
let ouri_of_reference (Ref (_,u,_)) = NUri.ouri_of_nuri u;;
+