X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fmatita%2FmatitaScript.ml;h=3a57745a48af9dcfd6ba76290cbd479c857b24de;hb=81e3d11cbb2a7a6498b4b19876bbb5ababc8942b;hp=2186b75b5ff2d4c9914861031920487d86498197;hpb=732ffd3b5cb77cbacb60b95c1d52d3b63bd56c3b;p=helm.git diff --git a/helm/software/matita/matitaScript.ml b/helm/software/matita/matitaScript.ml index 2186b75b5..3a57745a4 100644 --- a/helm/software/matita/matitaScript.ml +++ b/helm/software/matita/matitaScript.ml @@ -559,13 +559,13 @@ let rec eval_macro include_paths (buffer : GText.buffer) guistuff grafite_status in let ty,_ = CicTypeChecker.type_of_aux' - menv [] proof_term CicUniv.empty_ugraph + [] [] proof_term CicUniv.empty_ugraph in - prerr_endline (CicPp.ppterm proof_term); + prerr_endline (CicPp.ppterm proof_term ^ " n lambda= " ^ string_of_int how_many_lambdas); (* use declarative output *) let obj = (* il proof_term vive in cc, devo metterci i lambda no? *) - (Cic.CurrentProof ("xxx",menv,proof_term,ty,[],[])) + (Cic.CurrentProof ("xxx",[],proof_term,ty,[],[])) in ApplyTransformation.txt_of_cic_object ~map_unicode_to_tex:(Helm_registry.get_bool @@ -699,9 +699,17 @@ class script ~(source_view: GSourceView2.source_view) () = let buffer = source_view#buffer in let source_buffer = source_view#source_buffer in -let initial_statuses baseuri = +let initial_statuses current baseuri = + let empty_lstatus = new LexiconEngine.status in + (match current with + Some current -> + LexiconSync.time_travel ~present:current ~past:empty_lstatus; + GrafiteSync.time_travel ~present:current (); + (* CSC: there is a known bug in invalidation; temporary fix here *) + NCicEnvironment.invalidate () + | None -> ()); let lexicon_status = - CicNotation2.load_notation ~include_paths:[] (new LexiconEngine.status) + CicNotation2.load_notation ~include_paths:[] empty_lstatus BuildTimeConf.core_notation_script in let grafite_status = GrafiteSync.init lexicon_status baseuri in @@ -770,7 +778,7 @@ object (self) val mutable statements = [] (** executed statements *) - val mutable history = [ initial_statuses default_buri ] + val mutable history = [ initial_statuses None default_buri ] (** list of states before having executed statements. Head element of this * list is the current state, last element is the state at the beginning of * the script. @@ -845,7 +853,7 @@ object (self) match history with s::_ -> s | [] -> assert false in LexiconSync.time_travel ~present:cur_grafite_status ~past:grafite_status; - GrafiteSync.time_travel ~present:cur_grafite_status ~past:grafite_status; + GrafiteSync.time_travel ~present:cur_grafite_status ~past:grafite_status (); statements <- new_statements; history <- new_history; self#moveMark (- offset) @@ -970,7 +978,6 @@ object (self) | Some f -> Some (Librarian.absolutize f) | None -> None in - self#goto_top; filename_ <- file; include_paths_ <- (match file with Some file -> read_include_paths file | None -> []); @@ -1000,22 +1007,9 @@ object (self) HLog.debug ("backup " ^ f ^ " saved") end - method private goto_top = - let grafite_status = - let rec last x = function - | [] -> x - | hd::tl -> last hd tl - in - last (self#grafite_status) history - in - (* FIXME: this is not correct since there is no undo for - * library_objects.set_default... *) - GrafiteSync.time_travel ~present:self#grafite_status ~past:grafite_status; - LexiconSync.time_travel ~present:self#grafite_status ~past:grafite_status - method private reset_buffer = statements <- []; - history <- [ initial_statuses self#buri_of_current_file ]; + history <- [ initial_statuses (Some self#grafite_status) self#buri_of_current_file ]; userGoal <- None; self#notify; buffer#remove_tag locked_tag ~start:buffer#start_iter ~stop:buffer#end_iter; @@ -1046,7 +1040,6 @@ object (self) match pos with | `Top -> dispose_old_locked_mark (); - self#goto_top; self#reset_buffer; self#notify | `Bottom ->