]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/software/components/grafite_engine/grafiteEngine.ml
Added ntry and nassumption tactics
[helm.git] / helm / software / components / grafite_engine / grafiteEngine.ml
index bb01585d12ce603108b7948dcdad09082a57ac31..e02bd159fe0d13544c5cc33252810b2d5bdcff0e 100644 (file)
@@ -471,22 +471,28 @@ let coercion_moo_statement_of (uri,arity, saturations,_) =
    (HExtlib.dummy_floc, CicUtil.term_of_uri uri, false, arity, saturations)
 
 let basic_eval_unification_hint (t,n) status =
- let hstatus =
-  NCicUnifHint.add_user_provided_hint (status.NRstatus.uhint_db) t n
- in
-  { status with NRstatus.uhint_db = hstatus }
+ NCicUnifHint.add_user_provided_hint status t n
 ;;
 
 let inject_unification_hint =
- NRstatus.Serializer.register "unification_hints" basic_eval_unification_hint
+ let basic_eval_unification_hint (t,n) ~refresh_uri_in_term =
+  let t = refresh_uri_in_term t in basic_eval_unification_hint (t,n)
+ in
+  NRstatus.Serializer.register "unification_hints" basic_eval_unification_hint
 ;;
 
 let eval_unification_hint status t n = 
