]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/matita/matitaScript.ml
some optimizations...
[helm.git] / helm / matita / matitaScript.ml
index f9855348a0d0ff9b6a4cc8224fd303aa527936e3..c7859a7c7b96df61e8501b289d146237bc0b5709 100644 (file)
  *)
 
 open Printf
-
 open MatitaTypes
 
+let debug = true
+let debug_print = if  debug then prerr_endline else ignore
+
   (** raised when one of the script margins (top or bottom) is reached *)
 exception Margin
 
@@ -91,8 +93,13 @@ let eval_with_engine status user_goal parsed_text st =
     let module UM = UriManager in
     DTE.fold (
       fun k ((v,_) as value) acc -> 
-        let v = UM.strip_xpointer (UM.uri_of_string v) in
-        if List.exists (fun (s,_) -> s = v) new_status.objects then
+        let b = 
+          try
+            let v = UM.strip_xpointer (UM.uri_of_string v) in
+            List.exists (fun (s,_) -> s = v) new_status.objects 
+          with UM.IllFormedUri _ -> false
+        in
+        if b then 
           acc
         else
           DTE.add k value acc
@@ -162,7 +169,7 @@ let eval_macro status (mathviewer:MatitaTypes.mathViewer) urichooser parsed_text
       let term = disambiguate term status in
       let uri =
         match term with
-        | Cic.MutInd (uri,n,_) -> UriManager.string_of_uriref (uri,[n])
+        | Cic.MutInd (uri,n,_) -> UriManager.uri_of_string (UriManager.string_of_uriref (uri,[n]))
         | _ -> failwith "Not a MutInd"
       in
       let l = MQ.elim ~dbd uri in
@@ -188,7 +195,7 @@ let eval_macro status (mathviewer:MatitaTypes.mathViewer) urichooser parsed_text
           (TA.Executable (loc,
             (TA.Tactical (loc, 
                TA.Tactic (loc,
-                 TA.Apply (loc, CicAst.Uri (uri,None))))))) 
+                 TA.Apply (loc, CicAst.Uri (UriManager.string_of_uri uri,None))))))) 
         in
         let new_status = MatitaEngine.eval_ast status ast in
         let extra_text = 
@@ -200,7 +207,7 @@ let eval_macro status (mathviewer:MatitaTypes.mathViewer) urichooser parsed_text
           MatitaLog.error 
             "The result of the urichooser should be only 1 uri, not:\n";
           List.iter (
-            fun u -> MatitaLog.error (u ^ "\n")
+            fun u -> MatitaLog.error (UriManager.string_of_uri u ^ "\n")
           ) selected;
           assert false)
   | TA.Check (_,term) ->