On Wed, Nov 03, 2021 at 01:01:14PM +0300, Vladimir Chigarev wrote: > Hello Paul, > > Just a gentle reminder. > May I ask you to review my changes in gitk? Thanks for the reminder. See comments below. > > > +proc fetch {} { > > > + global bgcolor NS fetch_output > > > + > > > + set fetch_output {} > > > + if {[catch {exec sh -c "git fetch -v 2>&1"} fetch_output]} { This "exec" call is synchronous, meaning that the gitk process won't do anything else until the exec call returns. Since git fetch is a network operation, that could be quite a long time, during which the GUI will be unresponsive. It would be better to use open rather than exec, which will return a file descriptor. You would then use filerun to set up a procedure to be called when the file descriptor is readable. That way you can arrange for the GUI to continue to respond while the git fetch is happening. Also, it may be more useful to do "git fetch --all" rather than just "git fetch", though I'm not going to insist on that. > > > + } > > > + > > > + set w .about Why are you reusing the "About gitk" window here? That doesn't seem right. Don't you mean "set w .fetch" or similar? > > > + if {[winfo exists $w]} { > > > + raise $w > > > + return > > > + } > > > + ttk_toplevel $w > > > + wm title $w [mc "Fetch"] > > > + make_transient $w . > > > + message $w.m -text [mc " $fetch_output "] \ > > > + -justify left -aspect 600 -border 2 -bg $bgcolor -relief groove How long can the git fetch output be? If it can be say ten or more lines you might need to use a text widget and a scrollbar rather than a message widget. > > > + pack $w.m -side top -fill x -padx 2 -pady 2 > > > + ${NS}::button $w.ok -text [mc "Close"] -command "destroy $w" > > -default active > > > + pack $w.ok -side bottom > > > + bind $w <Visibility> "focus $w.ok" > > > + bind $w <Key-Escape> "destroy $w" > > > + bind $w <Key-Return> "destroy $w" > > > + tk::PlaceWindow $w widget . > > > + > > > + reloadcommits > > > +} > > > + > > > proc updatecommits {} { > > > global curview vcanopt vorigargs vfilelimit viewinstances > > > global viewactive viewcomplete tclencoding > > > @@ -2089,6 +2117,7 @@ proc makewindow {} { > > > mc "&File" cascade { > > > {mc "&Update" command updatecommits -accelerator F5} > > > {mc "&Reload" command reloadcommits -accelerator Shift-F5} > > > + {mc "&Fetch" command fetch -accelerator F7} > > > {mc "Reread re&ferences" command rereadrefs} > > > {mc "&List references" command showrefs -accelerator F2} > > > {xx "" separator} > > > @@ -2609,6 +2638,7 @@ proc makewindow {} { > > > bindkey f nextfile > > > bind . <F5> updatecommits > > > bindmodfunctionkey Shift 5 reloadcommits > > > + bind . <F7> fetch > > > bind . <F2> showrefs > > > bindmodfunctionkey Shift 4 {newview 0} > > > bind . <F4> edit_or_newview > > > @@ -3125,6 +3155,7 @@ proc keys {} { > > > [mc "<%s-KP-> Decrease font size" $M1T] > > > [mc "<%s-minus> Decrease font size" $M1T] > > > [mc "<F5> Update"] > > > +[mc "<F7> Fetch"] > > > " \ > > > -justify left -bg $bgcolor -border 2 -relief groove > > > pack $w.m -side top -fill both -padx 2 -pady 2 Paul.