@ -319,16 +319,6 @@ set _reponame [lindex [file split \
[file normalize [file dirname $_gitdir]]] \
[file normalize [file dirname $_gitdir]]] \
end]
end]
enable_option multicommit
enable_option branch
enable_option transport
if {[appname] eq {git-citool}} {
disable_option multicommit
disable_option branch
disable_option transport
}
######################################################################
######################################################################
##
##
## task management
## task management
@ -1307,7 +1297,7 @@ proc commit_committree {fd_wt curHEAD msg} {
$ui_comm edit reset
$ui_comm edit reset
$ui_comm edit modified false
$ui_comm edit modified false
if {![is_enabled multicommit]} do_quit
if {[is_enabled singlecommit]} do_quit
# -- Update in memory status
# -- Update in memory status
#
#
@ -3236,12 +3226,17 @@ proc read_ls_tree {fd w} {
proc show_blame {commit path} {
proc show_blame {commit path} {
global next_browser_id blame_status blame_data
global next_browser_id blame_status blame_data
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 blame_status($w) {Loading current file content...}
set blame_status($w) {Loading current file content...}
set texts [list]
set texts [list]
toplevel $w
label $w.path -text "$commit:$path" \
label $w.path -text "$commit:$path" \
-anchor w \
-anchor w \
-justify left \
-justify left \
@ -3399,12 +3394,12 @@ proc show_blame {commit path} {
set blame_data($w,colors) {}
set blame_data($w,colors) {}
bind $w <Visibility> "focus $w"
bind $tl <Visibility> "focus $tl"
bind $w <Destroy> "
bind $tl <Destroy> "
array unset blame_status $w
array unset blame_status {$w}
array unset blame_data $w,*
array unset blame_data $w,*
"
"
wm title $w "[appname] ([reponame]): File Viewer"
wm title $tl "[appname] ([reponame]): File Viewer"
set blame_data($w,total_lines) 0
set blame_data($w,total_lines) 0
set cmd [list git cat-file blob "$commit:$path"]
set cmd [list git cat-file blob "$commit:$path"]
@ -3442,7 +3437,9 @@ proc read_blame_catfile {fd w commit path texts w_lno w_file} {
lappend cmd $commit -- $path
lappend cmd $commit -- $path
set fd [open "| $cmd" r]
set fd [open "| $cmd" r]
fconfigure $fd -blocking 0 -translation lf -encoding binary
fconfigure $fd -blocking 0 -translation lf -encoding binary
fileevent $fd readable "read_blame_incremental $fd $w $texts"
set handler [list read_blame_incremental $fd $w]
append handler " $texts"
fileevent $fd readable $handler
}
}
}
}
@ -4916,10 +4913,36 @@ set font_descs {
load_config 0
load_config 0
apply_config
apply_config
######################################################################
##
## feature option selection
enable_option multicommit
enable_option branch
enable_option transport
if {[appname] eq {git-citool}} {
enable_option singlecommit
disable_option multicommit
disable_option branch
disable_option transport
}
switch -- [lindex $argv 0] {
blame {
disable_option multicommit
disable_option branch
disable_option transport
}
}
######################################################################
######################################################################
##
##
## ui construction
## ui construction
set ui_comm {}
# -- Menu Bar
# -- Menu Bar
#
#
menu .mbar -tearoff 0
menu .mbar -tearoff 0
@ -4928,7 +4951,9 @@ menu .mbar -tearoff 0
if {[is_enabled branch]} {
if {[is_enabled branch]} {
.mbar add cascade -label Branch -menu .mbar.branch
.mbar add cascade -label Branch -menu .mbar.branch
}
}
.mbar add cascade -label Commit -menu .mbar.commit
if {[is_enabled multicommit] || [is_enabled singlecommit]} {
.mbar add cascade -label Commit -menu .mbar.commit
}
if {[is_enabled transport]} {
if {[is_enabled transport]} {
.mbar add cascade -label Merge -menu .mbar.merge
.mbar add cascade -label Merge -menu .mbar.merge
.mbar add cascade -label Fetch -menu .mbar.fetch
.mbar add cascade -label Fetch -menu .mbar.fetch
@ -4944,15 +4969,17 @@ menu .mbar.repository
-label {Browse Current Branch} \
-label {Browse Current Branch} \
-command {new_browser $current_branch} \
-command {new_browser $current_branch} \
-font font_ui
-font font_ui
trace add variable current_branch write ".mbar.repository entryconf [.mbar.repository index last] -label \"Browse \$current_branch\" ;#"
.mbar.repository add separator
.mbar.repository add separator
.mbar.repository add command \
.mbar.repository add command \
-label {Visualize Current Branch} \
-label {Visualize Current Branch} \
-command {do_gitk {}} \
-command {do_gitk $current_branch} \
-font font_ui
-font font_ui
trace add variable current_branch write ".mbar.repository entryconf [.mbar.repository index last] -label \"Visualize \$current_branch\" ;#"
.mbar.repository add command \
.mbar.repository add command \
-label {Visualize All Branches} \
-label {Visualize All Branches} \
-command {do_gitk {--all}} \
-command {do_gitk --all} \
-font font_ui
-font font_ui
.mbar.repository add separator
.mbar.repository add separator
@ -5049,73 +5076,75 @@ if {[is_enabled branch]} {
# -- Commit Menu
# -- Commit Menu
#
#
menu .mbar.commit
if {[is_enabled multicommit] || [is_enabled singlecommit]} {
menu .mbar.commit
.mbar.commit add radiobutton \
-label {New Commit} \
.mbar.commit add radiobutton \
-command do_select_commit_type \
-label {New Commit} \
-variable selected_commit_type \
-command do_select_commit_type \
-value new \
-variable selected_commit_type \
-font font_ui
-value new \
lappend disable_on_lock \
-font font_ui
[list .mbar.commit entryconf [.mbar.commit index last] -state]
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add radiobutton \
.mbar.commit add radiobutton \
-label {Amend Last Commit} \
-label {Amend Last Commit} \
-command do_select_commit_type \
-command do_select_commit_type \
-variable selected_commit_type \
-variable selected_commit_type \
-value amend \
-value amend \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add separator
.mbar.commit add separator
.mbar.commit add command -label Rescan \
.mbar.commit add command -label Rescan \
-command do_rescan \
-command do_rescan \
-accelerator F5 \
-accelerator F5 \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add command -label {Add To Commit} \
.mbar.commit add command -label {Add To Commit} \
-command do_add_selection \
-command do_add_selection \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add command -label {Add All To Commit} \
.mbar.commit add command -label {Add All To Commit} \
-command do_add_all \
-command do_add_all \
-accelerator $M1T-I \
-accelerator $M1T-I \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add command -label {Unstage From Commit} \
.mbar.commit add command -label {Unstage From Commit} \
-command do_unstage_selection \
-command do_unstage_selection \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add command -label {Revert Changes} \
.mbar.commit add command -label {Revert Changes} \
-command do_revert_selection \
-command do_revert_selection \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
.mbar.commit add separator
.mbar.commit add separator
.mbar.commit add command -label {Sign Off} \
.mbar.commit add command -label {Sign Off} \
-command do_signoff \
-command do_signoff \
-accelerator $M1T-S \
-accelerator $M1T-S \
-font font_ui
-font font_ui
.mbar.commit add command -label Commit \
.mbar.commit add command -label Commit \
-command do_commit \
-command do_commit \
-accelerator $M1T-Return \
-accelerator $M1T-Return \
-font font_ui
-font font_ui
lappend disable_on_lock \
lappend disable_on_lock \
[list .mbar.commit entryconf [.mbar.commit index last] -state]
[list .mbar.commit entryconf [.mbar.commit index last] -state]
}
if {[is_MacOSX]} {
if {[is_MacOSX]} {
# -- Apple Menu (Mac OS X only)
# -- Apple Menu (Mac OS X only)
@ -5218,6 +5247,34 @@ if {$browser ne {}} {
}
}
unset browser doc_path doc_url
unset browser doc_path doc_url
# -- Standard bindings
#
bind . <Destroy> do_quit
bind all <$M1B-Key-q> do_quit
bind all <$M1B-Key-Q> do_quit
bind all <$M1B-Key-w> {destroy [winfo toplevel %W]}
bind all <$M1B-Key-W> {destroy [winfo toplevel %W]}
# -- Not a normal commit type invocation? Do that instead!
#
switch -- [lindex $argv 0] {
blame {
if {[llength $argv] == 3} {
set current_branch [lindex $argv 1]
show_blame $current_branch [lindex $argv 2]
return
} else {
puts stderr "usage: $argv0 blame commit path"
exit 1
}
}
{} {}
default {
puts stderr "usage: $argv0 \[{blame}\]"
exit 1
}
}
# -- Branch Control
# -- Branch Control
#
#
frame .branch \
frame .branch \
@ -5714,7 +5771,6 @@ if {[is_enabled branch]} {
bind . <$M1B-Key-N> do_create_branch
bind . <$M1B-Key-N> do_create_branch
}
}
bind . <Destroy> do_quit
bind all <Key-F5> do_rescan
bind all <Key-F5> do_rescan
bind all <$M1B-Key-r> do_rescan
bind all <$M1B-Key-r> do_rescan
bind all <$M1B-Key-R> do_rescan
bind all <$M1B-Key-R> do_rescan
@ -5723,10 +5779,6 @@ bind . <$M1B-Key-S> do_signoff
bind . <$M1B-Key-i> do_add_all
bind . <$M1B-Key-i> do_add_all
bind . <$M1B-Key-I> do_add_all
bind . <$M1B-Key-I> do_add_all
bind . <$M1B-Key-Return> do_commit
bind . <$M1B-Key-Return> do_commit
bind all <$M1B-Key-q> do_quit
bind all <$M1B-Key-Q> do_quit
bind all <$M1B-Key-w> {destroy [winfo toplevel %W]}
bind all <$M1B-Key-W> {destroy [winfo toplevel %W]}
foreach i [list $ui_index $ui_workdir] {
foreach i [list $ui_index $ui_workdir] {
bind $i <Button-1> "toggle_or_diff $i %x %y; break"
bind $i <Button-1> "toggle_or_diff $i %x %y; break"
bind $i <$M1B-Button-1> "add_one_to_selection $i %x %y; break"
bind $i <$M1B-Button-1> "add_one_to_selection $i %x %y; break"