@ -3044,7 +3044,14 @@ proc new_browser {commit} {
global next_browser_id cursor_ptr M1B
global next_browser_id cursor_ptr M1B
global browser_commit browser_status browser_stack browser_path browser_busy
global browser_commit browser_status browser_stack browser_path browser_busy
set w .browser[incr next_browser_id]
if {[winfo ismapped .]} {
set w .browser[incr next_browser_id]
set tl $w
toplevel $w
} else {
set w {}
set tl .
}
set w_list $w.list.l
set w_list $w.list.l
set browser_commit($w_list) $commit
set browser_commit($w_list) $commit
set browser_status($w_list) {Starting...}
set browser_status($w_list) {Starting...}
@ -3052,7 +3059,6 @@ proc new_browser {commit} {
set browser_path($w_list) $browser_commit($w_list):
set browser_path($w_list) $browser_commit($w_list):
set browser_busy($w_list) 1
set browser_busy($w_list) 1
toplevel $w
label $w.path -textvariable browser_path($w_list) \
label $w.path -textvariable browser_path($w_list) \
-anchor w \
-anchor w \
-justify left \
-justify left \
@ -3102,8 +3108,8 @@ proc new_browser {commit} {
bind $w_list <Left> break
bind $w_list <Left> break
bind $w_list <Right> break
bind $w_list <Right> break
bind $w <Visibility> "focus $w"
bind $tl <Visibility> "focus $w"
bind $w <Destroy> "
bind $tl <Destroy> "
array unset browser_buffer $w_list
array unset browser_buffer $w_list
array unset browser_files $w_list
array unset browser_files $w_list
array unset browser_status $w_list
array unset browser_status $w_list
@ -3112,7 +3118,7 @@ proc new_browser {commit} {
array unset browser_commit $w_list
array unset browser_commit $w_list
array unset browser_busy $w_list
array unset browser_busy $w_list
"
"
wm title $w "[appname] ([reponame]): File Browser"
wm title $tl "[appname] ([reponame]): File Browser"
ls_tree $w_list $browser_commit($w_list) {}
ls_tree $w_list $browser_commit($w_list) {}
}
}
@ -5019,6 +5025,7 @@ enable_option transport
switch -- $subcommand {
switch -- $subcommand {
--version -
--version -
version -
version -
browser -
blame {
blame {
disable_option multicommit
disable_option multicommit
disable_option branch
disable_option branch
@ -5359,6 +5366,15 @@ version {
puts "git-gui version $appvers"
puts "git-gui version $appvers"
exit
exit
}
}
browser {
if {[llength $argv] != 1} {
puts stderr "usage: $argv0 browser commit"
exit 1
}
set current_branch [lindex $argv 0]
new_browser $current_branch
return
}
blame {
blame {
if {[llength $argv] != 2} {
if {[llength $argv] != 2} {
puts stderr "usage: $argv0 blame commit path"
puts stderr "usage: $argv0 blame commit path"