]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/software/components/ng_kernel/nReference.ml
convertibility was taking a metasenv but not using it
[helm.git] / helm / software / components / ng_kernel / nReference.ml
index 4ecf746456504c3475fb206f7bba360aa10d3e7b..81a08af4e6bc3037ce24ebc2dac8290c9163af23 100644 (file)
@@ -30,7 +30,7 @@ type spec =
  | 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
@@ -91,7 +91,7 @@ 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))
@@ -109,19 +109,31 @@ let string_of_reference (Ref (_,u,indinfo)) =
   | 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) -> 
+  | 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;;