X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fmatita%2FmatitaScript.ml;h=f12ac877dad2af34b1ca45fb31030d117861e322;hb=5a702cea95883f7095c16b450e065ccb1714fc5a;hp=1bd4b9fd1226e35b503e8891959fc5aeb279c9f3;hpb=aa6153d8e480abfe52b00e1bc6bd48ef84c48988;p=helm.git diff --git a/helm/matita/matitaScript.ml b/helm/matita/matitaScript.ml index 1bd4b9fd1..f12ac877d 100644 --- a/helm/matita/matitaScript.ml +++ b/helm/matita/matitaScript.ml @@ -57,7 +57,7 @@ let first_line s = (** creates a statement AST for the Goal tactic, e.g. "goal 7" *) let goal_ast n = let module A = GrafiteAst in - let loc = Disambiguate.dummy_floc in + let loc = DisambiguateTypes.dummy_floc in A.Executable (loc, A.Tactical (loc, A.Tactic (loc, A.Goal (loc, n)))) type guistuff = { @@ -118,7 +118,7 @@ let eval_with_engine guistuff status user_goal parsed_text st = let initial_space,status,new_status_and_text_list_rev = let module DTE = DisambiguateTypes.Environment in let module UM = UriManager in - DTE.fold_flatten ( + DTE.fold ( fun k ((v,_) as value) (initial_space,status,acc) -> let b = try @@ -133,9 +133,9 @@ let eval_with_engine guistuff status user_goal parsed_text st = let initial_space = if initial_space = "" then "\n" else initial_space in initial_space ^ - DisambiguatePp.pp_environment(DTE.cons k value DTE.empty) in + DisambiguatePp.pp_environment(DTE.add k value DTE.empty) in let new_status = - {status with aliases = DTE.cons k value status.aliases} + MatitaSync.set_proof_aliases status (DTE.add k value status.aliases) in "\n",new_status,((new_status, new_text)::acc) ) new_aliases (initial_space,status,[]) in @@ -206,8 +206,9 @@ let disambiguate term status = let dbd = MatitaDb.instance () in let metasenv = MatitaMisc.get_proof_metasenv status in let context = MatitaMisc.get_proof_context status in - let aliases = MatitaMisc.get_proof_aliases status in - let interps = MD.disambiguate_term dbd context metasenv aliases term in + let interps = + MD.disambiguate_term ~dbd ~context ~metasenv ~aliases:status.aliases + ~universe:(Some status.multi_aliases) term in match interps with | [_,_,x,_], _ -> x | _ -> assert false @@ -294,10 +295,9 @@ let eval_macro guistuff status unparsed_text parsed_text script mac = | TA.Check (_,term) -> let metasenv = MatitaMisc.get_proof_metasenv status in let context = MatitaMisc.get_proof_context status in - let aliases = MatitaMisc.get_proof_aliases status in let interps = - MatitaDisambiguator.disambiguate_term - dbd context metasenv aliases term + MatitaDisambiguator.disambiguate_term ~dbd ~context ~metasenv + ~aliases:status.aliases ~universe:(Some status.multi_aliases) term in let _, metasenv , term, ugraph = match interps with @@ -453,13 +453,10 @@ object (self) | None,_ -> sprintf ".unnamed%d.ma" scriptId initializer - ignore(GMain.Timeout.add ~ms:300000 - ~callback:(fun _ -> self#_saveToBackuptFile ();true)); - ignore(buffer#connect#modified_changed - (fun _ -> if buffer#modified then - set_star self#ppFilename true - else - set_star self#ppFilename false)) + ignore (GMain.Timeout.add ~ms:300000 + ~callback:(fun _ -> self#_saveToBackupFile ();true)); + ignore (buffer#connect#modified_changed + (fun _ -> set_star (Filename.basename self#ppFilename) buffer#modified)) val mutable statements = []; (** executed statements *) val mutable history = [ init ]; @@ -586,7 +583,7 @@ object (self) method loadFromFile f = buffer#set_text (MatitaMisc.input_file f); - self#goto_top; + self#reset_buffer; buffer#set_modified false method assignFileName file = @@ -601,7 +598,7 @@ object (self) close_out oc; buffer#set_modified false - method private _saveToBackuptFile () = + method private _saveToBackupFile () = if buffer#modified then begin let f = self#ppFilename ^ "~" in @@ -613,28 +610,30 @@ object (self) end method private goto_top = - MatitaSync.time_travel ~present:self#status ~past:init; + MatitaSync.time_travel ~present:self#status ~past:init + + method private reset_buffer = statements <- []; history <- [ init ]; userGoal <- ~-1; + self#notify; buffer#remove_tag locked_tag ~start:buffer#start_iter ~stop:buffer#end_iter; buffer#move_mark (`MARK locked_mark) ~where:buffer#start_iter method reset () = - self#goto_top; + self#reset_buffer; source_buffer#begin_not_undoable_action (); buffer#delete ~start:buffer#start_iter ~stop:buffer#end_iter; source_buffer#end_not_undoable_action (); - self#notify; buffer#set_modified false - + method template () = let template = MatitaMisc.input_file BuildTimeConf.script_template in buffer#insert ~iter:(buffer#get_iter `START) template; guistuff.filenamedata <- (None,MatitamakeLib.development_for_dir (Unix.getcwd ())); buffer#set_modified false; - set_star self#ppFilename false + set_star (Filename.basename self#ppFilename) false method goto (pos: [`Top | `Bottom | `Cursor]) () = let old_locked_mark = @@ -645,7 +644,11 @@ object (self) let getoldpos _ = buffer#get_iter_at_mark old_locked_mark in let dispose_old_locked_mark () = buffer#delete_mark old_locked_mark in match pos with - | `Top -> dispose_old_locked_mark (); self#goto_top; self#notify + | `Top -> + dispose_old_locked_mark (); + self#goto_top; + self#reset_buffer; + self#notify | `Bottom -> (try let rec dowhile () =