* [PATCH] gitk: make use of themed widgets where available
@ 2009-02-28 0:18 Pat Thoyts
2009-02-28 0:47 ` Sverre Rabbelier
` (2 more replies)
0 siblings, 3 replies; 7+ messages in thread
From: Pat Thoyts @ 2009-02-28 0:18 UTC (permalink / raw)
To: git; +Cc: paulus
This patch improves the appearence of gitk on Windows XP and Vista
by making use of the themed widgets that are provided in Tk 8.5
and above. For good Vista support 8.6 will be needed.
Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
---
gitk | 432 ++++++++++++++++++++++++++++++++++++++++--------------------------
1 files changed, 262 insertions(+), 170 deletions(-)
diff --git a/gitk b/gitk
index f8c3c73..2b5265a 100755
--- a/gitk
+++ b/gitk
@@ -1765,6 +1765,15 @@ proc removehead {id name} {
unset headids($name)
}
+proc ttk_toplevel {w args} {
+ variable use_ttk
+ eval [linsert $args 0 ::toplevel $w]
+ if {$use_ttk} {
+ place [ttk::frame $w._toplevel_background] -x 0 -y 0 -relwidth 1 -relheight 1
+ }
+ return $w
+}
+
proc make_transient {window origin} {
global have_tk85
@@ -1784,14 +1793,16 @@ proc make_transient {window origin} {
}
proc show_error {w top msg} {
+ variable use_ttk
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
message $w.m -text $msg -justify center -aspect 400
pack $w.m -side top -fill x -padx 20 -pady 20
- button $w.ok -text [mc OK] -command "destroy $top"
+ ${ttk}::button $w.ok -default active -text [mc OK] -command "destroy $top"
pack $w.ok -side bottom -fill x
bind $top <Visibility> "grab $top; focus $top"
- bind $top <Key-Return> "destroy $top"
- bind $top <Key-space> "destroy $top"
- bind $top <Key-Escape> "destroy $top"
+ bind $top <Key-Return> [list $w.ok invoke]
+ bind $top <Key-space> [list $w.ok invoke]
+ bind $top <Key-Escape> [list $w.ok invoke]
tkwait window $top
}
@@ -1801,18 +1812,29 @@ proc error_popup {msg {owner .}} {
-parent $owner -message $msg
} else {
set w .error
- toplevel $w
+ ttk_toplevel $w
make_transient $w $owner
show_error $w $w $msg
}
}
+variable fullscreen 0
+proc togglefullscreen {} {
+ variable fullscreen
+ if {[catch {
+ set ofs [wm attribute . -fullscreen]
+ if {$ofs} {set fs 0} else {set fs 1}
+ wm attribute . -fullscreen $fs
+ set fullscreen $fs
+ } err]} { error_popup "fullscreen error: $err" }
+}
+
proc confirm_popup {msg {owner .}} {
global confirm_ok use_ttk
set ttk [expr {$use_ttk ? "ttk" : ""}]
set confirm_ok 0
set w .confirm
- toplevel $w
+ ttk_toplevel $w
make_transient $w $owner
message $w.m -text $msg -justify center -aspect 400
pack $w.m -side top -fill x -padx 20 -pady 20
@@ -1853,11 +1875,18 @@ proc setoptions {} {
# description depends on type; it's the sublist for cascade, the
# command to invoke for command, or {variable value} for radiobutton
proc makemenu {m items} {
- menu $m
- if {[tk windowingsystem] eq {aqua}} {
- set Meta1 Cmd
- } else {
- set Meta1 Ctrl
+ set Meta1 Ctrl
+ switch -exact -- [tk windowingsystem] {
+ win32 {
+ menu $m -tearoff 0
+ }
+ aqua {
+ menu $m
+ set Meta1 Cmd
+ }
+ default {
+ menu $m
+ }
}
foreach i $items {
set name [mc [lindex $i 1]]
@@ -1913,7 +1942,8 @@ proc makewindow {} {
global headctxmenu progresscanv progressitem progresscoords statusw
global fprogitem fprogcoord lastprogupdate progupdatepending
global rprogitem rprogcoord rownumsel numcommits
- global have_tk85
+ global have_tk85 use_ttk
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
# The "mc" arguments here are purely so that xgettext
# sees the following string as needing to be translated
@@ -1945,8 +1975,10 @@ proc makewindow {} {
}
. configure -menu .bar
+ place [${ttk}::frame ._main_background] -x 0 -y 0 -relwidth 1 -relheight 1
+
# the gui has upper and lower half, parts of a paned window.
- panedwindow .ctop -orient vertical
+ ${ttk}::panedwindow .ctop -orient vertical
# possibly use assumed geometry
if {![info exists geometry(pwsash0)]} {
@@ -1954,46 +1986,56 @@ proc makewindow {} {
set geometry(topwidth) [expr {80 * $charspc}]
set geometry(botheight) [expr {15 * $linespc}]
set geometry(botwidth) [expr {50 * $charspc}]
- set geometry(pwsash0) "[expr {40 * $charspc}] 2"
- set geometry(pwsash1) "[expr {60 * $charspc}] 2"
+ set geometry(pwsash0) [list [expr {40 * $charspc}] 2]
+ set geometry(pwsash1) [list [expr {60 * $charspc}] 2]
}
# the upper half will have a paned window, a scroll bar to the right, and some stuff below
- frame .tf -height $geometry(topheight) -width $geometry(topwidth)
- frame .tf.histframe
- panedwindow .tf.histframe.pwclist -orient horizontal -sashpad 0 -handlesize 4
+ ${ttk}::frame .tf -height $geometry(topheight) -width $geometry(topwidth)
+ ${ttk}::frame .tf.histframe
+ ${ttk}::panedwindow .tf.histframe.pwclist -orient horizontal
+ if {!$use_ttk} {
+ .tf.histframe.pwclist configure -sashpad 0 -handlesize 4
+ }
# create three canvases
set cscroll .tf.histframe.csb
set canv .tf.histframe.pwclist.canv
canvas $canv \
-selectbackground $selectbgcolor \
- -background $bgcolor -bd 0 \
- -yscrollincr $linespc -yscrollcommand "scrollcanv $cscroll"
+ -background $bgcolor -borderwidth 0 \
+ -yscrollincrement $linespc -yscrollcommand "scrollcanv $cscroll"
.tf.histframe.pwclist add $canv
set canv2 .tf.histframe.pwclist.canv2
canvas $canv2 \
-selectbackground $selectbgcolor \
- -background $bgcolor -bd 0 -yscrollincr $linespc
+ -background $bgcolor -borderwidth 0 -yscrollincrement $linespc
.tf.histframe.pwclist add $canv2
set canv3 .tf.histframe.pwclist.canv3
canvas $canv3 \
-selectbackground $selectbgcolor \
- -background $bgcolor -bd 0 -yscrollincr $linespc
+ -background $bgcolor -borderwidth 0 -yscrollincrement $linespc
.tf.histframe.pwclist add $canv3
- eval .tf.histframe.pwclist sash place 0 $geometry(pwsash0)
- eval .tf.histframe.pwclist sash place 1 $geometry(pwsash1)
+ if {$use_ttk} {
+ #set p1 [expr {[winfo screenwidth .] - (40 * $charspc)}]
+ #set p0 [expr {[winfo screenwidth .] - (100 * $charspc)}]
+ #.tf.histframe.pwclist sashpos 0 585
+ #.tf.histframe.pwclist sashpos 1 868
+ } else {
+ eval .tf.histframe.pwclist sash place 0 $geometry(pwsash0)
+ eval .tf.histframe.pwclist sash place 1 $geometry(pwsash1)
+ }
# a scroll bar to rule them
- scrollbar $cscroll -command {allcanvs yview} -highlightthickness 0
+ ${ttk}::scrollbar $cscroll -command {allcanvs yview} ;#-highlightthickness 0
pack $cscroll -side right -fill y
bind .tf.histframe.pwclist <Configure> {resizeclistpanes %W %w}
lappend bglist $canv $canv2 $canv3
pack .tf.histframe.pwclist -fill both -expand 1 -side left
# we have two button bars at bottom of top frame. Bar 1
- frame .tf.bar
- frame .tf.lbar -height 15
+ ${ttk}::frame .tf.bar
+ ${ttk}::frame .tf.lbar -height 15
set sha1entry .tf.bar.sha1
set entries $sha1entry
@@ -2002,7 +2044,7 @@ proc makewindow {} {
-command gotocommit -width 8
$sha1but conf -disabledforeground [$sha1but cget -foreground]
pack .tf.bar.sha1label -side left
- entry $sha1entry -width 40 -font textfont -textvariable sha1string
+ ${ttk}::entry $sha1entry -width 40 -font textfont -textvariable sha1string
trace add variable sha1string write sha1change
pack $sha1entry -side left -pady 2
@@ -2029,12 +2071,12 @@ proc makewindow {} {
-state disabled -width 26
pack .tf.bar.rightbut -side left -fill y
- label .tf.bar.rowlabel -text [mc "Row"]
+ ${ttk}::label .tf.bar.rowlabel -text [mc "Row"]
set rownumsel {}
- label .tf.bar.rownum -width 7 -font textfont -textvariable rownumsel \
+ ${ttk}::label .tf.bar.rownum -width 7 -font textfont -textvariable rownumsel \
-relief sunken -anchor e
- label .tf.bar.rowlabel2 -text "/"
- label .tf.bar.numcommits -width 7 -font textfont -textvariable numcommits \
+ ${ttk}::label .tf.bar.rowlabel2 -text "/"
+ ${ttk}::label .tf.bar.numcommits -width 7 -font textfont -textvariable numcommits \
-relief sunken -anchor e
pack .tf.bar.rowlabel .tf.bar.rownum .tf.bar.rowlabel2 .tf.bar.numcommits \
-side left
@@ -2043,7 +2085,7 @@ proc makewindow {} {
# Status label and progress bar
set statusw .tf.bar.status
- label $statusw -width 15 -relief sunken
+ ${ttk}::label $statusw -width 15 -relief sunken
pack $statusw -side left -padx 5
set h [expr {[font metrics uifont -linespace] + 2}]
set progresscanv .tf.bar.progress
@@ -2060,32 +2102,52 @@ proc makewindow {} {
set progupdatepending 0
# build up the bottom bar of upper window
- label .tf.lbar.flabel -text "[mc "Find"] "
- button .tf.lbar.fnext -text [mc "next"] -command {dofind 1 1}
- button .tf.lbar.fprev -text [mc "prev"] -command {dofind -1 1}
- label .tf.lbar.flab2 -text " [mc "commit"] "
+ ${ttk}::label .tf.lbar.flabel -text "[mc "Find"] "
+ ${ttk}::button .tf.lbar.fnext -text [mc "next"] -command {dofind 1 1}
+ ${ttk}::button .tf.lbar.fprev -text [mc "prev"] -command {dofind -1 1}
+ ${ttk}::label .tf.lbar.flab2 -text " [mc "commit"] "
pack .tf.lbar.flabel .tf.lbar.fnext .tf.lbar.fprev .tf.lbar.flab2 \
-side left -fill y
set gdttype [mc "containing:"]
- set gm [tk_optionMenu .tf.lbar.gdttype gdttype \
- [mc "containing:"] \
- [mc "touching paths:"] \
- [mc "adding/removing string:"]]
+ if {$use_ttk} {
+ set values [list [mc "containing:"] [mc "touching paths:"] \
+ [mc "adding/removing string:"]]
+ set gm [ttk::combobox .tf.lbar.gdttype -width 10\
+ -values $values -textvariable gdtype]
+ } else {
+ set gm [tk_optionMenu .tf.lbar.gdttype gdttype \
+ [mc "containing:"] \
+ [mc "touching paths:"] \
+ [mc "adding/removing string:"]]
+ }
trace add variable gdttype write gdttype_change
pack .tf.lbar.gdttype -side left -fill y
set findstring {}
set fstring .tf.lbar.findstring
lappend entries $fstring
- entry $fstring -width 30 -font textfont -textvariable findstring
+ ${ttk}::entry $fstring -width 30 -font textfont -textvariable findstring
trace add variable findstring write find_change
set findtype [mc "Exact"]
- set findtypemenu [tk_optionMenu .tf.lbar.findtype \
- findtype [mc "Exact"] [mc "IgnCase"] [mc "Regexp"]]
+ if {$use_ttk} {
+ set values [list [mc "Exact"] [mc "IgnCase"] [mc "Regexp"]]
+ ttk::combobox .tf.lbar.findtype -width 10 \
+ -values $values -textvariable findtype
+ } else {
+ set findtypemenu [tk_optionMenu .tf.lbar.findtype \
+ findtype [mc "Exact"] [mc "IgnCase"] [mc "Regexp"]]
+ }
trace add variable findtype write findcom_change
set findloc [mc "All fields"]
- tk_optionMenu .tf.lbar.findloc findloc [mc "All fields"] [mc "Headline"] \
- [mc "Comments"] [mc "Author"] [mc "Committer"]
+ if {$use_ttk} {
+ set values [list [mc "All fields"] [mc "Headline"] \
+ [mc "Comments"] [mc "Author"] [mc "Committer"]]
+ ttk::combobox .tf.lbar.findloc -width 10 \
+ -values $values -textvariable findloc
+ } else {
+ tk_optionMenu .tf.lbar.findloc findloc [mc "All fields"] [mc "Headline"] \
+ [mc "Comments"] [mc "Author"] [mc "Committer"]
+ }
trace add variable findloc write find_change
pack .tf.lbar.findloc -side right
pack .tf.lbar.findtype -side right
@@ -2096,38 +2158,41 @@ proc makewindow {} {
pack .tf.bar -in .tf -side bottom -fill x
pack .tf.histframe -fill both -side top -expand 1
.ctop add .tf
- .ctop paneconfigure .tf -height $geometry(topheight)
- .ctop paneconfigure .tf -width $geometry(topwidth)
+ if {!$use_ttk} {
+ .ctop paneconfigure .tf -height $geometry(topheight)
+ .ctop paneconfigure .tf -width $geometry(topwidth)
+ }
# now build up the bottom
- panedwindow .pwbottom -orient horizontal
+ ${ttk}::panedwindow .pwbottom -orient horizontal
# lower left, a text box over search bar, scroll bar to the right
# if we know window height, then that will set the lower text height, otherwise
# we set lower text height which will drive window height
if {[info exists geometry(main)]} {
- frame .bleft -width $geometry(botwidth)
+ ${ttk}::frame .bleft -width $geometry(botwidth)
} else {
- frame .bleft -width $geometry(botwidth) -height $geometry(botheight)
+ ${ttk}::frame .bleft -width $geometry(botwidth) -height $geometry(botheight)
}
- frame .bleft.top
- frame .bleft.mid
- frame .bleft.bottom
+ ${ttk}::frame .bleft.top
+ ${ttk}::frame .bleft.mid
+ ${ttk}::frame .bleft.bottom
- button .bleft.top.search -text [mc "Search"] -command dosearch
+ ${ttk}::button .bleft.top.search -text [mc "Search"] -command dosearch
pack .bleft.top.search -side left -padx 5
set sstring .bleft.top.sstring
- entry $sstring -width 20 -font textfont -textvariable searchstring
+ variable searchstring ""
+ ${ttk}::entry $sstring -width 20 -font textfont -textvariable searchstring
lappend entries $sstring
trace add variable searchstring write incrsearch
pack $sstring -side left -expand 1 -fill x
- radiobutton .bleft.mid.diff -text [mc "Diff"] \
+ ${ttk}::radiobutton .bleft.mid.diff -text [mc "Diff"] \
-command changediffdisp -variable diffelide -value {0 0}
- radiobutton .bleft.mid.old -text [mc "Old version"] \
+ ${ttk}::radiobutton .bleft.mid.old -text [mc "Old version"] \
-command changediffdisp -variable diffelide -value {0 1}
- radiobutton .bleft.mid.new -text [mc "New version"] \
+ ${ttk}::radiobutton .bleft.mid.new -text [mc "New version"] \
-command changediffdisp -variable diffelide -value {1 0}
- label .bleft.mid.labeldiffcontext -text " [mc "Lines of context"]: "
+ ${ttk}::label .bleft.mid.labeldiffcontext -text " [mc "Lines of context"]: "
pack .bleft.mid.diff .bleft.mid.old .bleft.mid.new -side left
spinbox .bleft.mid.diffcontext -width 5 -font textfont \
-from 1 -increment 1 -to 10000000 \
@@ -2137,7 +2202,7 @@ proc makewindow {} {
trace add variable diffcontextstring write diffcontextchange
lappend entries .bleft.mid.diffcontext
pack .bleft.mid.labeldiffcontext .bleft.mid.diffcontext -side left
- checkbutton .bleft.mid.ignspace -text [mc "Ignore space change"] \
+ ${ttk}::checkbutton .bleft.mid.ignspace -text [mc "Ignore space change"] \
-command changeignorespace -variable ignorespace
pack .bleft.mid.ignspace -side left -padx 5
set ctext .bleft.bottom.ctext
@@ -2148,9 +2213,8 @@ proc makewindow {} {
if {$have_tk85} {
$ctext conf -tabstyle wordprocessor
}
- scrollbar .bleft.bottom.sb -command "$ctext yview"
- scrollbar .bleft.bottom.sbhorizontal -command "$ctext xview" -orient h \
- -width 10
+ ${ttk}::scrollbar .bleft.bottom.sb -command "$ctext yview"
+ ${ttk}::scrollbar .bleft.bottom.sbhorizontal -command "$ctext xview" -orient h
pack .bleft.top -side top -fill x
pack .bleft.mid -side top -fill x
grid $ctext .bleft.bottom.sb -sticky nsew
@@ -2190,14 +2254,16 @@ proc makewindow {} {
$ctext tag conf found -back yellow
.pwbottom add .bleft
- .pwbottom paneconfigure .bleft -width $geometry(botwidth)
+ if {!$use_ttk} {
+ .pwbottom paneconfigure .bleft -width $geometry(botwidth)
+ }
# lower right
- frame .bright
- frame .bright.mode
- radiobutton .bright.mode.patch -text [mc "Patch"] \
+ ${ttk}::frame .bright
+ ${ttk}::frame .bright.mode
+ ${ttk}::radiobutton .bright.mode.patch -text [mc "Patch"] \
-command reselectline -variable cmitmode -value "patch"
- radiobutton .bright.mode.tree -text [mc "Tree"] \
+ ${ttk}::radiobutton .bright.mode.tree -text [mc "Tree"] \
-command reselectline -variable cmitmode -value "tree"
grid .bright.mode.patch .bright.mode.tree -sticky ew
pack .bright.mode -side top -fill x
@@ -2213,7 +2279,7 @@ proc makewindow {} {
-spacing1 1 -spacing3 1
lappend bglist $cflist
lappend fglist $cflist
- scrollbar .bright.sb -command "$cflist yview"
+ ${ttk}::scrollbar .bright.sb -command "$cflist yview"
pack .bright.sb -side right -fill y
pack $cflist -side left -fill both -expand 1
$cflist tag configure highlight \
@@ -2293,6 +2359,7 @@ proc makewindow {} {
bindkey u "$ctext yview scroll -18 units"
bindkey / {focus $fstring}
bindkey <Key-Return> {dofind 1 1}
+ bindkey <Alt-Return> [namespace code [list togglefullscreen]]
bindkey ? {dofind -1 1}
bindkey f nextfile
bind . <F5> updatecommits
@@ -2540,10 +2607,15 @@ proc savestuff {w} {
}
proc resizeclistpanes {win w} {
- global oldwidth
+ global oldwidth use_ttk
if {[info exists oldwidth($win)]} {
- set s0 [$win sash coord 0]
- set s1 [$win sash coord 1]
+ if {$use_ttk} {
+ set s0 [$win sashpos 0]
+ set s1 [$win sashpos 1]
+ } else {
+ set s0 [$win sash coord 0]
+ set s1 [$win sash coord 1]
+ }
if {$w < 60} {
set sash0 [expr {int($w/2 - 2)}]
set sash1 [expr {int($w*5/6 - 2)}]
@@ -2564,16 +2636,25 @@ proc resizeclistpanes {win w} {
}
}
}
- $win sash place 0 $sash0 [lindex $s0 1]
- $win sash place 1 $sash1 [lindex $s1 1]
+ if {$use_ttk} {
+ $win sashpos 0 $sash0
+ $win sashpos 1 $sash1
+ } else {
+ $win sash place 0 $sash0 [lindex $s0 1]
+ $win sash place 1 $sash1 [lindex $s1 1]
+ }
}
set oldwidth($win) $w
}
proc resizecdetpanes {win w} {
- global oldwidth
+ global oldwidth use_ttk
if {[info exists oldwidth($win)]} {
- set s0 [$win sash coord 0]
+ if {$use_ttk} {
+ set s0 [$win sashpos 0]
+ } else {
+ set s0 [$win sash coord 0]
+ }
if {$w < 60} {
set sash0 [expr {int($w*3/4 - 2)}]
} else {
@@ -2586,7 +2667,11 @@ proc resizecdetpanes {win w} {
set sash0 [expr {$w - 15}]
}
}
- $win sash place 0 $sash0 [lindex $s0 1]
+ if {$use_ttk} {
+ $win sashpos 0 $sash0
+ } else {
+ $win sash place 0 $sash0 [lindex $s0 1]
+ }
}
set oldwidth($win) $w
}
@@ -2606,13 +2691,15 @@ proc bindall {event action} {
}
proc about {} {
- global uifont
+ global uifont use_ttk
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
set w .about
if {[winfo exists $w]} {
raise $w
return
}
- toplevel $w
+ ttk_toplevel $w
+ wm withdraw $w
wm title $w [mc "About gitk"]
make_transient $w .
message $w.m -text [mc "
@@ -2623,14 +2710,18 @@ Copyright © 2005-2008 Paul Mackerras
Use and redistribute under the terms of the GNU General Public License"] \
-justify center -aspect 400 -border 2 -bg white -relief groove
pack $w.m -side top -fill x -padx 2 -pady 2
- button $w.ok -text [mc "Close"] -command "destroy $w" -default active
+ ${ttk}::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 .
+ wm deiconify $w
}
proc keys {} {
+ variable use_ttk
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
set w .keys
if {[winfo exists $w]} {
raise $w
@@ -2641,7 +2732,7 @@ proc keys {} {
} else {
set M1T Ctrl
}
- toplevel $w
+ ttk_toplevel $w
wm title $w [mc "Gitk key bindings"]
make_transient $w .
message $w.m -text "
@@ -2685,7 +2776,7 @@ proc keys {} {
" \
-justify left -bg white -border 2 -relief groove
pack $w.m -side top -fill both -padx 2 -pady 2
- button $w.ok -text [mc "Close"] -command "destroy $w" -default active
+ ${ttk}::button $w.ok -text [mc "Close"] -command "destroy $w" -default active
bind $w <Key-Escape> [list destroy $w]
pack $w.ok -side bottom
bind $w <Visibility> "focus $w.ok"
@@ -3750,16 +3841,17 @@ proc editview {} {
proc vieweditor {top n title} {
global newviewname newviewopts viewfiles bgcolor
- global known_view_options
+ global known_view_options use_ttk
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
- toplevel $top
+ ttk_toplevel $top
wm title $top $title
make_transient $top .
# View name
- frame $top.nfr
- label $top.nl -text [mc "Name"]
- entry $top.name -width 20 -textvariable newviewname($n)
+ ${ttk}::frame $top.nfr
+ ${ttk}::label $top.nl -text [mc "Name"]
+ ${ttk}::entry $top.name -width 20 -textvariable newviewname($n)
pack $top.nfr -in $top -fill x -pady 5 -padx 3
pack $top.nl -in $top.nfr -side left -padx {0 30}
pack $top.name -in $top.nfr -side left
@@ -3778,7 +3870,7 @@ proc vieweditor {top n title} {
if {$flags eq "+" || $flags eq "*"} {
set cframe $top.fr$cnt
incr cnt
- frame $cframe
+ ${ttk}::frame $cframe
pack $cframe -in $top -fill x -pady 3 -padx 3
set cexpand [expr {$flags eq "*"}]
} else {
@@ -3786,18 +3878,18 @@ proc vieweditor {top n title} {
}
if {$type eq "b"} {
- checkbutton $cframe.c_$id -text $title -variable newviewopts($n,$id)
+ ${ttk}::checkbutton $cframe.c_$id -text $title -variable newviewopts($n,$id)
pack $cframe.c_$id -in $cframe -side left \
-padx [list $lxpad 0] -expand $cexpand -anchor w
} elseif {[regexp {^t(\d+)$} $type type sz]} {
- message $cframe.l_$id -aspect 1500 -text $title
- entry $cframe.e_$id -width $sz -background $bgcolor \
+ ${ttk}::label $cframe.l_$id -text $title
+ ${ttk}::entry $cframe.e_$id -width $sz -background $bgcolor \
-textvariable newviewopts($n,$id)
pack $cframe.l_$id -in $cframe -side left -padx [list $lxpad 0]
pack $cframe.e_$id -in $cframe -side left -expand 1 -fill x
} elseif {[regexp {^t(\d+)=$} $type type sz]} {
- message $cframe.l_$id -aspect 1500 -text $title
- entry $cframe.e_$id -width $sz -background $bgcolor \
+ ${ttk}::label $cframe.l_$id -text $title
+ ${ttk}::entry $cframe.e_$id -width $sz -background $bgcolor \
-textvariable newviewopts($n,$id)
pack $cframe.l_$id -in $cframe -side top -pady [list 3 0] -anchor w
pack $cframe.e_$id -in $cframe -side top -fill x
@@ -3805,7 +3897,7 @@ proc vieweditor {top n title} {
}
# Path list
- message $top.l -aspect 1500 \
+ ${ttk}::label $top.l \
-text [mc "Enter files and directories to include, one per line:"]
pack $top.l -in $top -side top -pady [list 7 0] -anchor w -padx 3
text $top.t -width 40 -height 5 -background $bgcolor -font uifont
@@ -3818,10 +3910,11 @@ proc vieweditor {top n title} {
$top.t mark set insert 0.0
}
pack $top.t -in $top -side top -pady [list 0 5] -fill both -expand 1 -padx 3
- frame $top.buts
- button $top.buts.ok -text [mc "OK"] -command [list newviewok $top $n]
- button $top.buts.apply -text [mc "Apply (F5)"] -command [list newviewok $top $n 1]
- button $top.buts.can -text [mc "Cancel"] -command [list destroy $top]
+ ${ttk}::frame $top.buts
+ ${ttk}::button $top.buts.ok -text [mc "OK"] -command [list newviewok $top $n] \
+ -default active
+ ${ttk}::button $top.buts.apply -text [mc "Apply (F5)"] -command [list newviewok $top $n 1]
+ ${ttk}::button $top.buts.can -text [mc "Cancel"] -command [list destroy $top]
bind $top <Control-Return> [list newviewok $top $n]
bind $top <F5> [list newviewok $top $n 1]
bind $top <Escape> [list destroy $top]
@@ -6665,8 +6758,7 @@ proc selectline {l isnew {desired_loc {}}} {
$sha1entry delete 0 end
$sha1entry insert 0 $id
if {$autoselect} {
- $sha1entry selection from 0
- $sha1entry selection to end
+ $sha1entry selection range 0 end
}
rhighlight_sel $id
@@ -8043,7 +8135,8 @@ proc doseldiff {oldid newid} {
}
proc mkpatch {} {
- global rowmenuid currentid commitinfo patchtop patchnum
+ global rowmenuid currentid commitinfo patchtop patchnum use_ttk
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
if {![info exists currentid]} return
set oldid $currentid
@@ -8053,38 +8146,38 @@ proc mkpatch {} {
set top .patch
set patchtop $top
catch {destroy $top}
- toplevel $top
+ ttk_toplevel $top
make_transient $top .
- label $top.title -text [mc "Generate patch"]
+ ${ttk}::label $top.title -text [mc "Generate patch"]
grid $top.title - -pady 10
- label $top.from -text [mc "From:"]
- entry $top.fromsha1 -width 40 -relief flat
+ ${ttk}::label $top.from -text [mc "From:"]
+ ${ttk}::entry $top.fromsha1 -width 40 ;#-relief flat
$top.fromsha1 insert 0 $oldid
$top.fromsha1 conf -state readonly
grid $top.from $top.fromsha1 -sticky w
- entry $top.fromhead -width 60 -relief flat
+ ${ttk}::entry $top.fromhead -width 60 ;#-relief flat
$top.fromhead insert 0 $oldhead
$top.fromhead conf -state readonly
grid x $top.fromhead -sticky w
- label $top.to -text [mc "To:"]
- entry $top.tosha1 -width 40 -relief flat
+ ${ttk}::label $top.to -text [mc "To:"]
+ ${ttk}::entry $top.tosha1 -width 40 ;#-relief flat
$top.tosha1 insert 0 $newid
$top.tosha1 conf -state readonly
grid $top.to $top.tosha1 -sticky w
- entry $top.tohead -width 60 -relief flat
+ ${ttk}::entry $top.tohead -width 60 ;#-relief flat
$top.tohead insert 0 $newhead
- $top.tohead conf -state readonly
+ $top.tohead configure -state readonly
grid x $top.tohead -sticky w
- button $top.rev -text [mc "Reverse"] -command mkpatchrev -padx 5
- grid $top.rev x -pady 10
- label $top.flab -text [mc "Output file:"]
- entry $top.fname -width 60
+ ${ttk}::button $top.rev -text [mc "Reverse"] -command mkpatchrev
+ grid $top.rev x -pady 10 -padx 5
+ ${ttk}::label $top.flab -text [mc "Output file:"]
+ ${ttk}::entry $top.fname -width 60
$top.fname insert 0 [file normalize "patch$patchnum.patch"]
incr patchnum
grid $top.flab $top.fname -sticky w
- frame $top.buts
- button $top.buts.gen -text [mc "Generate"] -command mkpatchgo
- button $top.buts.can -text [mc "Cancel"] -command mkpatchcan
+ ${ttk}::frame $top.buts
+ ${ttk}::button $top.buts.gen -text [mc "Generate"] -command mkpatchgo
+ ${ttk}::button $top.buts.can -text [mc "Cancel"] -command mkpatchcan
bind $top <Key-Return> mkpatchgo
bind $top <Key-Escape> mkpatchcan
grid $top.buts.gen $top.buts.can
@@ -8140,7 +8233,7 @@ proc mktag {} {
set top .maketag
set mktagtop $top
catch {destroy $top}
- toplevel $top
+ ttk_toplevel $top
make_transient $top .
label $top.title -text [mc "Create tag"]
grid $top.title - -pady 10
@@ -8243,7 +8336,7 @@ proc writecommit {} {
set top .writecommit
set wrcomtop $top
catch {destroy $top}
- toplevel $top
+ ttk_toplevel $top
make_transient $top .
label $top.title -text [mc "Write commit to file"]
grid $top.title - -pady 10
@@ -8300,7 +8393,7 @@ proc mkbranch {} {
set top .makebranch
catch {destroy $top}
- toplevel $top
+ ttk_toplevel $top
make_transient $top .
label $top.title -text [mc "Create new branch"]
grid $top.title - -pady 10
@@ -8463,7 +8556,7 @@ proc resethead {} {
set confirm_ok 0
set w ".confirmreset"
- toplevel $w
+ ttk_toplevel $w
make_transient $w .
wm title $w [mc "Confirm reset"]
message $w.m -text \
@@ -8644,7 +8737,7 @@ proc showrefs {} {
refill_reflist
return
}
- toplevel $top
+ ttk_toplevel $top
wm title $top [mc "Tags and heads: %s" [file tail [pwd]]]
make_transient $top .
text $top.list -background $bgcolor -foreground $fgcolor \
@@ -9987,7 +10080,7 @@ proc choosefont {font which} {
if {![winfo exists $top]} {
font create sample
eval font config sample [font actual $font]
- toplevel $top
+ ttk_toplevel $top
make_transient $top $prefstop
wm title $top [mc "Gitk font chooser"]
label $top.l -textvariable fontparam(which)
@@ -10088,10 +10181,11 @@ proc chg_fontparam {v sub op} {
}
proc doprefs {} {
- global maxwidth maxgraphpct
+ global maxwidth maxgraphpct use_ttk
global oldprefs prefstop showneartags showlocalchanges
global bgcolor fgcolor ctext diffcolors selectbgcolor markbgcolor
global tabstop limitdiffs autoselect extdifftool perfile_attrs
+ set ttk [expr {$use_ttk ? "ttk" : ""}]
set top .gitkprefs
set prefstop $top
@@ -10103,97 +10197,95 @@ proc doprefs {} {
limitdiffs tabstop perfile_attrs} {
set oldprefs($v) [set $v]
}
- toplevel $top
+ ttk_toplevel $top
wm title $top [mc "Gitk preferences"]
make_transient $top .
- label $top.ldisp -text [mc "Commit list display options"]
+ ${ttk}::label $top.ldisp -text [mc "Commit list display options"]
grid $top.ldisp - -sticky w -pady 10
- label $top.spacer -text " "
- label $top.maxwidthl -text [mc "Maximum graph width (lines)"] \
+ ${ttk}::label $top.spacer -text " "
+ ${ttk}::label $top.maxwidthl -text [mc "Maximum graph width (lines)"] \
-font optionfont
spinbox $top.maxwidth -from 0 -to 100 -width 4 -textvariable maxwidth
grid $top.spacer $top.maxwidthl $top.maxwidth -sticky w
- label $top.maxpctl -text [mc "Maximum graph width (% of pane)"] \
+ ${ttk}::label $top.maxpctl -text [mc "Maximum graph width (% of pane)"] \
-font optionfont
spinbox $top.maxpct -from 1 -to 100 -width 4 -textvariable maxgraphpct
grid x $top.maxpctl $top.maxpct -sticky w
- checkbutton $top.showlocal -text [mc "Show local changes"] \
- -font optionfont -variable showlocalchanges
+ ${ttk}::checkbutton $top.showlocal -text [mc "Show local changes"] \
+ -variable showlocalchanges
grid x $top.showlocal -sticky w
- checkbutton $top.autoselect -text [mc "Auto-select SHA1"] \
- -font optionfont -variable autoselect
+ ${ttk}::checkbutton $top.autoselect -text [mc "Auto-select SHA1"] \
+ -variable autoselect
grid x $top.autoselect -sticky w
- label $top.ddisp -text [mc "Diff display options"]
+ ${ttk}::label $top.ddisp -text [mc "Diff display options"]
grid $top.ddisp - -sticky w -pady 10
- label $top.tabstopl -text [mc "Tab spacing"] -font optionfont
+ ${ttk}::label $top.tabstopl -text [mc "Tab spacing"] -font optionfont
spinbox $top.tabstop -from 1 -to 20 -width 4 -textvariable tabstop
grid x $top.tabstopl $top.tabstop -sticky w
- checkbutton $top.ntag -text [mc "Display nearby tags"] \
- -font optionfont -variable showneartags
+ ${ttk}::checkbutton $top.ntag -text [mc "Display nearby tags"] \
+ -variable showneartags
grid x $top.ntag -sticky w
- checkbutton $top.ldiff -text [mc "Limit diffs to listed paths"] \
- -font optionfont -variable limitdiffs
+ ${ttk}::checkbutton $top.ldiff -text [mc "Limit diffs to listed paths"] \
+ -variable limitdiffs
grid x $top.ldiff -sticky w
- checkbutton $top.lattr -text [mc "Support per-file encodings"] \
- -font optionfont -variable perfile_attrs
+ ${ttk}::checkbutton $top.lattr -text [mc "Support per-file encodings"] \
+ -variable perfile_attrs
grid x $top.lattr -sticky w
- entry $top.extdifft -textvariable extdifftool
- frame $top.extdifff
- label $top.extdifff.l -text [mc "External diff tool" ] -font optionfont \
- -padx 10
- button $top.extdifff.b -text [mc "Choose..."] -font optionfont \
- -command choose_extdiff
- pack $top.extdifff.l $top.extdifff.b -side left
+ ${ttk}::entry $top.extdifft -textvariable extdifftool
+ ${ttk}::frame $top.extdifff
+ ${ttk}::label $top.extdifff.l -text [mc "External diff tool" ] -font optionfont
+ ${ttk}::button $top.extdifff.b -text [mc "Choose..."] -command choose_extdiff
+ pack $top.extdifff.l -padx 10 ; pack $top.extdifff.b -side left
grid x $top.extdifff $top.extdifft -sticky w
- label $top.cdisp -text [mc "Colors: press to choose"]
+ ${ttk}::label $top.cdisp -text [mc "Colors: press to choose"]
grid $top.cdisp - -sticky w -pady 10
- label $top.bg -padx 40 -relief sunk -background $bgcolor
- button $top.bgbut -text [mc "Background"] -font optionfont \
+ ${ttk}::label $top.bg -relief sunk -background $bgcolor
+ ${ttk}::button $top.bgbut -text [mc "Background"] -font optionfont \
-command [list choosecolor bgcolor {} $top.bg [mc "background"] setbg]
grid x $top.bgbut $top.bg -sticky w
- label $top.fg -padx 40 -relief sunk -background $fgcolor
- button $top.fgbut -text [mc "Foreground"] -font optionfont \
+ ${ttk}::label $top.fg -padx 40 -relief sunk -background $fgcolor
+ ${ttk}::button $top.fgbut -text [mc "Foreground"] -font optionfont \
-command [list choosecolor fgcolor {} $top.fg [mc "foreground"] setfg]
grid x $top.fgbut $top.fg -sticky w
- label $top.diffold -padx 40 -relief sunk -background [lindex $diffcolors 0]
- button $top.diffoldbut -text [mc "Diff: old lines"] -font optionfont \
+ ${ttk}::label $top.diffold -padx 40 -relief sunk -background [lindex $diffcolors 0]
+ ${ttk}::button $top.diffoldbut -text [mc "Diff: old lines"] -font optionfont \
-command [list choosecolor diffcolors 0 $top.diffold [mc "diff old lines"] \
[list $ctext tag conf d0 -foreground]]
grid x $top.diffoldbut $top.diffold -sticky w
- label $top.diffnew -padx 40 -relief sunk -background [lindex $diffcolors 1]
- button $top.diffnewbut -text [mc "Diff: new lines"] -font optionfont \
+ ${ttk}::label $top.diffnew -padx 40 -relief sunk -background [lindex $diffcolors 1]
+ ${ttk}::button $top.diffnewbut -text [mc "Diff: new lines"] -font optionfont \
-command [list choosecolor diffcolors 1 $top.diffnew [mc "diff new lines"] \
[list $ctext tag conf dresult -foreground]]
grid x $top.diffnewbut $top.diffnew -sticky w
- label $top.hunksep -padx 40 -relief sunk -background [lindex $diffcolors 2]
- button $top.hunksepbut -text [mc "Diff: hunk header"] -font optionfont \
+ ${ttk}::label $top.hunksep -padx 40 -relief sunk -background [lindex $diffcolors 2]
+ ${ttk}::button $top.hunksepbut -text [mc "Diff: hunk header"] -font optionfont \
-command [list choosecolor diffcolors 2 $top.hunksep \
[mc "diff hunk header"] \
[list $ctext tag conf hunksep -foreground]]
grid x $top.hunksepbut $top.hunksep -sticky w
- label $top.markbgsep -padx 40 -relief sunk -background $markbgcolor
- button $top.markbgbut -text [mc "Marked line bg"] -font optionfont \
+ ${ttk}::label $top.markbgsep -padx 40 -relief sunk -background $markbgcolor
+ ${ttk}::button $top.markbgbut -text [mc "Marked line bg"] -font optionfont \
-command [list choosecolor markbgcolor {} $top.markbgsep \
[mc "marked line background"] \
[list $ctext tag conf omark -background]]
grid x $top.markbgbut $top.markbgsep -sticky w
- label $top.selbgsep -padx 40 -relief sunk -background $selectbgcolor
- button $top.selbgbut -text [mc "Select bg"] -font optionfont \
+ ${ttk}::label $top.selbgsep -padx 40 -relief sunk -background $selectbgcolor
+ ${ttk}::button $top.selbgbut -text [mc "Select bg"] -font optionfont \
-command [list choosecolor selectbgcolor {} $top.selbgsep [mc "background"] setselbg]
grid x $top.selbgbut $top.selbgsep -sticky w
- label $top.cfont -text [mc "Fonts: press to choose"]
+ ${ttk}::label $top.cfont -text [mc "Fonts: press to choose"]
grid $top.cfont - -sticky w -pady 10
mkfontdisp mainfont $top [mc "Main font"]
mkfontdisp textfont $top [mc "Diff display font"]
mkfontdisp uifont $top [mc "User interface font"]
- frame $top.buts
- button $top.buts.ok -text [mc "OK"] -command prefsok -default active
- button $top.buts.can -text [mc "Cancel"] -command prefscan -default normal
+ ${ttk}::frame $top.buts
+ ${ttk}::button $top.buts.ok -text [mc "OK"] -command prefsok -default active
+ ${ttk}::button $top.buts.can -text [mc "Cancel"] -command prefscan -default normal
bind $top <Key-Return> prefsok
bind $top <Key-Escape> prefscan
grid $top.buts.ok $top.buts.can
@@ -10791,11 +10883,11 @@ proc init {args} {
# check that we can find a .git directory somewhere...
if {[catch {set gitdir [gitdir]}]} {
- show_error {} . [mc "Cannot find a git repository here."]
+ error_popup [mc "Cannot find a git repository here."]
exit 1
}
if {![file isdirectory $gitdir]} {
- show_error {} . [mc "Cannot find the git directory \"%s\"." $gitdir]
+ error_popup [mc "Cannot find the git directory \"%s\"." $gitdir]
exit 1
}
--
1.6.0.2.1172.ga5ed0
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH] gitk: make use of themed widgets where available
2009-02-28 0:18 [PATCH] gitk: make use of themed widgets where available Pat Thoyts
@ 2009-02-28 0:47 ` Sverre Rabbelier
2009-02-28 0:59 ` Pat Thoyts
2009-02-28 2:45 ` Paul Mackerras
2009-03-23 5:34 ` Paul Mackerras
2 siblings, 1 reply; 7+ messages in thread
From: Sverre Rabbelier @ 2009-02-28 0:47 UTC (permalink / raw)
To: Pat Thoyts; +Cc: git, paulus
Heya,
On Sat, Feb 28, 2009 at 01:18, Pat Thoyts
<patthoyts@users.sourceforge.net> wrote:
> This patch improves the appearence of gitk on Windows XP and Vista
> by making use of the themed widgets that are provided in Tk 8.5
> and above. For good Vista support 8.6 will be needed.
Screenies with before/after? :D
--
Cheers,
Sverre Rabbelier
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gitk: make use of themed widgets where available
2009-02-28 0:47 ` Sverre Rabbelier
@ 2009-02-28 0:59 ` Pat Thoyts
0 siblings, 0 replies; 7+ messages in thread
From: Pat Thoyts @ 2009-02-28 0:59 UTC (permalink / raw)
To: git
Sverre Rabbelier <srabbelier <at> gmail.com> writes:
>
> Heya,
>
> On Sat, Feb 28, 2009 at 01:18, Pat Thoyts
> <patthoyts <at> users.sourceforge.net> wrote:
> > This patch improves the appearence of gitk on Windows XP and Vista
> > by making use of the themed widgets that are provided in Tk 8.5
> > and above. For good Vista support 8.6 will be needed.
>
> Screenies with before/after? :D
>
After (on Vista) http://www.patthoyts.tk/screenshots/gitk-vista.png
Pat Thoyts
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gitk: make use of themed widgets where available
2009-02-28 0:18 [PATCH] gitk: make use of themed widgets where available Pat Thoyts
2009-02-28 0:47 ` Sverre Rabbelier
@ 2009-02-28 2:45 ` Paul Mackerras
2009-02-28 9:24 ` Pat Thoyts
2009-03-23 5:34 ` Paul Mackerras
2 siblings, 1 reply; 7+ messages in thread
From: Paul Mackerras @ 2009-02-28 2:45 UTC (permalink / raw)
To: Pat Thoyts; +Cc: git
Pat Thoyts writes:
> This patch improves the appearence of gitk on Windows XP and Vista
> by making use of the themed widgets that are provided in Tk 8.5
> and above. For good Vista support 8.6 will be needed.
Wow. It'll take me a while to digest this. Before I start diving
into it, does gitk still work on Tk 8.4 with this patch?
Paul.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gitk: make use of themed widgets where available
2009-02-28 2:45 ` Paul Mackerras
@ 2009-02-28 9:24 ` Pat Thoyts
0 siblings, 0 replies; 7+ messages in thread
From: Pat Thoyts @ 2009-02-28 9:24 UTC (permalink / raw)
To: Paul Mackerras; +Cc: git
Paul Mackerras <paulus@samba.org> writes:
>Pat Thoyts writes:
>
>> This patch improves the appearence of gitk on Windows XP and Vista
>> by making use of the themed widgets that are provided in Tk 8.5
>> and above. For good Vista support 8.6 will be needed.
>
>Wow. It'll take me a while to digest this. Before I start diving
>into it, does gitk still work on Tk 8.4 with this patch?
>
>Paul.
Yes. It uses the variable 'use_ttk' to turn on the use of the themed
widgets and if this is unavailable (or an option could be provided to
turn it off explicitly) then only standard Tk widgets are used.
--
Pat Thoyts http://www.patthoyts.tk/
PGP fingerprint 2C 6E 98 07 2C 59 C8 97 10 CE 11 E6 04 E0 B9 DD
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gitk: make use of themed widgets where available
2009-02-28 0:18 [PATCH] gitk: make use of themed widgets where available Pat Thoyts
2009-02-28 0:47 ` Sverre Rabbelier
2009-02-28 2:45 ` Paul Mackerras
@ 2009-03-23 5:34 ` Paul Mackerras
2009-03-23 23:28 ` Pat Thoyts
2 siblings, 1 reply; 7+ messages in thread
From: Paul Mackerras @ 2009-03-23 5:34 UTC (permalink / raw)
To: Pat Thoyts; +Cc: git
Pat Thoyts writes:
> This patch improves the appearence of gitk on Windows XP and Vista
> by making use of the themed widgets that are provided in Tk 8.5
> and above. For good Vista support 8.6 will be needed.
>
> Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
Thanks for the patch. It does seem to do a bit more than the commit
description says, though:
- It adds a toggle-fullscreen function. I'd prefer that was done in a
separate patch.
- It makes various changes to the layout in the non-ttk case - in
particular various message widgets get turned into label widgets.
Are label widgets entirely equivalent to message widgets?
Also, the patch has been corrupted by your mailer: on lines containing
only a "+", the "+" has been deleted.
I have a few questions about specific things you've done in the patch:
> +proc ttk_toplevel {w args} {
> + variable use_ttk
> + eval [linsert $args 0 ::toplevel $w]
> + if {$use_ttk} {
> + place [ttk::frame $w._toplevel_background] -x 0 -y 0 -relwidth 1 -relheight 1
What is the effect of this line, or what would happen if it wasn't
there?
> proc show_error {w top msg} {
> + variable use_ttk
> + set ttk [expr {$use_ttk ? "ttk" : ""}]
Is there a strong reason for using variable here rather than global,
or is it just habit?
It looks to me as though $ttk might as well be a global variable,
rather than computing it from $use_ttk everywhere that we need it.
> @@ -1945,8 +1975,10 @@ proc makewindow {} {
> }
> . configure -menu .bar
>
> + place [${ttk}::frame ._main_background] -x 0 -y 0 -relwidth 1 -relheight 1
Once again, what's the reason for using place and the extra frame?
> + if {$use_ttk} {
> + #set p1 [expr {[winfo screenwidth .] - (40 * $charspc)}]
> + #set p0 [expr {[winfo screenwidth .] - (100 * $charspc)}]
> + #.tf.histframe.pwclist sashpos 0 585
> + #.tf.histframe.pwclist sashpos 1 868
> + } else {
> + eval .tf.histframe.pwclist sash place 0 $geometry(pwsash0)
> + eval .tf.histframe.pwclist sash place 1 $geometry(pwsash1)
> + }
Looks like that could be cleaned up a bit.
> - set gm [tk_optionMenu .tf.lbar.gdttype gdttype \
> - [mc "containing:"] \
> - [mc "touching paths:"] \
> - [mc "adding/removing string:"]]
> + if {$use_ttk} {
> + set values [list [mc "containing:"] [mc "touching paths:"] \
> + [mc "adding/removing string:"]]
> + set gm [ttk::combobox .tf.lbar.gdttype -width 10\
> + -values $values -textvariable gdtype]
> + } else {
> + set gm [tk_optionMenu .tf.lbar.gdttype gdttype \
> + [mc "containing:"] \
> + [mc "touching paths:"] \
> + [mc "adding/removing string:"]]
> + }
We could profitably use a helper function here that would take the
list of alternatives and make the combobox/optionMenu.
> - $top.tohead conf -state readonly
> + $top.tohead configure -state readonly
Do all the other instances of conf need to be changed to configure,
and if so, why?
> - checkbutton $top.showlocal -text [mc "Show local changes"] \
> - -font optionfont -variable showlocalchanges
> + ${ttk}::checkbutton $top.showlocal -text [mc "Show local changes"] \
> + -variable showlocalchanges
Why do we lose the -font optionfont?
Thanks,
Paul.
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gitk: make use of themed widgets where available
2009-03-23 5:34 ` Paul Mackerras
@ 2009-03-23 23:28 ` Pat Thoyts
0 siblings, 0 replies; 7+ messages in thread
From: Pat Thoyts @ 2009-03-23 23:28 UTC (permalink / raw)
To: Paul Mackerras; +Cc: git
Paul Mackerras wrote:
> Pat Thoyts writes:
>
>> This patch improves the appearence of gitk on Windows XP and Vista
>> by making use of the themed widgets that are provided in Tk 8.5
>> and above. For good Vista support 8.6 will be needed.
>>
>> Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
>
> Thanks for the patch. It does seem to do a bit more than the commit
> description says, though:
>
> - It adds a toggle-fullscreen function. I'd prefer that was done in a
> separate patch.
Sure. This seems to be a recurring issue that I need to take care of.
> - It makes various changes to the layout in the non-ttk case - in
> particular various message widgets get turned into label widgets.
> Are label widgets entirely equivalent to message widgets?
It depends on how the message widget is being used - but for simple cases
they are equivalent. The message widget has some more options for placing
the text within but is no themed equivalent for message.
> Also, the patch has been corrupted by your mailer: on lines containing
> only a "+", the "+" has been deleted.
Damn - I'm surprised Gnus mashed anything in a patch file.
> I have a few questions about specific things you've done in the patch:
>
>> +proc ttk_toplevel {w args} {
>> + variable use_ttk
>> + eval [linsert $args 0 ::toplevel $w]
>> + if {$use_ttk} {
>> + place [ttk::frame $w._toplevel_background] -x 0 -y 0 -relwidth 1 -relheight 1
>
> What is the effect of this line, or what would happen if it wasn't
> there?
A 'toplevel' widget is not themed so it picks up the default Tk options
for the current platform. Where the theme background colour for a frame
is significantly different to the Tk background colour this becomes
obvious. For instance:
package require Tk 8.5
ttk::style theme use clam
pack [ttk::frame .f -height 100 -width 100] -padx 10 -pady 10
will show a different 10 pixel border around the frame in the Tk default
colour. On some themes the difference is not too noticable, on others
its significant.
>> proc show_error {w top msg} {
>> + variable use_ttk
>> + set ttk [expr {$use_ttk ? "ttk" : ""}]
>
> Is there a strong reason for using variable here rather than global,
> or is it just habit?
habit.
> It looks to me as though $ttk might as well be a global variable,
> rather than computing it from $use_ttk everywhere that we need it.
Agreed
>> @@ -1945,8 +1975,10 @@ proc makewindow {} {
>> }
>> . configure -menu .bar
>>
>> + place [${ttk}::frame ._main_background] -x 0 -y 0 -relwidth 1 -relheight 1
>
> Once again, what's the reason for using place and the extra frame?
As above. The other alternative would be to pack or grid a ttk::frame
and then make all the other widgets children of this and pack/grid them
inside. This is a simpler option.
>
>> + if {$use_ttk} {
>> + #set p1 [expr {[winfo screenwidth .] - (40 * $charspc)}]
>> + #set p0 [expr {[winfo screenwidth .] - (100 * $charspc)}]
>> + #.tf.histframe.pwclist sashpos 0 585
>> + #.tf.histframe.pwclist sashpos 1 868
>> + } else {
>> + eval .tf.histframe.pwclist sash place 0 $geometry(pwsash0)
>> + eval .tf.histframe.pwclist sash place 1 $geometry(pwsash1)
>> + }
>
> Looks like that could be cleaned up a bit.
Doh. I have this fixed properly locally (I'll comment at the end).
>> - set gm [tk_optionMenu .tf.lbar.gdttype gdttype \
>> - [mc "containing:"] \
>> - [mc "touching paths:"] \
>> - [mc "adding/removing string:"]]
>> + if {$use_ttk} {
>> + set values [list [mc "containing:"] [mc "touching paths:"] \
>> + [mc "adding/removing string:"]]
>> + set gm [ttk::combobox .tf.lbar.gdttype -width 10\
>> + -values $values -textvariable gdtype]
>> + } else {
>> + set gm [tk_optionMenu .tf.lbar.gdttype gdttype \
>> + [mc "containing:"] \
>> + [mc "touching paths:"] \
>> + [mc "adding/removing string:"]]
>> + }
>
> We could profitably use a helper function here that would take the
> list of alternatives and make the combobox/optionMenu.
>
>> - $top.tohead conf -state readonly
>> + $top.tohead configure -state readonly
>
> Do all the other instances of conf need to be changed to configure,
> and if so, why?
Using abbreviated subcommand or option names should really be restricted
to interactive code. In script files its better to write it out in full
as you never know in some future version Tk might get more subcommands
added and the abbreviation may no longer be unique.
However, such changes should be put in a separate style patch.
>
>> - checkbutton $top.showlocal -text [mc "Show local changes"] \
>> - -font optionfont -variable showlocalchanges
>> + ${ttk}::checkbutton $top.showlocal -text [mc "Show local changes"] \
>> + -variable showlocalchanges
>
> Why do we lose the -font optionfont?
The point to the ttk widgets is that the visual style of the widget
becomes dictated by the theme and it should no longer be necessary to
specify lots of options on each widget to get it looking reasonable.
When running on Windows, the graphical elements should be drawn using
the system configured fonts and in Tk 8.5+ this is read from the system
parameters info. So if a user configures her system to use large fonts
via the system display properties control panel, then large fonts is
what she will now get.
In fact the ttk::checkbutton doesn't accept a -font option to discourage
people from overriding the users chosen system settings. If you really
need to set the font for a checkbutton then you create a new style and
set the font for that style. Or cheat and use a tk::checkbutton which
provides all the same options it has always done.
For instance:
ttk::style configure Fat.Checkbutton -font {Arial 12 bold}
pack [ttk::checkbutton .check -text Emboldened -style Fat.Checkbutton]
I will redo the ttk patch on top of the new commits and take better care
to isolate them into descrete chunks of work. I have noticed since
posting the patch that it broke the preferences dialog on Linux and the
positions of the panedwindow splitters stopped being saved so these need
rolling into a new patch as well.
Pat Thoyts
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2009-03-23 23:30 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-02-28 0:18 [PATCH] gitk: make use of themed widgets where available Pat Thoyts
2009-02-28 0:47 ` Sverre Rabbelier
2009-02-28 0:59 ` Pat Thoyts
2009-02-28 2:45 ` Paul Mackerras
2009-02-28 9:24 ` Pat Thoyts
2009-03-23 5:34 ` Paul Mackerras
2009-03-23 23:28 ` Pat Thoyts
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).