X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fmatita%2Fmatita.ml;h=9aa1fb2f1c3db6f04c493434edf6df0760cc1c43;hb=f3c6deea5fa1ed58847d7fcdf597193e2c5c7ddb;hp=f8cc4efb44f6806115cf95c4a278b69b1420e666;hpb=7a060397679753a0233139b1ba83ac83c2c49949;p=helm.git diff --git a/helm/software/matita/matita.ml b/helm/software/matita/matita.ml index f8cc4efb4..9aa1fb2f1 100644 --- a/helm/software/matita/matita.ml +++ b/helm/software/matita/matita.ml @@ -81,8 +81,15 @@ let _ = let sequents_viewer = MatitaMathView.sequentsViewer_instance () in sequents_viewer#load_logo; cic_math_view#set_href_callback - (Some (fun uri -> (MatitaMathView.cicBrowser ())#load - (`Uri (UriManager.uri_of_string uri)))); + (Some (fun uri -> + let uri = + try + `Uri (UriManager.uri_of_string uri) + with + UriManager.IllFormedUri _ -> + `NRef (NReference.reference_of_string uri) + in + (MatitaMathView.cicBrowser ())#load uri)); let browser_observer _ _ = MatitaMathView.refresh_all_browsers () in let sequents_observer _ grafite_status = sequents_viewer#reset; @@ -99,7 +106,21 @@ let _ = sequents_viewer#goto_sequent goal with Failure _ -> script#setGoal None); | Proof proof -> sequents_viewer#load_logo_with_qed - | No_proof -> sequents_viewer#load_logo + | No_proof -> + (match grafite_status.ng_status with + ProofMode nstatus -> + sequents_viewer#nload_sequents nstatus; + (try + script#setGoal (Some (Continuationals.Stack.find_goal nstatus.NTacStatus.gstatus)); + let goal = + match script#goal with + None -> assert false + | Some n -> n + in + sequents_viewer#goto_sequent goal + with Failure _ -> script#setGoal None); + | CommandMode _ -> sequents_viewer#load_logo + ) | Intermediate _ -> assert false (* only the engine may be in this state *) in script#addObserver sequents_observer; @@ -120,10 +141,18 @@ let _ = in addDebugItem "dump aliases" (fun _ -> let status = script#lexicon_status in + LexiconEngine.dump_aliases HLog.debug "" status); +(* FG: DEBUGGING + addDebugItem "dump interpretations" (fun _ -> + let status = script#lexicon_status in + let filter = + List.filter (function LexiconAst.Interpretation _ -> true | _ -> false) + in HLog.debug (String.concat "\n" - (DisambiguateTypes.Environment.fold - (fun _ x l -> (LexiconAstPp.pp_alias x)::l) - status.LexiconEngine.aliases []))); + (List.fold_right + (fun x l -> (LexiconAstPp.pp_command x)::l) + (filter status.LexiconEngine.lexicon_content_rev) []))); +*) addDebugItem "dump environment to \"env.dump\"" (fun _ -> let oc = open_out "env.dump" in CicEnvironment.dump_to_channel oc; @@ -157,7 +186,7 @@ let _ = (fun cmd -> prerr_endline (GrafiteAstPp.pp_command - ~term_pp:(fun _ -> assert false) + ~term_pp:(fun t -> CicPp.ppterm t) ~obj_pp:(fun _ -> assert false) cmd)) (List.rev moo)); @@ -184,7 +213,7 @@ let _ = addDebugItem "Print current proof (natural language) to stderr" (fun _ -> prerr_endline - (ApplyTransformation.txt_of_cic_object 120 GrafiteAst.Declarative "" + (ApplyTransformation.txt_of_cic_object 120 [] ~map_unicode_to_tex:(Helm_registry.get_bool "matita.paste_unicode_as_tex") (match @@ -280,8 +309,9 @@ let _ = ~doc:(HExtlib.unopt (mview ())#get_document) ~name:"matita.xml" ())); *) addDebugItem "load (sequent) MathML from matita.xml" (fun _ -> (mview ())#load_uri ~filename:"matita.xml"); - addDebugItem "autoWin" - (fun _ -> MatitaAutoGui.auto_dialog Auto.get_auto_status); + addDebugSeparator (); + addDebugItem "Expand virtuals" + (fun _ -> (MatitaScript.current ())#expandAllVirtuals); end (** Debugging }}} *)