X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fmatita%2FmatitaScript.ml;h=c58e0fa3928a4dd05dc7efa9d9d445da6e9086eb;hb=5b32b7905bc78c11e353efd68137b8eb7b6ac73b;hp=f181b53d291c0d9a64e8755e867b47d70cdc255d;hpb=deb24393d87debc27665aa6bd05d6f55bcde9dad;p=helm.git diff --git a/helm/matita/matitaScript.ml b/helm/matita/matitaScript.ml index f181b53d2..c58e0fa39 100644 --- a/helm/matita/matitaScript.ml +++ b/helm/matita/matitaScript.ml @@ -110,16 +110,15 @@ let eval_with_engine guistuff status user_goal parsed_text st = match ex with | TA.Command (_, TA.Alias _) | TA.Command (_, TA.Include _) - | TA.Command (_, TA.Interpretation _) -> - DisambiguateTypes.Environment.empty + | TA.Command (_, TA.Interpretation _) -> [] | _ -> MatitaSync.alias_diff ~from:status new_status in (* we remove the defined object since we consider them "automatic aliases" *) let initial_space,status,new_status_and_text_list_rev = let module DTE = DisambiguateTypes.Environment in let module UM = UriManager in - DTE.fold_flatten ( - fun k ((v,_) as value) (initial_space,status,acc) -> + List.fold_left ( + fun (initial_space,status,acc) (k,((v,_) as value)) -> let b = try let v = UM.strip_xpointer (UM.uri_of_string v) in @@ -133,12 +132,14 @@ 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 + (DisambiguateTypes.Environment.add k value + DisambiguateTypes.Environment.empty) in let new_status = - {status with aliases = DTE.cons k value status.aliases} + MatitaSync.set_proof_aliases status [k,value] in "\n",new_status,((new_status, new_text)::acc) - ) new_aliases (initial_space,status,[]) in + ) (initial_space,status,[]) new_aliases in let parsed_text = initial_space ^ parsed_text in let res = List.rev new_status_and_text_list_rev @ new_status_and_text_list' @ @@ -206,8 +207,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 +296,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 @@ -369,7 +370,7 @@ let rec eval_statement baseoffset parsedlen error_tag (buffer : GText.buffer) if Pcre.pmatch ~rex:only_dust_RE unparsed_text then raise Margin; let st = try - GrafiteParser.parse_statement (Stream.of_string unparsed_text) + GrafiteParser.parse_statement (Ulexing.from_utf8_string unparsed_text) with CicNotationParser.Parse_error (floc,err) as exc -> let (x, y) = CicNotationPt.loc_of_floc floc in @@ -449,17 +450,14 @@ object (self) method private ppFilename = match guistuff.filenamedata with - | Some f,_ -> Filename.basename f + | Some f,_ -> f | 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 +584,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 +599,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 +611,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 +645,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 () = @@ -727,7 +731,7 @@ object (self) let s = self#getFuture in let rec is_there_and_executable s = if Pcre.pmatch ~rex:only_dust_RE s then raise Margin; - let st = GrafiteParser.parse_statement (Stream.of_string s) in + let st = GrafiteParser.parse_statement (Ulexing.from_utf8_string s) in match st with | GrafiteAst.Comment (loc,_)-> let parsed_text_length = snd (CicNotationPt.loc_of_floc loc) in