X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;ds=sidebyside;f=helm%2FgTopLevel%2FgTopLevel.ml;h=c6e8ac763c993e366f4051e2c8c33dbeb2ba3e77;hb=1dd5176f6d6a6247ebf941a1f6319a909f43d5fc;hp=58e6180f0107ea500f032adb06be71c0992d5d51;hpb=448714550fafa988ba45244ab150aca0a5e1999f;p=helm.git
diff --git a/helm/gTopLevel/gTopLevel.ml b/helm/gTopLevel/gTopLevel.ml
index 58e6180f0..c6e8ac763 100644
--- a/helm/gTopLevel/gTopLevel.ml
+++ b/helm/gTopLevel/gTopLevel.ml
@@ -85,6 +85,23 @@ let current_cic_infos = ref None;;
let current_goal_infos = ref None;;
let current_scratch_infos = ref None;;
+let id_to_uris = ref ([],function _ -> None);;
+
+let check_term = ref (fun _ _ _ -> assert false);;
+
+exception RenderingWindowsNotInitialized;;
+
+let set_rendering_window,rendering_window =
+ let rendering_window_ref = ref None in
+ (function rw -> rendering_window_ref := Some rw),
+ (function () ->
+ match !rendering_window_ref with
+ None -> raise RenderingWindowsNotInitialized
+ | Some rw -> rw
+ )
+;;
+ref None;;
+
(* COMMAND LINE OPTIONS *)
let usedb = ref true
@@ -121,6 +138,7 @@ let cic_textual_parser_uri_of_uri uri' =
)
;;
+
let term_of_uri uri =
let module C = Cic in
let module CTP = CicTextualParser0 in
@@ -131,6 +149,205 @@ let term_of_uri uri =
| CTP.IndConUri (uri,tyno,consno) -> C.MutConstruct (uri,tyno,consno,[])
;;
+(* UTILITY FUNCTIONS TO DISAMBIGUATE AN URI *)
+
+exception NoChoice;;
+
+let interactive_user_uri_choice ?(cancel="Cancel") ~title ~msg uris =
+ let choice = ref None in
+ let window = GWindow.dialog ~modal:true ~title () in
+ let lMessage =
+ GMisc.label ~text:msg ~packing:window#vbox#add () in
+ let vbox = GPack.vbox ~border_width:10
+ ~packing:(window#action_area#pack ~expand:true ~padding:4) () in
+ let hbox1 = GPack.hbox ~border_width:10 ~packing:vbox#add () in
+ let combo =
+ GEdit.combo ~popdown_strings:uris ~packing:hbox1#add () in
+ let checkb =
+ GButton.button ~label:"Check"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let hbox = GPack.hbox ~border_width:10 ~packing:vbox#add () in
+ let okb =
+ GButton.button ~label:"Ok"
+ ~packing:(hbox#pack ~expand:false ~fill:false ~padding:5) () in
+ let cancelb =
+ GButton.button ~label:cancel
+ ~packing:(hbox#pack ~expand:false ~fill:false ~padding:5) () in
+ (* actions *)
+ let ok_callback () =
+ choice := Some combo#entry#text ;
+ window#destroy ()
+ in
+ let check_callback () = !check_term [] [] (term_of_uri combo#entry#text) in
+ ignore (window#connect#destroy GMain.Main.quit) ;
+ ignore (cancelb#connect#clicked window#destroy) ;
+ ignore (okb#connect#clicked ok_callback) ;
+ ignore (checkb#connect#clicked check_callback) ;
+ window#set_position `CENTER ;
+ window#show () ;
+ GMain.Main.main () ;
+ match !choice with
+ None -> raise NoChoice
+ | Some uri -> uri
+;;
+
+(* MISC FUNCTIONS *)
+
+(* CSC: IMPERATIVE AND NOT VERY CLEAN, TO GET THE LAST ISSUED QUERY *)
+let get_last_query =
+ let query = ref "" in
+ MQueryGenerator.set_confirm_query
+ (function q -> query := MQueryUtil.text_of_query q ; true) ;
+ function result -> !query ^ "
Result:
" ^ MQueryUtil.text_of_result result "
"
+;;
+
+let register_alias (id,uri) =
+ let dom,resolve_id = !id_to_uris in
+ id_to_uris :=
+ (if List.mem id dom then dom else id::dom),
+ function id' -> if id' = id then Some uri else resolve_id id'
+;;
+
+let output_html outputhtml msg =
+ htmlheader_and_content := !htmlheader_and_content ^ msg ;
+ outputhtml#source (!htmlheader_and_content ^ htmlfooter) ;
+ outputhtml#set_topline (-1)
+;;
+
+let locate_one_id id =
+ let result = MQueryGenerator.locate id in
+ let uris =
+ List.map
+ (function uri,_ ->
+ wrong_xpointer_format_from_wrong_xpointer_format' uri
+ ) result in
+ let html= " Locate Query:
" ^ get_last_query result ^ "
" in
+ output_html (rendering_window ())#outputhtml html ;
+ let uris' =
+ match uris with
+ [] ->
+ (match
+ (GToolbox.input_string ~title:"Unknown input"
+ ("No URI matching \"" ^ id ^ "\" found. Please enter its URI"))
+ with
+ None -> raise NoChoice
+ | Some uri -> ["cic:" ^ uri]
+ )
+ | [uri] -> [uri]
+ | _ ->
+ try
+ [interactive_user_uri_choice
+ ~cancel:"Try every possibility."
+ ~title:"Ambiguous input."
+ ~msg:
+ ("Ambiguous input \"" ^ id ^
+ "\". Please, choose one interpretation:")
+ uris
+ ]
+ with
+ NoChoice -> uris
+ in
+ List.map cic_textual_parser_uri_of_uri uris'
+;;
+
+exception ThereDoesNotExistAnyWellTypedInterpretationOfTheInput;;
+exception AmbiguousInput;;
+
+let disambiguate_input context metasenv dom mk_metasenv_and_expr =
+ let known_ids,resolve_id = !id_to_uris in
+ let dom' =
+ let rec filter =
+ function
+ [] -> []
+ | he::tl ->
+ if List.mem he known_ids then filter tl else he::(filter tl)
+ in
+ filter dom
+ in
+ (* for each id in dom' we get the list of uris associated to it *)
+ let list_of_uris = List.map locate_one_id dom' in
+ (* and now we compute the list of all possible assignments from id to uris *)
+ let resolve_ids =
+ let rec aux ids list_of_uris =
+ match ids,list_of_uris with
+ [],[] -> [resolve_id]
+ | id::idtl,uris::uristl ->
+ let resolves = aux idtl uristl in
+ List.concat
+ (List.map
+ (function uri ->
+ List.map
+ (function f ->
+ function id' -> if id = id' then Some uri else f id'
+ ) resolves
+ ) uris
+ )
+ | _,_ -> assert false
+ in
+ aux dom' list_of_uris
+ in
+prerr_endline ("##### NE DISAMBIGUO: " ^ string_of_int (List.length resolve_ids)) ;
+ (* now we select only the ones that generates well-typed terms *)
+ let resolve_ids' =
+ let rec filter =
+ function
+ [] -> []
+ | resolve::tl ->
+ let metasenv',expr = mk_metasenv_and_expr resolve in
+ try
+(*CSC: Bug here: we do not try to typecheck also the metasenv' *)
+ ignore
+ (CicTypeChecker.type_of_aux' metasenv context expr) ;
+ resolve::(filter tl)
+ with
+ _ -> filter tl
+ in
+ filter resolve_ids
+ in
+ let resolve_id' =
+ match resolve_ids' with
+ [] -> raise ThereDoesNotExistAnyWellTypedInterpretationOfTheInput
+ | [resolve_id] -> resolve_id
+ | _ ->
+ let choices =
+ List.map
+ (function resolve ->
+ String.concat " ; "
+ (List.map
+ (function id ->
+ id ^ " := " ^
+ match resolve id with
+ None -> assert false
+ | Some uri ->
+ match uri with
+ CicTextualParser0.ConUri uri
+ | CicTextualParser0.VarUri uri ->
+ UriManager.string_of_uri uri
+ | CicTextualParser0.IndTyUri (uri,tyno) ->
+ UriManager.string_of_uri uri ^ "#xpointer(1/" ^
+ string_of_int (tyno+1) ^ ")"
+ | CicTextualParser0.IndConUri (uri,tyno,consno) ->
+ UriManager.string_of_uri uri ^ "#xpointer(1/" ^
+ string_of_int (tyno+1) ^ "/" ^ string_of_int consno ^ ")"
+ ) dom
+ )
+ ) resolve_ids'
+ in
+ let choice =
+ GToolbox.question_box ~title:"Ambiguous input."
+ ~buttons:choices
+ ~default:1 "Ambiguous input. Please, choose one interpretation."
+ in
+ if choice > 0 then
+ List.nth resolve_ids' (choice - 1)
+ else
+ (* No choice from the user *)
+ raise NoChoice
+ in
+ id_to_uris := known_ids @ dom', resolve_id' ;
+ mk_metasenv_and_expr resolve_id'
+;;
+
let domImpl = Gdome.domImplementation ();;
let parseStyle name =
@@ -272,10 +489,17 @@ prerr_endline ("Offending proof: " ^ CicPp.ppobj (Cic.CurrentProof ("questa",met
raise (RefreshProofException e)
;;
-let refresh_sequent (proofw : GMathView.math_view) =
+let refresh_sequent ?(empty_notebook=true) notebook =
try
match !ProofEngine.goal with
- None -> proofw#unload
+ None ->
+ if empty_notebook then
+ begin
+ notebook#remove_all_pages ;
+ notebook#set_empty_page
+ end
+ else
+ notebook#proofw#unload
| Some metano ->
let metasenv =
match !ProofEngine.proof with
@@ -292,7 +516,13 @@ let refresh_sequent (proofw : GMathView.math_view) =
let sequent_mml =
applyStylesheets sequent_doc sequent_styles sequent_args
in
- proofw#load_tree ~dom:sequent_mml ;
+ if empty_notebook then
+ begin
+ notebook#remove_all_pages ;
+ List.iter (function (m,_,_) -> notebook#add_page m) metasenv ;
+ end ;
+ notebook#set_current_page metano ;
+ notebook#proofw#load_tree ~dom:sequent_mml ;
current_goal_infos :=
Some (ids_to_terms,ids_to_father_ids,ids_to_hypotheses)
with
@@ -346,26 +576,20 @@ let mml_of_cic_term metano term =
res
;;
-let output_html outputhtml msg =
- htmlheader_and_content := !htmlheader_and_content ^ msg ;
- outputhtml#source (!htmlheader_and_content ^ htmlfooter) ;
- outputhtml#set_topline (-1)
-;;
-
(***********************)
(* TACTICS *)
(***********************)
-let call_tactic tactic rendering_window () =
- let proofw = (rendering_window#proofw : GMathView.math_view) in
- let output = (rendering_window#output : GMathView.math_view) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
+let call_tactic tactic () =
+ let notebook = (rendering_window ())#notebook in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
let savedproof = !ProofEngine.proof in
let savedgoal = !ProofEngine.goal in
begin
try
tactic () ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output
with
RefreshSequentException e ->
@@ -374,14 +598,14 @@ let call_tactic tactic rendering_window () =
"sequent: " ^ Printexc.to_string e ^ "") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw
+ refresh_sequent notebook
| RefreshProofException e ->
output_html outputhtml
("Exception raised during the refresh of the " ^
"proof: " ^ Printexc.to_string e ^ "
") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output
| e ->
output_html outputhtml
@@ -391,11 +615,11 @@ let call_tactic tactic rendering_window () =
end
;;
-let call_tactic_with_input tactic rendering_window () =
- let proofw = (rendering_window#proofw : GMathView.math_view) in
- let output = (rendering_window#output : GMathView.math_view) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let inputt = (rendering_window#inputt : GEdit.text) in
+let call_tactic_with_input tactic () =
+ let notebook = (rendering_window ())#notebook in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
let savedproof = !ProofEngine.proof in
let savedgoal = !ProofEngine.goal in
(*CSC: Gran cut&paste da sotto... *)
@@ -412,32 +636,38 @@ let call_tactic_with_input tactic rendering_window () =
None -> assert false
| Some (uri,metasenv,bo,ty) -> uri,metasenv,bo,ty
in
+ let canonical_context =
+ match !ProofEngine.goal with
+ None -> assert false
+ | Some metano ->
+ let (_,canonical_context,_) =
+ List.find (function (m,_,_) -> m=metano) metasenv
+ in
+ canonical_context
+ in
let context =
List.map
(function
Some (n,_) -> Some n
- | None -> None)
- (match !ProofEngine.goal with
- None -> assert false
- | Some metano ->
- let (_,canonical_context,_) =
- List.find (function (m,_,_) -> m=metano) metasenv
- in
- canonical_context
- )
+ | None -> None
+ ) canonical_context
in
try
while true do
match
- CicTextualParserContext.main
- curi context metasenv CicTextualLexer.token lexbuf
+ CicTextualParserContext.main context metasenv CicTextualLexer.token
+ lexbuf register_alias
with
None -> ()
- | Some (metasenv',expr) ->
- ProofEngine.proof := Some (uri,metasenv',bo,ty) ;
- tactic expr ;
- refresh_sequent proofw ;
- refresh_proof output
+ | Some (dom,mk_metasenv_and_expr) ->
+ let (metasenv',expr) =
+ disambiguate_input canonical_context metasenv dom
+ mk_metasenv_and_expr
+ in
+ ProofEngine.proof := Some (uri,metasenv',bo,ty) ;
+ tactic expr ;
+ refresh_sequent notebook ;
+ refresh_proof output
done
with
CicTextualParser0.Eof ->
@@ -448,14 +678,14 @@ let call_tactic_with_input tactic rendering_window () =
"sequent: " ^ Printexc.to_string e ^ "") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw
+ refresh_sequent notebook
| RefreshProofException e ->
output_html outputhtml
("Exception raised during the refresh of the " ^
"proof: " ^ Printexc.to_string e ^ "
") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output
| e ->
output_html outputhtml
@@ -464,15 +694,15 @@ let call_tactic_with_input tactic rendering_window () =
ProofEngine.goal := savedgoal ;
;;
-let call_tactic_with_goal_input tactic rendering_window () =
+let call_tactic_with_goal_input tactic () =
let module L = LogicalOperations in
let module G = Gdome in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
- let output = (rendering_window#output : GMathView.math_view) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
+ let notebook = (rendering_window ())#notebook in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
let savedproof = !ProofEngine.proof in
let savedgoal = !ProofEngine.goal in
- match proofw#get_selection with
+ match notebook#proofw#get_selection with
Some node ->
let xpath =
((node : Gdome.element)#getAttributeNS
@@ -487,8 +717,8 @@ let call_tactic_with_goal_input tactic rendering_window () =
Some (ids_to_terms, ids_to_father_ids,_) ->
let id = xpath in
tactic (Hashtbl.find ids_to_terms id) ;
- refresh_sequent rendering_window#proofw ;
- refresh_proof rendering_window#output
+ refresh_sequent notebook ;
+ refresh_proof output
| None -> assert false (* "ERROR: No current term!!!" *)
with
RefreshSequentException e ->
@@ -497,14 +727,14 @@ let call_tactic_with_goal_input tactic rendering_window () =
"sequent: " ^ Printexc.to_string e ^ "") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw
+ refresh_sequent notebook
| RefreshProofException e ->
output_html outputhtml
("Exception raised during the refresh of the " ^
"proof: " ^ Printexc.to_string e ^ "
") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output
| e ->
output_html outputhtml
@@ -517,16 +747,16 @@ let call_tactic_with_goal_input tactic rendering_window () =
("No term selected
")
;;
-let call_tactic_with_input_and_goal_input tactic rendering_window () =
+let call_tactic_with_input_and_goal_input tactic () =
let module L = LogicalOperations in
let module G = Gdome in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
- let output = (rendering_window#output : GMathView.math_view) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let inputt = (rendering_window#inputt : GEdit.text) in
+ let notebook = (rendering_window ())#notebook in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
let savedproof = !ProofEngine.proof in
let savedgoal = !ProofEngine.goal in
- match proofw#get_selection with
+ match notebook#proofw#get_selection with
Some node ->
let xpath =
((node : Gdome.element)#getAttributeNS
@@ -554,34 +784,39 @@ let call_tactic_with_input_and_goal_input tactic rendering_window () =
None -> assert false
| Some (uri,metasenv,bo,ty) -> uri,metasenv,bo,ty
in
+ let canonical_context =
+ match !ProofEngine.goal with
+ None -> assert false
+ | Some metano ->
+ let (_,canonical_context,_) =
+ List.find (function (m,_,_) -> m=metano) metasenv
+ in
+ canonical_context in
let context =
List.map
(function
Some (n,_) -> Some n
- | None -> None)
- (match !ProofEngine.goal with
- None -> assert false
- | Some metano ->
- let (_,canonical_context,_) =
- List.find (function (m,_,_) -> m=metano) metasenv
- in
- canonical_context
- )
+ | None -> None
+ ) canonical_context
in
begin
try
while true do
match
- CicTextualParserContext.main curi context metasenv
- CicTextualLexer.token lexbuf
+ CicTextualParserContext.main context metasenv
+ CicTextualLexer.token lexbuf register_alias
with
None -> ()
- | Some (metasenv',expr) ->
- ProofEngine.proof := Some (uri,metasenv',bo,ty) ;
- tactic ~goal_input:(Hashtbl.find ids_to_terms id)
- ~input:expr ;
- refresh_sequent proofw ;
- refresh_proof output
+ | Some (dom,mk_metasenv_and_expr) ->
+ let (metasenv',expr) =
+ disambiguate_input canonical_context metasenv dom
+ mk_metasenv_and_expr
+ in
+ ProofEngine.proof := Some (uri,metasenv',bo,ty) ;
+ tactic ~goal_input:(Hashtbl.find ids_to_terms id)
+ ~input:expr ;
+ refresh_sequent notebook ;
+ refresh_proof output
done
with
CicTextualParser0.Eof ->
@@ -595,14 +830,14 @@ let call_tactic_with_input_and_goal_input tactic rendering_window () =
"sequent: " ^ Printexc.to_string e ^ "") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw
+ refresh_sequent notebook
| RefreshProofException e ->
output_html outputhtml
("Exception raised during the refresh of the " ^
"proof: " ^ Printexc.to_string e ^ "
") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output
| e ->
output_html outputhtml
@@ -652,15 +887,15 @@ let call_tactic_with_goal_input_in_scratch tactic scratch_window () =
("No term selected
")
;;
-let call_tactic_with_hypothesis_input tactic rendering_window () =
+let call_tactic_with_hypothesis_input tactic () =
let module L = LogicalOperations in
let module G = Gdome in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
- let output = (rendering_window#output : GMathView.math_view) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
+ let notebook = (rendering_window ())#notebook in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
let savedproof = !ProofEngine.proof in
let savedgoal = !ProofEngine.goal in
- match proofw#get_selection with
+ match notebook#proofw#get_selection with
Some node ->
let xpath =
((node : Gdome.element)#getAttributeNS
@@ -675,8 +910,8 @@ let call_tactic_with_hypothesis_input tactic rendering_window () =
Some (_,_,ids_to_hypotheses) ->
let id = xpath in
tactic (Hashtbl.find ids_to_hypotheses id) ;
- refresh_sequent rendering_window#proofw ;
- refresh_proof rendering_window#output
+ refresh_sequent notebook ;
+ refresh_proof output
| None -> assert false (* "ERROR: No current term!!!" *)
with
RefreshSequentException e ->
@@ -685,14 +920,14 @@ let call_tactic_with_hypothesis_input tactic rendering_window () =
"sequent: " ^ Printexc.to_string e ^ "") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw
+ refresh_sequent notebook
| RefreshProofException e ->
output_html outputhtml
("Exception raised during the refresh of the " ^
"proof: " ^ Printexc.to_string e ^ "
") ;
ProofEngine.proof := savedproof ;
ProofEngine.goal := savedgoal ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output
| e ->
output_html outputhtml
@@ -706,77 +941,29 @@ let call_tactic_with_hypothesis_input tactic rendering_window () =
;;
-let intros rendering_window = call_tactic ProofEngine.intros rendering_window;;
-let exact rendering_window =
- call_tactic_with_input ProofEngine.exact rendering_window
-;;
-let apply rendering_window =
- call_tactic_with_input ProofEngine.apply rendering_window
-;;
-let elimsimplintros rendering_window =
- call_tactic_with_input ProofEngine.elim_simpl_intros rendering_window
-;;
-let elimtype rendering_window =
- call_tactic_with_input ProofEngine.elim_type rendering_window
-;;
-let whd rendering_window =
- call_tactic_with_goal_input ProofEngine.whd rendering_window
-;;
-let reduce rendering_window =
- call_tactic_with_goal_input ProofEngine.reduce rendering_window
-;;
-let simpl rendering_window =
- call_tactic_with_goal_input ProofEngine.simpl rendering_window
-;;
-let fold rendering_window =
- call_tactic_with_input ProofEngine.fold rendering_window
-;;
-let cut rendering_window =
- call_tactic_with_input ProofEngine.cut rendering_window
-;;
-let change rendering_window =
- call_tactic_with_input_and_goal_input ProofEngine.change rendering_window
-;;
-let letin rendering_window =
- call_tactic_with_input ProofEngine.letin rendering_window
-;;
-let ring rendering_window = call_tactic ProofEngine.ring rendering_window;;
-let clearbody rendering_window =
- call_tactic_with_hypothesis_input ProofEngine.clearbody rendering_window
-;;
-let clear rendering_window =
- call_tactic_with_hypothesis_input ProofEngine.clear rendering_window
-;;
-let fourier rendering_window =
- call_tactic ProofEngine.fourier rendering_window
-;;
-let rewritesimpl rendering_window =
- call_tactic_with_input ProofEngine.rewrite_simpl rendering_window
-;;
-let reflexivity rendering_window =
- call_tactic ProofEngine.reflexivity rendering_window
-;;
-let symmetry rendering_window =
- call_tactic ProofEngine.symmetry rendering_window
-;;
-let transitivity rendering_window =
- call_tactic_with_input ProofEngine.transitivity rendering_window
-;;
-let left rendering_window =
- call_tactic ProofEngine.left rendering_window
-;;
-let right rendering_window =
- call_tactic ProofEngine.right rendering_window
-;;
-let assumption rendering_window =
- call_tactic ProofEngine.assumption rendering_window
-;;
-(*
-let prova_tatticali rendering_window =
- call_tactic ProofEngine.prova_tatticali rendering_window
-;;
-*)
-
+let intros = call_tactic ProofEngine.intros;;
+let exact = call_tactic_with_input ProofEngine.exact;;
+let apply = call_tactic_with_input ProofEngine.apply;;
+let elimsimplintros = call_tactic_with_input ProofEngine.elim_simpl_intros;;
+let elimtype = call_tactic_with_input ProofEngine.elim_type;;
+let whd = call_tactic_with_goal_input ProofEngine.whd;;
+let reduce = call_tactic_with_goal_input ProofEngine.reduce;;
+let simpl = call_tactic_with_goal_input ProofEngine.simpl;;
+let fold = call_tactic_with_input ProofEngine.fold;;
+let cut = call_tactic_with_input ProofEngine.cut;;
+let change = call_tactic_with_input_and_goal_input ProofEngine.change;;
+let letin = call_tactic_with_input ProofEngine.letin;;
+let ring = call_tactic ProofEngine.ring;;
+let clearbody = call_tactic_with_hypothesis_input ProofEngine.clearbody;;
+let clear = call_tactic_with_hypothesis_input ProofEngine.clear;;
+let fourier = call_tactic ProofEngine.fourier;;
+let rewritesimpl = call_tactic_with_input ProofEngine.rewrite_simpl;;
+let reflexivity = call_tactic ProofEngine.reflexivity;;
+let symmetry = call_tactic ProofEngine.symmetry;;
+let transitivity = call_tactic_with_input ProofEngine.transitivity;;
+let left = call_tactic ProofEngine.left;;
+let right = call_tactic ProofEngine.right;;
+let assumption = call_tactic ProofEngine.assumption;;
let whd_in_scratch scratch_window =
call_tactic_with_goal_input_in_scratch ProofEngine.whd_in_scratch
@@ -800,7 +987,7 @@ let simpl_in_scratch scratch_window =
exception OpenConjecturesStillThere;;
exception WrongProof;;
-let qed rendering_window () =
+let qed () =
match !ProofEngine.proof with
None -> assert false
| Some (uri,[],bo,ty) ->
@@ -820,7 +1007,7 @@ let qed rendering_window () =
let mml =
mml_of_cic_object uri acic ids_to_inner_sorts ids_to_inner_types
in
- (rendering_window#output : GMathView.math_view)#load_tree mml ;
+ ((rendering_window ())#output : GMathView.math_view)#load_tree mml ;
current_cic_infos :=
Some
(ids_to_terms,ids_to_father_ids,ids_to_conjectures,
@@ -837,8 +1024,8 @@ let dtdname = "/home/tassi/miohelm/helm/dtd/cic.dtd";;
*)
let dtdname = "/projects/helm/V7_mowgli/dtd/cic.dtd";;
-let save rendering_window () =
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
+let save () =
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
match !ProofEngine.proof with
None -> assert false
| Some (uri, metasenv, bo, ty) ->
@@ -877,11 +1064,10 @@ let typecheck_loaded_proof metasenv bo ty =
ignore (T.type_of_aux' metasenv [] bo)
;;
-(*CSC: ancora da implementare *)
-let load rendering_window () =
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let output = (rendering_window#output : GMathView.math_view) in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
+let load () =
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let notebook = (rendering_window ())#notebook in
try
let uri = UriManager.uri_of_string "cic:/dummy.con" in
match CicParser.obj_of_xml prooffiletype (Some prooffile) with
@@ -895,7 +1081,7 @@ let load rendering_window () =
| (metano,_,_)::_ -> Some metano
) ;
refresh_proof output ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
output_html outputhtml
("Current proof type loaded from " ^
prooffiletype ^ "
") ;
@@ -917,11 +1103,13 @@ let load rendering_window () =
("" ^ Printexc.to_string e ^ "
") ;
;;
-let proveit rendering_window () =
+let proveit () =
let module L = LogicalOperations in
let module G = Gdome in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- match rendering_window#output#get_selection with
+ let notebook = (rendering_window ())#notebook in
+ let output = (rendering_window ())#output in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ match (rendering_window ())#output#get_selection with
Some node ->
let xpath =
((node : Gdome.element)#getAttributeNS
@@ -939,8 +1127,8 @@ let proveit rendering_window () =
Some (ids_to_terms, ids_to_father_ids, _, _) ->
let id = xpath in
L.to_sequent id ids_to_terms ids_to_father_ids ;
- refresh_proof rendering_window#output ;
- refresh_sequent rendering_window#proofw
+ refresh_proof output ;
+ refresh_sequent notebook
| None -> assert false (* "ERROR: No current term!!!" *)
with
RefreshSequentException e ->
@@ -958,11 +1146,12 @@ let proveit rendering_window () =
| None -> assert false (* "ERROR: No selection!!!" *)
;;
-let focus rendering_window () =
+let focus () =
let module L = LogicalOperations in
let module G = Gdome in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- match rendering_window#output#get_selection with
+ let notebook = (rendering_window ())#notebook in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ match (rendering_window ())#output#get_selection with
Some node ->
let xpath =
((node : Gdome.element)#getAttributeNS
@@ -980,7 +1169,7 @@ let focus rendering_window () =
Some (ids_to_terms, ids_to_father_ids, _, _) ->
let id = xpath in
L.focus id ids_to_terms ids_to_father_ids ;
- refresh_sequent rendering_window#proofw
+ refresh_sequent notebook
| None -> assert false (* "ERROR: No current term!!!" *)
with
RefreshSequentException e ->
@@ -1001,45 +1190,19 @@ let focus rendering_window () =
exception NoPrevGoal;;
exception NoNextGoal;;
-let prevgoal metasenv metano =
- let rec aux =
- function
- [] -> assert false
- | [(m,_,_)] -> raise NoPrevGoal
- | (n,_,_)::(m,_,_)::_ when m=metano -> n
- | _::tl -> aux tl
- in
- aux metasenv
-;;
-
-let nextgoal metasenv metano =
- let rec aux =
- function
- [] -> assert false
- | [(m,_,_)] when m = metano -> raise NoNextGoal
- | (m,_,_)::(n,_,_)::_ when m=metano -> n
- | _::tl -> aux tl
- in
- aux metasenv
-;;
-
-let prev_or_next_goal select_goal rendering_window () =
+let setgoal metano =
let module L = LogicalOperations in
let module G = Gdome in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
+ let notebook = (rendering_window ())#notebook in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
let metasenv =
match !ProofEngine.proof with
None -> assert false
| Some (_,metasenv,_,_) -> metasenv
- in
- let metano =
- match !ProofEngine.goal with
- None -> assert false
- | Some m -> m
in
try
- ProofEngine.goal := Some (select_goal metasenv metano) ;
- refresh_sequent rendering_window#proofw
+ ProofEngine.goal := Some metano ;
+ refresh_sequent ~empty_notebook:false notebook ;
with
RefreshSequentException e ->
output_html outputhtml
@@ -1052,12 +1215,12 @@ let prev_or_next_goal select_goal rendering_window () =
exception NotADefinition;;
-let open_ rendering_window () =
- let inputt = (rendering_window#inputt : GEdit.text) in
- let oldinputt = (rendering_window#oldinputt : GEdit.text) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let output = (rendering_window#output : GMathView.math_view) in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
+let open_ () =
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
+ let oldinputt = ((rendering_window ())#oldinputt : GEdit.text) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let notebook = (rendering_window ())#notebook in
let inputlen = inputt#length in
let input = inputt#get_chars 0 inputlen in
try
@@ -1074,7 +1237,7 @@ let open_ rendering_window () =
ProofEngine.proof :=
Some (uri, metasenv, bo, ty) ;
ProofEngine.goal := None ;
- refresh_sequent proofw ;
+ refresh_sequent notebook ;
refresh_proof output ;
inputt#delete_text 0 inputlen ;
ignore(oldinputt#insert_text input oldinputt#length)
@@ -1092,12 +1255,12 @@ let open_ rendering_window () =
("" ^ Printexc.to_string e ^ "
") ;
;;
-let state rendering_window () =
- let inputt = (rendering_window#inputt : GEdit.text) in
- let oldinputt = (rendering_window#oldinputt : GEdit.text) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let output = (rendering_window#output : GMathView.math_view) in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
+let state () =
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
+ let oldinputt = ((rendering_window ())#oldinputt : GEdit.text) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ let output = ((rendering_window ())#output : GMathView.math_view) in
+ let notebook = (rendering_window ())#notebook in
let inputlen = inputt#length in
let input = inputt#get_chars 0 inputlen ^ "\n" in
(* Do something interesting *)
@@ -1105,16 +1268,22 @@ let state rendering_window () =
try
while true do
(* Execute the actions *)
- match CicTextualParser.main CicTextualLexer.token lexbuf with
+ match
+ CicTextualParserContext.main [] [] CicTextualLexer.token
+ lexbuf register_alias
+ with
None -> ()
- | Some expr ->
- let _ = CicTypeChecker.type_of_aux' [] [] expr in
- ProofEngine.proof :=
- Some (UriManager.uri_of_string "cic:/dummy.con",
- [1,[],expr], Cic.Meta (1,[]), expr) ;
- ProofEngine.goal := Some 1 ;
- refresh_sequent proofw ;
- refresh_proof output ;
+ | Some (dom,mk_metasenv_and_expr) ->
+ let metasenv,expr =
+ disambiguate_input [] [] dom mk_metasenv_and_expr
+ in
+ let _ = CicTypeChecker.type_of_aux' metasenv [] expr in
+ ProofEngine.proof :=
+ Some (UriManager.uri_of_string "cic:/dummy.con",
+ (1,[],expr)::metasenv, Cic.Meta (1,[]), expr) ;
+ ProofEngine.goal := Some 1 ;
+ refresh_sequent notebook ;
+ refresh_proof output ;
done
with
CicTextualParser0.Eof ->
@@ -1133,11 +1302,22 @@ let state rendering_window () =
("" ^ Printexc.to_string e ^ "
") ;
;;
-let check rendering_window scratch_window () =
- let inputt = (rendering_window#inputt : GEdit.text) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let output = (rendering_window#output : GMathView.math_view) in
- let proofw = (rendering_window#proofw : GMathView.math_view) in
+let check_term_in_scratch scratch_window metasenv context expr =
+ try
+ let ty = CicTypeChecker.type_of_aux' metasenv context expr in
+ let mml = mml_of_cic_term 111 (Cic.Cast (expr,ty)) in
+prerr_endline ("### " ^ CicPp.ppterm expr ^ " ==> " ^ CicPp.ppterm ty) ;
+ scratch_window#show () ;
+ scratch_window#mmlwidget#load_tree ~dom:mml
+ with
+ e ->
+ print_endline ("? " ^ CicPp.ppterm expr) ;
+ raise e
+;;
+
+let check scratch_window () =
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
let inputlen = inputt#length in
let input = inputt#get_chars 0 inputlen ^ "\n" in
let curi,metasenv =
@@ -1167,21 +1347,15 @@ let check rendering_window scratch_window () =
while true do
(* Execute the actions *)
match
- CicTextualParserContext.main curi names_context metasenv
- CicTextualLexer.token lexbuf
+ CicTextualParserContext.main names_context metasenv CicTextualLexer.token
+ lexbuf register_alias
with
None -> ()
- | Some (metasenv',expr) ->
- try
- let ty = CicTypeChecker.type_of_aux' metasenv' context expr in
- let mml = mml_of_cic_term 111 (Cic.Cast (expr,ty)) in
-prerr_endline ("### " ^ CicPp.ppterm expr ^ " ==> " ^ CicPp.ppterm ty) ;
- scratch_window#show () ;
- scratch_window#mmlwidget#load_tree ~dom:mml
- with
- e ->
- print_endline ("? " ^ CicPp.ppterm expr) ;
- raise e
+ | Some (dom,mk_metasenv_and_expr) ->
+ let (metasenv',expr) =
+ disambiguate_input context metasenv dom mk_metasenv_and_expr
+ in
+ check_term_in_scratch scratch_window metasenv' context expr
done
with
CicTextualParser0.Eof -> ()
@@ -1192,33 +1366,20 @@ prerr_endline ("### " ^ CicPp.ppterm expr ^ " ==> " ^ CicPp.ppterm ty) ;
exception NoObjectsLocated;;
-let user_uri_choice uris =
+let user_uri_choice ~title ~msg uris =
let uri =
match uris with
[] -> raise NoObjectsLocated
| [uri] -> uri
| uris ->
- let choice =
- GToolbox.question_box ~title:"Ambiguous result."
- ~buttons:uris ~default:1
- "Ambiguous result. Please, choose one."
- in
- List.nth uris (choice-1)
+ interactive_user_uri_choice ~title ~msg uris
in
String.sub uri 4 (String.length uri - 4)
;;
-(* CSC: IMPERATIVE AND NOT VERY CLEAN, TO GET THE LAST ISSUED QUERY *)
-let get_last_query =
- let query = ref "" in
- MQueryGenerator.set_confirm_query
- (function q -> query := MQueryUtil.text_of_query q ; true) ;
- function result -> !query ^ " Result:
" ^ MQueryUtil.text_of_result result "
"
-;;
-
-let locate rendering_window () =
- let inputt = (rendering_window#inputt : GEdit.text) in
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
+let locate () =
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
let inputlen = inputt#length in
let input = inputt#get_chars 0 inputlen in
try
@@ -1233,7 +1394,13 @@ let locate rendering_window () =
result in
let html = (" Locate Query:
" ^ get_last_query result ^ "
") in
output_html outputhtml html ;
- let uri' = user_uri_choice uris in
+ let uri' =
+ user_uri_choice ~title:"Ambiguous input."
+ ~msg:
+ ("Ambiguous input \"" ^ head ^
+ "\". Please, choose one interpetation:")
+ uris
+ in
ignore ((inputt#insert_text uri') ~pos:0)
with
e ->
@@ -1241,9 +1408,9 @@ let locate rendering_window () =
("" ^ Printexc.to_string e ^ "
")
;;
-let searchPattern rendering_window () =
- let outputhtml = (rendering_window#outputhtml : GHtml.xmhtml) in
- let inputt = (rendering_window#inputt : GEdit.text) in
+let searchPattern () =
+ let outputhtml = ((rendering_window ())#outputhtml : GHtml.xmhtml) in
+ let inputt = ((rendering_window ())#inputt : GEdit.text) in
let inputlen = inputt#length in
let input = inputt#get_chars 0 inputlen in
let level = int_of_string input in
@@ -1300,7 +1467,11 @@ let searchPattern rendering_window () =
string_of_int (List.length uris') ^ ""
in
output_html outputhtml html' ;
- let uri' = user_uri_choice uris' in
+ let uri' =
+ user_uri_choice ~title:"Ambiguous input."
+ ~msg:"Many lemmas can be successfully applied. Please, choose one:"
+ uris'
+ in
inputt#delete_text 0 inputlen ;
ignore ((inputt#insert_text uri') ~pos:0)
with
@@ -1490,81 +1661,14 @@ object(self)
ignore(simplb#connect#clicked (simpl_in_scratch self))
end;;
-(* Main window *)
-
-class rendering_window output proofw (label : GMisc.label) =
- let window =
- GWindow.window ~title:"MathML viewer" ~border_width:2 () in
- let hbox0 =
- GPack.hbox ~packing:window#add () in
- let vbox =
- GPack.vbox ~packing:(hbox0#pack ~expand:false ~fill:false ~padding:5) () in
- let _ = vbox#pack ~expand:false ~fill:false ~padding:5 label#coerce in
- let scrolled_window0 =
- GBin.scrolled_window ~border_width:10
- ~packing:(vbox#pack ~expand:true ~padding:5) () in
- let _ = scrolled_window0#add output#coerce in
- let hbox1 =
- GPack.hbox ~packing:(vbox#pack ~expand:false ~fill:false ~padding:5) () in
- let settingsb =
- GButton.button ~label:"Settings"
- ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
- let button_export_to_postscript =
- GButton.button ~label:"export_to_postscript"
- ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
- let qedb =
- GButton.button ~label:"Qed"
- ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
- let saveb =
- GButton.button ~label:"Save"
- ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
- let loadb =
- GButton.button ~label:"Load"
- ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
- let closeb =
- GButton.button ~label:"Close"
- ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
- let hbox2 =
- GPack.hbox ~packing:(vbox#pack ~expand:false ~fill:false ~padding:5) () in
- let proveitb =
- GButton.button ~label:"Prove It"
- ~packing:(hbox2#pack ~expand:false ~fill:false ~padding:5) () in
- let focusb =
- GButton.button ~label:"Focus"
- ~packing:(hbox2#pack ~expand:false ~fill:false ~padding:5) () in
- let prevgoalb =
- GButton.button ~label:"<"
- ~packing:(hbox2#pack ~expand:false ~fill:false ~padding:5) () in
- let nextgoalb =
- GButton.button ~label:">"
- ~packing:(hbox2#pack ~expand:false ~fill:false ~padding:5) () in
- let oldinputt = GEdit.text ~editable:false ~width:400 ~height:180
- ~packing:(vbox#pack ~padding:5) () in
- let hbox4 =
- GPack.hbox ~packing:(vbox#pack ~expand:false ~fill:false ~padding:5) () in
- let stateb =
- GButton.button ~label:"State"
- ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
- let openb =
- GButton.button ~label:"Open"
- ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
- let checkb =
- GButton.button ~label:"Check"
- ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
- let locateb =
- GButton.button ~label:"Locate"
- ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
- let searchpatternb =
- GButton.button ~label:"SearchPattern"
- ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
- let inputt = GEdit.text ~editable:true ~width:400 ~height: 100
- ~packing:(vbox#pack ~padding:5) () in
- let vbox1 =
- GPack.vbox ~packing:(hbox0#pack ~expand:false ~fill:false ~padding:5) () in
+class page () =
+ let vbox1 = GPack.vbox () in
let scrolled_window1 =
GBin.scrolled_window ~border_width:10
~packing:(vbox1#pack ~expand:true ~padding:5) () in
- let _ = scrolled_window1#add proofw#coerce in
+ let proofw =
+ GMathView.math_view ~width:400 ~height:275
+ ~packing:(scrolled_window1#add) () in
let hbox3 =
GPack.hbox ~packing:(vbox1#pack ~expand:false ~fill:false ~padding:5) () in
let exactb =
@@ -1640,147 +1744,203 @@ class rendering_window output proofw (label : GMisc.label) =
let assumptionb =
GButton.button ~label:"Assumption"
~packing:(hbox5#pack ~expand:false ~fill:false ~padding:5) () in
-(*
- let prova_tatticalib =
- GButton.button ~label:"Prova_tatticali"
- ~packing:(hbox5#pack ~expand:false ~fill:false ~padding:5) () in
-*)
+object
+ method proofw = proofw
+ method content = vbox1
+ initializer
+ ignore(exactb#connect#clicked exact) ;
+ ignore(applyb#connect#clicked apply) ;
+ ignore(elimsimplintrosb#connect#clicked elimsimplintros) ;
+ ignore(elimtypeb#connect#clicked elimtype) ;
+ ignore(whdb#connect#clicked whd) ;
+ ignore(reduceb#connect#clicked reduce) ;
+ ignore(simplb#connect#clicked simpl) ;
+ ignore(foldb#connect#clicked fold) ;
+ ignore(cutb#connect#clicked cut) ;
+ ignore(changeb#connect#clicked change) ;
+ ignore(letinb#connect#clicked letin) ;
+ ignore(ringb#connect#clicked ring) ;
+ ignore(clearbodyb#connect#clicked clearbody) ;
+ ignore(clearb#connect#clicked clear) ;
+ ignore(fourierb#connect#clicked fourier) ;
+ ignore(rewritesimplb#connect#clicked rewritesimpl) ;
+ ignore(reflexivityb#connect#clicked reflexivity) ;
+ ignore(symmetryb#connect#clicked symmetry) ;
+ ignore(transitivityb#connect#clicked transitivity) ;
+ ignore(leftb#connect#clicked left) ;
+ ignore(rightb#connect#clicked right) ;
+ ignore(assumptionb#connect#clicked assumption) ;
+ ignore(introsb#connect#clicked intros) ;
+ initializer
+ ignore(proofw#connect#selection_changed (choose_selection proofw)) ;
+end
+;;
+
+class notebook =
+object(self)
+ val notebook = GPack.notebook ()
+ val pages = ref []
+ val mutable skip_switch_page_event = false
+ method notebook = notebook
+ method add_page n =
+ let new_page = new page () in
+ pages := !pages @ [n,new_page] ;
+ notebook#append_page
+ ~tab_label:((GMisc.label ~text:("?" ^ string_of_int n) ())#coerce)
+ new_page#content#coerce
+ method remove_all_pages =
+ List.iter (function _ -> notebook#remove_page 0) !pages ;
+ pages := [] ;
+ method set_current_page n =
+ let (_,page) = List.find (function (m,_) -> m=n) !pages in
+ let new_page = notebook#page_num page#content#coerce in
+ if new_page <> notebook#current_page then
+ skip_switch_page_event <- true ;
+ notebook#goto_page new_page
+ method set_empty_page = self#add_page (-1)
+ method proofw =
+ (snd (List.nth !pages notebook#current_page))#proofw
+ initializer
+ ignore
+ (notebook#connect#switch_page
+ (function i ->
+ let skip = skip_switch_page_event in
+ skip_switch_page_event <- false ;
+ if not skip then
+ try
+ let metano = fst (List.nth !pages i) in
+ setgoal metano
+ with _ -> ()
+ ))
+end
+;;
+
+(* Main window *)
+
+class rendering_window output (notebook : notebook) (label : GMisc.label) =
+ let window =
+ GWindow.window ~title:"MathML viewer" ~border_width:2 () in
+ let hbox0 =
+ GPack.hbox ~packing:window#add () in
+ let vbox =
+ GPack.vbox ~packing:(hbox0#pack ~expand:false ~fill:false ~padding:5) () in
+ let _ = vbox#pack ~expand:false ~fill:false ~padding:5 label#coerce in
+ let scrolled_window0 =
+ GBin.scrolled_window ~border_width:10
+ ~packing:(vbox#pack ~expand:true ~padding:5) () in
+ let _ = scrolled_window0#add output#coerce in
+ let hbox1 =
+ GPack.hbox ~packing:(vbox#pack ~expand:false ~fill:false ~padding:5) () in
+ let settingsb =
+ GButton.button ~label:"Settings"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let button_export_to_postscript =
+ GButton.button ~label:"export_to_postscript"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let qedb =
+ GButton.button ~label:"Qed"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let saveb =
+ GButton.button ~label:"Save"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let loadb =
+ GButton.button ~label:"Load"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let closeb =
+ GButton.button ~label:"Close"
+ ~packing:(hbox1#pack ~expand:false ~fill:false ~padding:5) () in
+ let hbox2 =
+ GPack.hbox ~packing:(vbox#pack ~expand:false ~fill:false ~padding:5) () in
+ let proveitb =
+ GButton.button ~label:"Prove It"
+ ~packing:(hbox2#pack ~expand:false ~fill:false ~padding:5) () in
+ let focusb =
+ GButton.button ~label:"Focus"
+ ~packing:(hbox2#pack ~expand:false ~fill:false ~padding:5) () in
+ let oldinputt = GEdit.text ~editable:false ~width:400 ~height:180
+ ~packing:(vbox#pack ~padding:5) () in
+ let hbox4 =
+ GPack.hbox ~packing:(vbox#pack ~expand:false ~fill:false ~padding:5) () in
+ let stateb =
+ GButton.button ~label:"State"
+ ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
+ let openb =
+ GButton.button ~label:"Open"
+ ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
+ let checkb =
+ GButton.button ~label:"Check"
+ ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
+ let locateb =
+ GButton.button ~label:"Locate"
+ ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
+ let searchpatternb =
+ GButton.button ~label:"SearchPattern"
+ ~packing:(hbox4#pack ~expand:false ~fill:false ~padding:5) () in
+ let inputt = GEdit.text ~editable:true ~width:400 ~height: 100
+ ~packing:(vbox#pack ~padding:5) () in
+ let vboxl =
+ GPack.vbox ~packing:(hbox0#pack ~expand:false ~fill:false ~padding:5) () in
+ let _ =
+ vboxl#pack ~expand:false ~fill:false ~padding:5 notebook#notebook#coerce in
let outputhtml =
GHtml.xmhtml
~source:""
~width:400 ~height: 200
- ~packing:(vbox1#pack ~expand:false ~fill:false ~padding:5)
+ ~packing:(vboxl#pack ~expand:false ~fill:false ~padding:5)
~show:true () in
let scratch_window = new scratch_window outputhtml in
-object(self)
+object
method outputhtml = outputhtml
method oldinputt = oldinputt
method inputt = inputt
method output = (output : GMathView.math_view)
- method proofw = (proofw : GMathView.math_view)
+ method notebook = notebook
method show = window#show
initializer
+ notebook#set_empty_page ;
button_export_to_postscript#misc#set_sensitive false ;
+ check_term := (check_term_in_scratch scratch_window) ;
(* signal handlers here *)
ignore(output#connect#selection_changed
- (function elem -> proofw#unload ; choose_selection output elem)) ;
- ignore(proofw#connect#selection_changed (choose_selection proofw)) ;
+ (function elem -> notebook#proofw#unload ; choose_selection output elem)) ;
ignore(closeb#connect#clicked (fun _ -> GMain.Main.quit ())) ;
let settings_window = new settings_window output scrolled_window0
button_export_to_postscript (choose_selection output) in
ignore(settingsb#connect#clicked settings_window#show) ;
ignore(button_export_to_postscript#connect#clicked (export_to_postscript output)) ;
- ignore(qedb#connect#clicked (qed self)) ;
- ignore(saveb#connect#clicked (save self)) ;
- ignore(loadb#connect#clicked (load self)) ;
- ignore(proveitb#connect#clicked (proveit self)) ;
- ignore(focusb#connect#clicked (focus self)) ;
- ignore(prevgoalb#connect#clicked (prev_or_next_goal prevgoal self)) ;
- ignore(nextgoalb#connect#clicked (prev_or_next_goal nextgoal self)) ;
+ ignore(qedb#connect#clicked qed) ;
+ ignore(saveb#connect#clicked save) ;
+ ignore(loadb#connect#clicked load) ;
+ ignore(proveitb#connect#clicked proveit) ;
+ ignore(focusb#connect#clicked focus) ;
ignore(window#event#connect#delete (fun _ -> GMain.Main.quit () ; true )) ;
- ignore(stateb#connect#clicked (state self)) ;
- ignore(openb#connect#clicked (open_ self)) ;
- ignore(checkb#connect#clicked (check self scratch_window)) ;
- ignore(locateb#connect#clicked (locate self)) ;
- ignore(searchpatternb#connect#clicked (searchPattern self)) ;
- ignore(exactb#connect#clicked (exact self)) ;
- ignore(applyb#connect#clicked (apply self)) ;
- ignore(elimsimplintrosb#connect#clicked (elimsimplintros self)) ;
- ignore(elimtypeb#connect#clicked (elimtype self)) ;
- ignore(whdb#connect#clicked (whd self)) ;
- ignore(reduceb#connect#clicked (reduce self)) ;
- ignore(simplb#connect#clicked (simpl self)) ;
- ignore(foldb#connect#clicked (fold self)) ;
- ignore(cutb#connect#clicked (cut self)) ;
- ignore(changeb#connect#clicked (change self)) ;
- ignore(letinb#connect#clicked (letin self)) ;
- ignore(ringb#connect#clicked (ring self)) ;
- ignore(clearbodyb#connect#clicked (clearbody self)) ;
- ignore(clearb#connect#clicked (clear self)) ;
- ignore(fourierb#connect#clicked (fourier self)) ;
- ignore(rewritesimplb#connect#clicked (rewritesimpl self)) ;
- ignore(reflexivityb#connect#clicked (reflexivity self)) ;
- ignore(symmetryb#connect#clicked (symmetry self)) ;
- ignore(transitivityb#connect#clicked (transitivity self)) ;
- ignore(leftb#connect#clicked (left self)) ;
- ignore(rightb#connect#clicked (right self)) ;
- ignore(assumptionb#connect#clicked (assumption self)) ;
-(*
- ignore(prova_tatticalib#connect#clicked (prova_tatticali self)) ;
-*)
- ignore(introsb#connect#clicked (intros self)) ;
+ ignore(stateb#connect#clicked state) ;
+ ignore(openb#connect#clicked open_) ;
+ ignore(checkb#connect#clicked (check scratch_window)) ;
+ ignore(locateb#connect#clicked locate) ;
+ ignore(searchpatternb#connect#clicked searchPattern) ;
Logger.log_callback :=
(Logger.log_to_html ~print_and_flush:(output_html outputhtml))
end;;
(* MAIN *)
-let rendering_window = ref None;;
-
let initialize_everything () =
let module U = Unix in
- let output = GMathView.math_view ~width:350 ~height:280 ()
- and proofw = GMathView.math_view ~width:400 ~height:275 ()
- and label = GMisc.label ~text:"gTopLevel" () in
- let rendering_window' =
- new rendering_window output proofw label
- in
- rendering_window := Some rendering_window' ;
+ let output = GMathView.math_view ~width:350 ~height:280 () in
+ let notebook = new notebook in
+ let label = GMisc.label ~text:"gTopLevel" () in
+ let rendering_window' = new rendering_window output notebook label in
+ set_rendering_window rendering_window' ;
rendering_window'#show () ;
GMain.Main.main ()
;;
let _ =
if !usedb then
- begin
-(*
- Mqint.init "dbname=helm" ;
-*)
- Mqint.init "host=mowgli.cs.unibo.it dbname=helm_mowgli user=helm" ;
- CicTextualParser0.set_locate_object
- (function id ->
- let result = MQueryGenerator.locate id in
- let uris =
- List.map
- (function uri,_ ->
- wrong_xpointer_format_from_wrong_xpointer_format' uri
- ) result in
- let html =
- (" Locate Query:
" ^ get_last_query result ^ "
")
- in
- begin
- match !rendering_window with
- None -> assert false
- | Some rw -> output_html rw#outputhtml html ;
- end ;
- let uri =
- match uris with
- [] ->
- (match
- (GToolbox.input_string ~title:"Unknown input"
- ("No URI matching \"" ^ id ^ "\" found. Please enter its URI"))
- with
- None -> None
- | Some uri -> Some ("cic:" ^ uri)
- )
- | [uri] -> Some uri
- | _ ->
- let choice =
- GToolbox.question_box ~title:"Ambiguous input."
- ~buttons:uris ~default:1 "Ambiguous input. Please, choose one."
- in
- if choice > 0 then
- Some (List.nth uris (choice - 1))
- else
- (* No choice from the user *)
- None
- in
- match uri with
- Some uri' -> Some (cic_textual_parser_uri_of_uri uri')
- | None -> None
- )
- end ;
+(* Mqint.init "dbname=helm_mowgli" ; *)
+ Mqint.init "host=mowgli.cs.unibo.it dbname=helm_mowgli user=helm" ;
ignore (GtkMain.Main.init ()) ;
initialize_everything () ;
if !usedb then Mqint.close ();