[prev in list] [next in list] [prev in thread] [next in thread]
List: git
Subject: Re: [PATCH 3/6] Add a tree view to the local branches, remote branches and tags, where / is treated
From: Paul Mackerras <paulus () ozlabs ! org>
Date: 2016-12-31 9:08:59
Message-ID: 20161231090859.GC21019 () fergus ! ozlabs ! ibm ! com
[Download RAW message or body]
On Thu, Dec 15, 2016 at 09:58:44PM +1030, Pierre Dumuid wrote:
> Signed-off-by: Pierre Dumuid <pmdumuid@gmail.com>
> ---
> gitk | 117 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 117 insertions(+)
Nice idea in general... a few comments below. Also, please don't put
the entire commit message in the subject line. :)
> diff --git a/gitk b/gitk
> index 36cba49..a894f1d 100755
> --- a/gitk
> +++ b/gitk
> @@ -2089,6 +2089,10 @@ proc makewindow {} {
> {mc "Reread re&ferences" command rereadrefs}
> {mc "&List references" command showrefs -accelerator F2}
> {xx "" separator}
> + {mc "List Local Branches" command {show_tree_of_references_dialog \
> "localBranches"} -accelerator F6} + {mc "List Remote Branches" command \
> {show_tree_of_references_dialog "remoteBranches"} -accelerator F7} + {mc "List \
> Tags" command {show_tree_of_references_dialog "tags"} \
> -accelerator F8} + {xx "" separator}
> {mc "Start git &gui" command {exec git gui &}}
> {xx "" separator}
> {mc "&Quit" command doquit -accelerator Meta1-Q}
> @@ -2601,6 +2605,9 @@ proc makewindow {} {
> bind . <F5> updatecommits
> bindmodfunctionkey Shift 5 reloadcommits
> bind . <F2> showrefs
> + bind . <F6> {show_tree_of_references_dialog "localBranches"}
> + bind . <F7> {show_tree_of_references_dialog "remoteBranches"}
> + bind . <F8> {show_tree_of_references_dialog "tags"}
> bindmodfunctionkey Shift 4 {newview 0}
> bind . <F4> edit_or_newview
> bind . <$M1B-q> doquit
> @@ -10146,6 +10153,116 @@ proc rmbranch {} {
> run refill_reflist
> }
>
> +# Display a tree view of local branches, remote branches, and tags according to \
> view_type. +#
> +# @param string view_type
> +# Must be one of "localBranches", "remoteBranches", or "tags".
> +#
> +proc show_tree_of_references_dialog {view_type} {
> + global NS
> + global treefilelist
> + global headids tagids
> +
> + switch -- $view_type {
> + "localBranches" {
> + set dialogName "Local Branches"
> + set top .show_tree_of_local_branches
> + set listOfReferences [lsort [array names headids -regexp {^(?!remotes/)} ]]
> + set truncateFrom 0
> + }
> + "remoteBranches" {
> + set dialogName "Remote Branches"
> + set top .show_tree_of_remote_branches
> + set listOfReferences [lsort [array names headids -regexp {^remotes/} ]]
> + set truncateFrom 8
> + }
> + "tags" {
> + set dialogName "Tags"
> + set top .show_tree_of_tags
> + set listOfReferences [lsort [array names tagids]]
> + set truncateFrom 0
> + }
> + }
> +
> + if {[winfo exists $top]} {
> + raise $top
> + return
> + }
> +
> + ttk_toplevel $top
> + wm title $top [mc "$dialogName: %s" [file tail [pwd]]]
> + wm geometry $top "600x900"
Do you really need to do this? A fixed size like this is inevitably
going to be too big for some users and too small for others.
> +
> + make_transient $top .
> +
> + ## See http://www.tkdocs.com/tutorial/tree.html
> + ttk::treeview $top.referenceList -xscrollcommand "$top.horizontalScrollBar \
> set" -yscrollcommand "$top.verticalScrollBar set"
We still have the option for people to run without ttk, in case
someone is still using an old Tcl/Tk version or just doesn't like the
ttk widgets. However, there isn't an equivalent of ttk::treeview in
the older Tk widget set. It would be OK to omit the new menu entries
or to disable them if $use_ttk is false, but I don't want to have menu
entries that will always cause gitk to blow up when $use_ttk is false.
We possibly should consider converting the file list view to use a
ttk::treeview when $use_ttk is true.
Paul.
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic