* [PATCH] Make gitk save and restore window pane position on Linux and Cygwin.
@ 2007-02-13 0:19 Mark Levedahl
2007-02-13 1:15 ` Junio C Hamano
0 siblings, 1 reply; 4+ messages in thread
From: Mark Levedahl @ 2007-02-13 0:19 UTC (permalink / raw)
To: junkio, git; +Cc: Mark Levedahl
Subtle bugs remained on both Cygwin and Linux that caused the various
window panes to be restored in positions different than where the user
last placed them. Sergey Vlasov posed a pair of suggested fixes to this,
what is done here is slightly different. The basic fix here involves
a) explicitly remembering and restoring the sash positions for the upper
window, and b) using paneconfigure to redundantly set height and width of
other elements. This redundancy is needed as Cygwin Tcl has a nasty habit
of setting pane sizes to zero if their slaves are not configured with a
specific size, but Linux Tcl does not honor the specific size given.
Signed-off-by: Mark Levedahl <mdl123@verizon.net>
---
gitk | 23 +++++++++++++----------
1 files changed, 13 insertions(+), 10 deletions(-)
diff --git a/gitk b/gitk
index df1ce8c..9ddff3e 100755
--- a/gitk
+++ b/gitk
@@ -439,14 +439,13 @@ proc makewindow {} {
panedwindow .ctop -orient vertical
# possibly use assumed geometry
- if {![info exists geometry(topheight)]} {
+ if {![info exists geometry(pwsash0)]} {
set geometry(topheight) [expr {15 * $linespc}]
set geometry(topwidth) [expr {80 * $charspc}]
set geometry(botheight) [expr {15 * $linespc}]
set geometry(botwidth) [expr {50 * $charspc}]
- set geometry(canv) [expr {40 * $charspc}]
- set geometry(canv2) [expr {20 * $charspc}]
- set geometry(canv3) [expr {20 * $charspc}]
+ set geometry(pwsash0) "[expr {40 * $charspc}] 2"
+ set geometry(pwsash1) "[expr {60 * $charspc}] 2"
}
# the upper half will have a paned window, a scroll bar to the right, and some stuff below
@@ -457,18 +456,20 @@ proc makewindow {} {
# create three canvases
set cscroll .tf.histframe.csb
set canv .tf.histframe.pwclist.canv
- canvas $canv -width $geometry(canv) \
+ canvas $canv \
-background $bgcolor -bd 0 \
-yscrollincr $linespc -yscrollcommand "scrollcanv $cscroll"
.tf.histframe.pwclist add $canv
set canv2 .tf.histframe.pwclist.canv2
- canvas $canv2 -width $geometry(canv2) \
+ canvas $canv2 \
-background $bgcolor -bd 0 -yscrollincr $linespc
.tf.histframe.pwclist add $canv2
set canv3 .tf.histframe.pwclist.canv3
- canvas $canv3 -width $geometry(canv3) \
+ canvas $canv3 \
-background $bgcolor -bd 0 -yscrollincr $linespc
.tf.histframe.pwclist add $canv3
+ 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
@@ -577,6 +578,8 @@ 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)
# now build up the bottom
panedwindow .pwbottom -orient horizontal
@@ -638,6 +641,7 @@ proc makewindow {} {
$ctext tag conf found -back yellow
.pwbottom add .bleft
+ .pwbottom paneconfigure .bleft -width $geometry(botwidth)
# lower right
frame .bright
@@ -832,9 +836,8 @@ proc savestuff {w} {
puts $f "set geometry(main) [wm geometry .]"
puts $f "set geometry(topwidth) [winfo width .tf]"
puts $f "set geometry(topheight) [winfo height .tf]"
- puts $f "set geometry(canv) [winfo width $canv]"
- puts $f "set geometry(canv2) [winfo width $canv2]"
- puts $f "set geometry(canv3) [winfo width $canv3]"
+ puts $f "set geometry(pwsash0) \"[.tf.histframe.pwclist sash coord 0]\""
+ puts $f "set geometry(pwsash1) \"[.tf.histframe.pwclist sash coord 1]\""
puts $f "set geometry(botwidth) [winfo width .bleft]"
puts $f "set geometry(botheight) [winfo height .bleft]"
--
1.5.0.rc3.24.g0c5e
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] Make gitk save and restore window pane position on Linux and Cygwin.
2007-02-13 0:19 [PATCH] Make gitk save and restore window pane position on Linux and Cygwin Mark Levedahl
@ 2007-02-13 1:15 ` Junio C Hamano
2007-02-13 11:10 ` Sergey Vlasov
0 siblings, 1 reply; 4+ messages in thread
From: Junio C Hamano @ 2007-02-13 1:15 UTC (permalink / raw)
To: Sergey Vlasov; +Cc: Mark Levedahl, git
This looks sane to me, although a bit twisted (and again it is
not Mark's fault). Sergey, Ack?
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] Make gitk save and restore window pane position on Linux and Cygwin.
2007-02-13 1:15 ` Junio C Hamano
@ 2007-02-13 11:10 ` Sergey Vlasov
2007-02-13 17:45 ` Junio C Hamano
0 siblings, 1 reply; 4+ messages in thread
From: Sergey Vlasov @ 2007-02-13 11:10 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Mark Levedahl, git
[-- Attachment #1: Type: text/plain, Size: 207 bytes --]
On Mon, Feb 12, 2007 at 05:15:53PM -0800, Junio C Hamano wrote:
> This looks sane to me, although a bit twisted (and again it is
> not Mark's fault). Sergey, Ack?
Yes, current git (85b1f988) works for me.
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] Make gitk save and restore window pane position on Linux and Cygwin.
2007-02-13 11:10 ` Sergey Vlasov
@ 2007-02-13 17:45 ` Junio C Hamano
0 siblings, 0 replies; 4+ messages in thread
From: Junio C Hamano @ 2007-02-13 17:45 UTC (permalink / raw)
To: Sergey Vlasov; +Cc: Mark Levedahl, git
Sergey Vlasov <vsu@altlinux.ru> writes:
> On Mon, Feb 12, 2007 at 05:15:53PM -0800, Junio C Hamano wrote:
>> This looks sane to me, although a bit twisted (and again it is
>> not Mark's fault). Sergey, Ack?
>
> Yes, current git (85b1f988) works for me.
Thanks, both.
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2007-02-13 17:45 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-02-13 0:19 [PATCH] Make gitk save and restore window pane position on Linux and Cygwin Mark Levedahl
2007-02-13 1:15 ` Junio C Hamano
2007-02-13 11:10 ` Sergey Vlasov
2007-02-13 17:45 ` Junio C Hamano
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).