X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fmatita%2FmatitaGui.ml;h=e2a5588dc178dc2f6eb00394c5658f2e9013f621;hb=536be1abc85882d042c31e301299c90786c9a355;hp=998cdc339cb5690cc13b08272893c04c61a8337e;hpb=213cac2ec31720d1988c990a4c4ef04d47bb2ff9;p=helm.git diff --git a/helm/software/matita/matitaGui.ml b/helm/software/matita/matitaGui.ml index 998cdc339..e2a5588dc 100644 --- a/helm/software/matita/matitaGui.ml +++ b/helm/software/matita/matitaGui.ml @@ -157,7 +157,7 @@ class interpErrorModel = (let loc_row = tree_store#append () in begin match lll with - [passes,envs_and_diffs,_] -> + [passes,envs_and_diffs,_,_] -> tree_store#set ~row:loc_row ~column:id_col ("Error location " ^ string_of_int (!idx1+1) ^ ", error message " ^ string_of_int (!idx1+1) ^ ".1" ^ @@ -175,7 +175,7 @@ class interpErrorModel = Some loc_row) in let idx2 = ref ~-1 in List.iter - (fun passes,envs_and_diffs,_ -> + (fun passes,envs_and_diffs,_,_ -> incr idx2; let msg_row = if List.length lll = 1 then @@ -232,11 +232,19 @@ class interpErrorModel = end -let rec interactive_error_interp ?(all_passes=false) source_buffer notify_exn - offset errorll +let rec interactive_error_interp ?(all_passes=false) (source_buffer:GSourceView.source_buffer) notify_exn offset errorll = let errorll' = - if all_passes then errorll else List.rev (List.tl (List.tl (List.rev errorll))) in + 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)) + ::[]::[] + in let choices = let pass = ref 0 in List.flatten @@ -244,15 +252,15 @@ let rec interactive_error_interp ?(all_passes=false) source_buffer notify_exn (fun l -> incr pass; List.map - (fun (env,diff,offset,msg) -> - offset, [[!pass], [[!pass], env, diff], msg]) l + (fun (env,diff,offset,msg,significant) -> + offset, [[!pass], [[!pass], env, diff], msg, significant]) l ) errorll') in (* Here we are doing a stable sort and list_uniq returns the latter "equal" element. I.e. we are showing the error corresponding to the most advanced disambiguation pass *) let choices = let choices_compare (o1,_) (o2,_) = compare o1 o2 in - let choices_compare_by_passes (p1,_,_) (p2,_,_) = + let choices_compare_by_passes (p1,_,_,_) (p2,_,_,_) = compare p1 p2 in let rec uniq = function @@ -275,14 +283,15 @@ let rec interactive_error_interp ?(all_passes=false) source_buffer notify_exn List.sort choices_compare_by_passes (uniq_by_env (List.stable_sort choices_compare_by_env errors)) in - let choices_compare_by_msg (_,_,m1) (_,_,m2) = + let choices_compare_by_msg (_,_,m1,_) (_,_,m2,_) = compare (Lazy.force m1) (Lazy.force m2) in let rec uniq_by_msg = function [] -> [] | h::[] -> [h] - | (p1,i1,m1)::(p2,i2,m2)::tl when Lazy.force m1 = Lazy.force m2 -> - uniq_by_msg ((p1@p2,merge_by_env (i1@i2),m2) :: tl) + | (p1,i1,m1,s1)::(p2,i2,m2,s2)::tl + when Lazy.force m1 = Lazy.force m2 && s1 = s2 -> + uniq_by_msg ((p1@p2,merge_by_env (i1@i2),m2,s2) :: tl) | h1::tl -> h1 :: uniq_by_msg tl in List.sort choices_compare_by_msg @@ -292,16 +301,39 @@ let rec interactive_error_interp ?(all_passes=false) source_buffer notify_exn uniq ((o1,res) :: tl) | h1::tl -> h1 :: uniq tl in - List.map (fun o,l -> o,List.sort choices_compare_by_passes l) - (uniq (List.stable_sort choices_compare choices)) + (* Errors in phase 3 that are not also in phase 4 are filtered out *) + let filter_phase_3 choices = + if all_passes then choices + else + let filter = + HExtlib.filter_map + (function + (loffset,messages) -> + let filtered_messages = + HExtlib.filter_map + (function + [3],_,_,_ -> None + | item -> Some item + ) messages + in + if filtered_messages = [] then + None + else + Some (loffset,filtered_messages)) + in + filter choices + in + filter_phase_3 + (List.map (fun o,l -> o,List.sort choices_compare_by_passes l) + (uniq (List.stable_sort choices_compare choices))) in match choices with [] -> assert false - | [loffset,[_,envs_and_diffs,msg]] -> + | [loffset,[_,envs_and_diffs,msg,significant]] -> let _,env,diff = List.hd envs_and_diffs in notify_exn (GrafiteDisambiguator.DisambiguationError - (offset,[[env,diff,loffset,msg]])); + (offset,[[env,diff,loffset,msg,significant]])); | _::_ -> let dialog = new disambiguationErrors () in dialog#check_widgets (); @@ -311,37 +343,71 @@ let rec interactive_error_interp ?(all_passes=false) source_buffer notify_exn dialog#disambiguationErrors#set_title "Disambiguation error"; dialog#disambiguationErrorsLabel#set_label "Click on an error to see the corresponding message:"; - ignore (dialog#treeview#connect#cursor_changed (fun _ -> - let tree_path = - match fst (dialog#treeview#get_cursor ()) with - None -> assert false - | Some tp -> tp in - let idx1,idx2,idx3 = model#get_interp_no tree_path in - let loffset,lll = List.nth choices idx1 in - let _,envs_and_diffs,msg = - match idx2 with - Some idx2 -> List.nth lll idx2 - | None -> [],[],lazy "Multiple error messages. Please select one." in - let _,env,diff = - match idx3 with - Some idx3 -> List.nth envs_and_diffs idx3 - | None -> [],[],[] (* dymmy value, used *) in - let script = MatitaScript.current () in - let error_tag = script#error_tag in - source_buffer#remove_tag error_tag - ~start:source_buffer#start_iter - ~stop:source_buffer#end_iter; - notify_exn - (GrafiteDisambiguator.DisambiguationError - (offset,[[env,diff,loffset,msg]])) - )); + ignore (dialog#treeview#connect#cursor_changed + (fun _ -> + let tree_path = + match fst (dialog#treeview#get_cursor ()) with + None -> assert false + | Some tp -> tp in + let idx1,idx2,idx3 = model#get_interp_no tree_path in + let loffset,lll = List.nth choices idx1 in + let _,envs_and_diffs,msg,significant = + match idx2 with + Some idx2 -> List.nth lll idx2 + | None -> + [],[],lazy "Multiple error messages. Please select one.",true + in + let _,env,diff = + match idx3 with + Some idx3 -> List.nth envs_and_diffs idx3 + | None -> [],[],[] (* dymmy value, used *) in + let script = MatitaScript.current () in + let error_tag = script#error_tag in + source_buffer#remove_tag error_tag + ~start:source_buffer#start_iter + ~stop:source_buffer#end_iter; + notify_exn + (GrafiteDisambiguator.DisambiguationError + (offset,[[env,diff,loffset,msg,significant]])) + )); let return _ = dialog#disambiguationErrors#destroy (); GMain.Main.quit () in let fail _ = return () in - ignore (dialog#disambiguationErrors#event#connect#delete (fun _ -> true)); - connect_button dialog#disambiguationErrorsOkButton (fun _ -> return ()); + ignore(dialog#disambiguationErrors#event#connect#delete (fun _ -> true)); + connect_button dialog#disambiguationErrorsOkButton + (fun _ -> + let tree_path = + match fst (dialog#treeview#get_cursor ()) with + None -> assert false + | Some tp -> tp in + let idx1,idx2,idx3 = model#get_interp_no tree_path in + let diff = + match idx2,idx3 with + Some idx2, Some idx3 -> + let _,lll = List.nth choices idx1 in + let _,envs_and_diffs,_,_ = List.nth lll idx2 in + let _,_,diff = List.nth envs_and_diffs idx3 in + diff + | _,_ -> assert false + in + let newtxt = + String.concat "\n" + ("" :: + List.map + (fun k,value -> + DisambiguatePp.pp_environment + (DisambiguateTypes.Environment.add k value + DisambiguateTypes.Environment.empty)) + diff) ^ "\n" + in + source_buffer#insert + ~iter: + (source_buffer#get_iter_at_mark + (`NAME "beginning_of_statement")) newtxt ; + return () + ); connect_button dialog#disambiguationErrorsMoreErrors (fun _ -> return () ; interactive_error_interp ~all_passes:true source_buffer notify_exn offset @@ -1610,18 +1676,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 @@ -1629,12 +1693,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 @@ -1649,19 +1715,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