X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=matita%2FmatitaGui.ml;h=b8d20cf3cace3c3557b2c872fe72af18c8ca2e9f;hb=909cdbb5ddf942e75558149c9f11819c6c84bc3a;hp=baf5998a5371a8f3f535aa35fc877dbba1093287;hpb=3f9fd7c83c59b8230cb349a9114e72e026ac12d0;p=helm.git diff --git a/matita/matitaGui.ml b/matita/matitaGui.ml index baf5998a5..b8d20cf3c 100644 --- a/matita/matitaGui.ml +++ b/matita/matitaGui.ml @@ -234,16 +234,40 @@ class interpErrorModel = let rec interactive_error_interp ?(all_passes=false) (source_buffer:GSourceView.source_buffer) notify_exn offset errorll = + assert (List.flatten errorll <> []); let errorll' = let remove_non_significant = List.filter (fun (_env,_diff,_loc,_msg,significant) -> significant) in if all_passes then errorll else let safe_list_nth l n = try List.nth l n with Failure _ -> [] in (* We remove passes 1,2 and 5,6 *) - []::[] - ::(remove_non_significant (safe_list_nth errorll 2)) - ::(remove_non_significant (safe_list_nth errorll 3)) - ::[]::[] + let res = + []::[] + ::(remove_non_significant (safe_list_nth errorll 2)) + ::(remove_non_significant (safe_list_nth errorll 3)) + ::[]::[] + in + if List.flatten res <> [] then res + else + (* all errors (if any) are not significant: we keep them *) + let res = + []::[] + ::(safe_list_nth errorll 2) + ::(safe_list_nth errorll 3) + ::[]::[] + in + if List.flatten res <> [] then + begin + HLog.warn + "All disambiguation errors are not significant. Showing them anyway." ; + res + end + else + begin + HLog.warn + "No errors in phases 2 and 3. Showing all errors in all phases" ; + errorll + end in let choices = let pass = ref 0 in @@ -990,6 +1014,10 @@ class gui () = | false -> main#toplevel#unfullscreen ()) ~check:main#fullscreenMenuItem; main#fullscreenMenuItem#set_active false; + MatitaGtkMisc.toggle_callback + ~callback:(fun enabled -> + CicMetaSubst.use_low_level_ppterm_in_context := not enabled) + ~check:main#formulaePpMenuItem; (* log *) HLog.set_log_callback self#console#log_callback; GtkSignal.user_handler := @@ -1676,18 +1704,16 @@ let interactive_string_choice | Some uris -> uris) let interactive_interp_choice () text prefix_len choices = -(* List.iter (fun (l,_,_) -> - List.iter (fun l -> let start, stop = HExtlib.loc_of_floc l in - Printf.eprintf "(%d,%d)" start stop) l; prerr_endline "") - ((List.hd choices)); *) +(*List.iter (fun l -> prerr_endline "==="; List.iter (fun (_,id,dsc) -> prerr_endline (id ^ " = " ^ dsc)) l) choices;*) let filter_choices filter = let rec is_compatible filter = function [] -> true - | (_,id,dsc)::tl -> + | ([],_,_)::tl -> is_compatible filter tl + | (loc::tlloc,id,dsc)::tl -> try - if List.assoc id filter = dsc then - is_compatible filter tl + if List.assoc (loc,id) filter = dsc then + is_compatible filter ((tlloc,id,dsc)::tl) else false with @@ -1695,12 +1721,14 @@ let interactive_interp_choice () text prefix_len choices = in List.filter (fun (_,interp) -> is_compatible filter interp) in - let rec get_choices id = + let rec get_choices loc id = function [] -> [] | (_,he)::tl -> - let _,_,dsc = List.find (fun (_,id',_) -> id = id') he in - dsc :: (List.filter (fun dsc' -> dsc <> dsc') (get_choices id tl)) + let _,_,dsc = + List.find (fun (locs,id',_) -> id = id' && List.mem loc locs) he + in + dsc :: (List.filter (fun dsc' -> dsc <> dsc') (get_choices loc id tl)) in let example_interp = match choices with @@ -1715,19 +1743,22 @@ let interactive_interp_choice () text prefix_len choices = let rec classify ids filter partial_interpretations = match ids with [] -> List.map fst partial_interpretations - | (locs,id,_)::tl -> - let choices = get_choices id partial_interpretations in + | ([],_,_)::tl -> classify tl filter partial_interpretations + | (loc::tlloc,id,dsc)::tl -> + let choices = get_choices loc id partial_interpretations in let chosen_dsc = match choices with - [dsc] -> dsc + [] -> prerr_endline ("NO CHOICES FOR " ^ id); assert false + | [dsc] -> dsc | _ -> - match ask_user id locs choices with + match ask_user id [loc] choices with [x] -> x | _ -> assert false in - let filter = (id,chosen_dsc)::filter in - let compatible_interps = filter_choices filter partial_interpretations in - classify tl filter compatible_interps in + let filter = ((loc,id),chosen_dsc)::filter in + let compatible_interps = filter_choices filter partial_interpretations in + classify ((tlloc,id,dsc)::tl) filter compatible_interps + in let enumerated_choices = let idx = ref ~-1 in List.map (fun interp -> incr idx; !idx,interp) choices