- let rstatus =
-  basic_eval_unification_hint (t,n) (GrafiteTypes.get_rstatus status) in
- let status = GrafiteTypes.set_rstatus rstatus status in
- let dump = inject_unification_hint (t,n)::(GrafiteTypes.get_dump status) in
- let status = GrafiteTypes.set_dump dump status in
+ let estatus = GrafiteTypes.get_estatus status in
+ let metasenv,subst,estatus,t =
+  GrafiteDisambiguate.disambiguate_nterm None estatus [] [] [] ("",0,t) in
+ assert (metasenv=[]);
+ let t = NCicUntrusted.apply_subst subst [] t in
+ let status = GrafiteTypes.set_estatus estatus status in
+ let estatus =
+  basic_eval_unification_hint (t,n) (GrafiteTypes.get_estatus status) in
+ let dump = inject_unification_hint (t,n)::estatus#dump in
+ let estatus = estatus#set_dump dump in
+ let status = GrafiteTypes.set_estatus estatus status in
   status,`Old []
 ;;
 
@@ -597,7 +603,7 @@ let eval_ng_punct (_text, _prefix_len, punct) =
   | GrafiteAst.Merge _ -> NTactics.merge_tac 
 ;;
 
-let eval_ng_tac (text, prefix_len, tac) =
+let rec eval_ng_tac (text, prefix_len, tac) =
   match tac with
   | GrafiteAst.NApply (_loc, t) -> NTactics.apply_tac (text,prefix_len,t) 
   | GrafiteAst.NAssert (_loc, seqs) ->
@@ -648,6 +654,9 @@ let eval_ng_tac (text, prefix_len, tac) =
   | GrafiteAst.NSkip _ -> NTactics.skip_tac
   | GrafiteAst.NUnfocus _ -> NTactics.unfocus_tac
   | GrafiteAst.NWildcard _ -> NTactics.wildcard_tac 
+  | GrafiteAst.NTry (_,tac) -> NTactics.try_tac
+      (eval_ng_tac (text, prefix_len, tac))
+  | GrafiteAst.NAssumption _ -> NTactics.assumption_tac
 ;;
       
 let subst_metasenv_and_fix_names s =
@@ -661,6 +670,87 @@ let subst_metasenv_and_fix_names s =
         u,h,NCicUntrusted.apply_subst_metasenv subst metasenv,subst,o}}
 ;;
 
+let rec eval_ncommand opts status (text,prefix_len,cmd) =
+  match cmd with
+  | GrafiteAst.UnificationHint (loc, t, n) -> eval_unification_hint status t n
+  | GrafiteAst.NQed loc ->
+      (match status.GrafiteTypes.ng_status with
+       | GrafiteTypes.ProofMode
+          { NTacStatus.istatus =
+             { NTacStatus.pstatus = pstatus; estatus = estatus } } ->
+            let uri,height,menv,subst,obj_kind = pstatus in
+             if menv <> [] then
+              raise
+               (GrafiteTypes.Command_error"You can't Qed an incomplete theorem")
+             else
+              let obj_kind =
+               NCicUntrusted.map_obj_kind 
+                (NCicUntrusted.apply_subst subst []) obj_kind in
+              let height = NCicTypeChecker.height_of_obj_kind uri obj_kind in
+              (* fix the height inside the object *)
+              let rec fix () = function 
+                | NCic.Const (NReference.Ref (u,spec)) when NUri.eq u uri -> 
+                   NCic.Const (NReference.reference_of_spec u
+                    (match spec with
+                    | NReference.Def _ -> NReference.Def height
+                    | NReference.Fix (i,j,_) -> NReference.Fix(i,j,height)
+                    | NReference.CoFix _ -> NReference.CoFix height
+                    | NReference.Ind _ | NReference.Con _
+                    | NReference.Decl as s -> s))
+                | t -> NCicUtils.map (fun _ () -> ()) () fix t
+              in
+              let obj_kind = 
+                match obj_kind with
+                | NCic.Fixpoint _ -> 
+                    NCicUntrusted.map_obj_kind (fix ()) obj_kind 
+                | _ -> obj_kind
+              in
+              let obj = uri,height,[],[],obj_kind in
+               NCicTypeChecker.typecheck_obj obj;
+               let estatus = NCicLibrary.add_obj estatus uri obj in
+               let objs = NCicElim.mk_elims obj in
+               let timestamp,uris_rev =
+                 List.fold_left
+                  (fun (estatus,uris_rev) (uri,_,_,_,_) as obj ->
+                    NCicTypeChecker.typecheck_obj obj;
+                    let estatus = NCicLibrary.add_obj estatus uri obj in
+                     estatus,uri::uris_rev
+                  ) (estatus,[]) objs in
+               let uris = uri::List.rev uris_rev in
+                GrafiteTypes.set_estatus estatus
+                 {status with 
+                  GrafiteTypes.ng_status = 
+                   GrafiteTypes.CommandMode estatus },`New uris
+       | _ -> raise (GrafiteTypes.Command_error "Not in proof mode"))
+  | GrafiteAst.NObj (loc,obj) ->
+     let estatus =
+       match status.GrafiteTypes.ng_status with
+       | GrafiteTypes.ProofMode _ -> assert false
+       | GrafiteTypes.CommandMode es -> es 
+     in
+     let estatus,obj =
+      GrafiteDisambiguate.disambiguate_nobj estatus
+       ~baseuri:(GrafiteTypes.get_baseuri status) (text,prefix_len,obj) in
+     let uri,height,nmenv,nsubst,nobj = obj in
+     let ninitial_stack = Continuationals.Stack.of_nmetasenv nmenv in
+     let status =
+      { status with
+         GrafiteTypes.ng_status = 
+          GrafiteTypes.ProofMode
+           (subst_metasenv_and_fix_names
+            { NTacStatus.gstatus = ninitial_stack; 
+             istatus = { NTacStatus.pstatus = obj; estatus = estatus}})
+             }
+     in
+     (match nmenv with
+         [] ->
+          eval_ncommand opts status ("",0,GrafiteAst.NQed Stdpp.dummy_loc)
+       | _ -> status,`New [])
+  | GrafiteAst.NUnivConstraint (loc,strict,u1,u2) ->
+      NCicEnvironment.add_constraint strict [false,u1] [false,u2];
+      status, `New [u1;u2]
+;;
+
 let rec eval_command = {ec_go = fun ~disambiguate_command opts status
 (text,prefix_len,cmd) ->
  let status,cmd = disambiguate_command status (text,prefix_len,cmd) in
@@ -721,8 +811,6 @@ let rec eval_command = {ec_go = fun ~disambiguate_command opts status
       Inversion_principle.build_inverter ~add_obj status uri indty_uri params
      in
       res,`Old uris
-  | GrafiteAst.UnificationHint (loc, t, n) ->
-     eval_unification_hint status t n
   | GrafiteAst.Default (loc, what, uris) as cmd ->
      LibraryObjects.set_default what uris;
      GrafiteTypes.add_moo_content [cmd] status,`Old []
@@ -740,11 +828,11 @@ let rec eval_command = {ec_go = fun ~disambiguate_command opts status
            raise (IncludedFileNotCompiled (moopath_rw,baseuri))
      in
      let status = eval_from_moo.efm_go status moopath in
-     let rstatus = GrafiteTypes.get_rstatus status in
-     let rstatus =
-      NRstatus.Serializer.require ~baseuri:(NUri.uri_of_string baseuri) rstatus
-     in
-     let status = GrafiteTypes.set_rstatus rstatus status in
+     let estatus = GrafiteTypes.get_estatus status in
+     let estatus =
+       NRstatus.Serializer.require ~baseuri:(NUri.uri_of_string baseuri)
+        estatus in
+     let status = GrafiteTypes.set_estatus estatus status in
 (* debug
      let lt_uri = UriManager.uri_of_string "cic:/matita/nat/orders/lt.con" in
      let nat_uri = UriManager.uri_of_string "cic:/matita/nat/nat/nat.ind" in
@@ -788,70 +876,11 @@ let rec eval_command = {ec_go = fun ~disambiguate_command opts status
        {status with GrafiteTypes.proof_status = GrafiteTypes.No_proof},
         (*CSC: I throw away the arities *)
         `Old (uri::lemmas)
-  | GrafiteAst.NQed loc ->
-      (match status.GrafiteTypes.ng_status with
-       | GrafiteTypes.ProofMode
-          { NTacStatus.istatus =
-             { NTacStatus.pstatus = pstatus; estatus = estatus } } ->
-            let uri,height,menv,subst,obj_kind = pstatus in
-             if menv <> [] then
-              raise
-               (GrafiteTypes.Command_error"You can't Qed an incomplete theorem")
-             else
-              let obj_kind =
-               NCicUntrusted.map_obj_kind 
-                (NCicUntrusted.apply_subst subst []) obj_kind in
-              let height = NCicTypeChecker.height_of_obj_kind uri obj_kind in
-              let obj = uri,height,[],[],obj_kind in
-               NCicTypeChecker.typecheck_obj obj;
-               let timestamp = NCicLibrary.add_obj uri obj in
-               let objs = NCicElim.mk_elims obj in
-               let timestamp,uris_rev =
-                 List.fold_left
-                  (fun (timestamp,uris_rev) (uri,_,_,_,_) as obj ->
-                    NCicTypeChecker.typecheck_obj obj;
-                    let timestamp = NCicLibrary.add_obj uri obj in
-                     timestamp,uri::uris_rev
-                  ) (timestamp,[]) objs in
-               let uris = uri::List.rev uris_rev in
-                GrafiteTypes.set_library_db timestamp
-                 {status with 
-                  GrafiteTypes.ng_status = 
-                   GrafiteTypes.CommandMode estatus },`New uris
-       | _ -> raise (GrafiteTypes.Command_error "Not in proof mode"))
   | GrafiteAst.Relation (loc, id, a, aeq, refl, sym, trans) -> 
      Setoids.add_relation id a aeq refl sym trans;
      status, `Old [] (*CSC: TO BE FIXED *)
   | GrafiteAst.Set (loc, name, value) -> status, `Old []
 (*       GrafiteTypes.set_option status name value,[] *)
-  | GrafiteAst.NUnivConstraint (loc,strict,u1,u2) ->
-      NCicEnvironment.add_constraint strict [false,u1] [false,u2];
-      status, `New [u1;u2]
-  | GrafiteAst.NObj (loc,obj) ->
-     let estatus =
-       match status.GrafiteTypes.ng_status with
-       | GrafiteTypes.ProofMode _ -> assert false
-       | GrafiteTypes.CommandMode es -> es 
-     in
-     let estatus,obj =
-      GrafiteDisambiguate.disambiguate_nobj estatus
-       ~baseuri:(GrafiteTypes.get_baseuri status) (text,prefix_len,obj) in
-     let uri,height,nmenv,nsubst,nobj = obj in
-     let ninitial_stack = Continuationals.Stack.of_nmetasenv nmenv in
-     let status =
-      { status with
-         GrafiteTypes.ng_status = 
-          GrafiteTypes.ProofMode
-           (subst_metasenv_and_fix_names
-            { NTacStatus.gstatus = ninitial_stack; 
-             istatus = { NTacStatus.pstatus = obj; estatus = estatus}})
-             }
-     in
-     (match nmenv with
-         [] ->
-          eval_command.ec_go ~disambiguate_command opts status
-           ("",0,GrafiteAst.NQed Stdpp.dummy_loc)
-       | _ -> status,`New [])
   | GrafiteAst.Obj (loc,obj) ->
      let ext,name =
       match obj with
@@ -964,6 +993,8 @@ let rec eval_command = {ec_go = fun ~disambiguate_command opts status
        (punctuation_tactical_of_ast (text,prefix_len,punct)),`Old []
   | GrafiteAst.Command (_, cmd) ->
       eval_command.ec_go ~disambiguate_command opts status (text,prefix_len,cmd)
+  | GrafiteAst.NCommand (_, cmd) ->
+      eval_ncommand opts status (text,prefix_len,cmd)
   | GrafiteAst.Macro (loc, macro) ->
      raise (Macro (loc,disambiguate_macro status (text,prefix_len,macro)))