git-gui: fix size and position of window panes on startup
The themed panedwindow needs to have the sash position set after the widget has been mapped therefore apply this setting in the Map event binding. To avoid visible redraws as the application is constructed the main window should be withdrawn until all the widgets have been added Signed-off-by: Pat Thoyts <patthoyts@users.sourceforge.net>
This commit is contained in:
parent
9cb268c426
commit
2810a58dba
55
git-gui.sh
55
git-gui.sh
@ -334,6 +334,8 @@ proc _trace_exec {cmd} {
|
|||||||
puts stderr $d
|
puts stderr $d
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#'" fix poor old emacs font-lock mode
|
||||||
|
|
||||||
proc _git_cmd {name} {
|
proc _git_cmd {name} {
|
||||||
global _git_cmd_path
|
global _git_cmd_path
|
||||||
|
|
||||||
@ -648,6 +650,7 @@ proc rmsel_tag {text} {
|
|||||||
return $text
|
return $text
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wm withdraw .
|
||||||
set root_exists 0
|
set root_exists 0
|
||||||
bind . <Visibility> {
|
bind . <Visibility> {
|
||||||
bind . <Visibility> {}
|
bind . <Visibility> {}
|
||||||
@ -2919,6 +2922,7 @@ blame {
|
|||||||
set current_branch $head
|
set current_branch $head
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wm deiconify .
|
||||||
switch -- $subcommand {
|
switch -- $subcommand {
|
||||||
browser {
|
browser {
|
||||||
if {$jump_spec ne {}} usage
|
if {$jump_spec ne {}} usage
|
||||||
@ -3492,29 +3496,44 @@ $main_status show [mc "Initializing..."]
|
|||||||
|
|
||||||
# -- Load geometry
|
# -- Load geometry
|
||||||
#
|
#
|
||||||
catch {
|
proc on_ttk_pane_mapped {w pane pos} {
|
||||||
set gm $repo_config(gui.geometry)
|
bind $w <Map> {}
|
||||||
wm geometry . [lindex $gm 0]
|
after 0 [list after idle [list $w sashpos $pane $pos]]
|
||||||
if {$use_ttk} {
|
|
||||||
.vpane sashpos 0 [lindex $gm 1]
|
|
||||||
.vpane.files sashpos 0 [lindex $gm 2]
|
|
||||||
} else {
|
|
||||||
.vpane sash place 0 \
|
|
||||||
[lindex $gm 1] \
|
|
||||||
[lindex [.vpane sash coord 0] 1]
|
|
||||||
.vpane.files sash place 0 \
|
|
||||||
[lindex [.vpane.files sash coord 0] 0] \
|
|
||||||
[lindex $gm 2]
|
|
||||||
}
|
}
|
||||||
unset gm
|
proc on_tk_pane_mapped {w pane x y} {
|
||||||
|
bind $w <Map> {}
|
||||||
|
after 0 [list after idle [list $w sash place $pane $x $y]]
|
||||||
|
}
|
||||||
|
proc on_application_mapped {} {
|
||||||
|
global repo_config use_ttk
|
||||||
|
bind . <Map> {}
|
||||||
|
set gm $repo_config(gui.geometry)
|
||||||
|
if {$use_ttk} {
|
||||||
|
bind .vpane <Map> \
|
||||||
|
[list on_ttk_pane_mapped %W 0 [lindex $gm 1]]
|
||||||
|
bind .vpane.files <Map> \
|
||||||
|
[list on_ttk_pane_mapped %W 0 [lindex $gm 2]]
|
||||||
|
} else {
|
||||||
|
bind .vpane <Map> \
|
||||||
|
[list on_tk_pane_mapped %W 0 \
|
||||||
|
[lindex $gm 1] \
|
||||||
|
[lindex [.vpane sash coord 0] 1]]
|
||||||
|
bind .vpane.files <Map> \
|
||||||
|
[list on_tk_pane_mapped %W 0 \
|
||||||
|
[lindex [.vpane.files sash coord 0] 0] \
|
||||||
|
[lindex $gm 2]]
|
||||||
|
}
|
||||||
|
wm geometry . [lindex $gm 0]
|
||||||
|
}
|
||||||
|
if {[info exists repo_config(gui.geometry)]} {
|
||||||
|
bind . <Map> [list on_application_mapped]
|
||||||
|
wm geometry . [lindex $repo_config(gui.geometry) 0]
|
||||||
}
|
}
|
||||||
|
|
||||||
# -- Load window state
|
# -- Load window state
|
||||||
#
|
#
|
||||||
catch {
|
if {[info exists repo_config(gui.wmstate)]} {
|
||||||
set gws $repo_config(gui.wmstate)
|
catch {wm state . $repo_config(gui.wmstate)}
|
||||||
wm state . $gws
|
|
||||||
unset gws
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# -- Key Bindings
|
# -- Key Bindings
|
||||||
|
Loading…
Reference in New Issue
Block a user