git-gui: Allow the user to control the number of context lines in a diff.
When displaying a diff the Git default of 3 line of context may not be enough for a user to see what has actually changed. Consequently we set our own program default to 5 lines of context and then allow the user to adjust this on a per-repository and global level through our options dialog. Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
This commit is contained in:
parent
fd2656fdfe
commit
358d8de8f3
54
git-gui
54
git-gui
@ -517,6 +517,9 @@ proc show_diff {path {w {}} {lno {}}} {
|
|||||||
|
|
||||||
set cmd [list | git diff-index]
|
set cmd [list | git diff-index]
|
||||||
lappend cmd --no-color
|
lappend cmd --no-color
|
||||||
|
if {$repo_config(gui.diffcontext) > 0} {
|
||||||
|
lappend cmd "-U$repo_config(gui.diffcontext)"
|
||||||
|
}
|
||||||
lappend cmd -p
|
lappend cmd -p
|
||||||
|
|
||||||
switch $m {
|
switch $m {
|
||||||
@ -1765,12 +1768,18 @@ proc do_options {} {
|
|||||||
global repo_config global_config
|
global repo_config global_config
|
||||||
global repo_config_new global_config_new
|
global repo_config_new global_config_new
|
||||||
|
|
||||||
load_config 1
|
|
||||||
array unset repo_config_new
|
array unset repo_config_new
|
||||||
array unset global_config_new
|
array unset global_config_new
|
||||||
foreach name [array names repo_config] {
|
foreach name [array names repo_config] {
|
||||||
set repo_config_new($name) $repo_config($name)
|
set repo_config_new($name) $repo_config($name)
|
||||||
}
|
}
|
||||||
|
load_config 1
|
||||||
|
foreach name [array names repo_config] {
|
||||||
|
switch -- $name {
|
||||||
|
gui.diffcontext {continue}
|
||||||
|
}
|
||||||
|
set repo_config_new($name) $repo_config($name)
|
||||||
|
}
|
||||||
foreach name [array names global_config] {
|
foreach name [array names global_config] {
|
||||||
set global_config_new($name) $global_config($name)
|
set global_config_new($name) $global_config($name)
|
||||||
}
|
}
|
||||||
@ -1811,12 +1820,16 @@ proc do_options {} {
|
|||||||
pack $w.global -side right -fill both -expand 1 -pady 5 -padx 5
|
pack $w.global -side right -fill both -expand 1 -pady 5 -padx 5
|
||||||
|
|
||||||
foreach option {
|
foreach option {
|
||||||
{pullsummary {Show Pull Summary}}
|
{b pullsummary {Show Pull Summary}}
|
||||||
{trustmtime {Trust File Modification Timestamps}}
|
{b trustmtime {Trust File Modification Timestamps}}
|
||||||
|
{i diffcontext {Number of Diff Context Lines}}
|
||||||
} {
|
} {
|
||||||
set name [lindex $option 0]
|
set type [lindex $option 0]
|
||||||
set text [lindex $option 1]
|
set name [lindex $option 1]
|
||||||
|
set text [lindex $option 2]
|
||||||
foreach f {repo global} {
|
foreach f {repo global} {
|
||||||
|
switch $type {
|
||||||
|
b {
|
||||||
checkbutton $w.$f.$name -text $text \
|
checkbutton $w.$f.$name -text $text \
|
||||||
-variable ${f}_config_new(gui.$name) \
|
-variable ${f}_config_new(gui.$name) \
|
||||||
-onvalue true \
|
-onvalue true \
|
||||||
@ -1824,6 +1837,20 @@ proc do_options {} {
|
|||||||
-font font_ui
|
-font font_ui
|
||||||
pack $w.$f.$name -side top -anchor w
|
pack $w.$f.$name -side top -anchor w
|
||||||
}
|
}
|
||||||
|
i {
|
||||||
|
frame $w.$f.$name
|
||||||
|
label $w.$f.$name.l -text "$text:" -font font_ui
|
||||||
|
pack $w.$f.$name.l -side left -anchor w -fill x
|
||||||
|
spinbox $w.$f.$name.v \
|
||||||
|
-textvariable ${f}_config_new(gui.$name) \
|
||||||
|
-from 1 -to 99 -increment 1 \
|
||||||
|
-width 3 \
|
||||||
|
-font font_ui
|
||||||
|
pack $w.$f.$name.v -side right -anchor e
|
||||||
|
pack $w.$f.$name -side top -anchor w -fill x
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
set all_fonts [lsort [font families]]
|
set all_fonts [lsort [font families]]
|
||||||
@ -1888,6 +1915,7 @@ proc do_save_config {w} {
|
|||||||
if {[catch {save_config} err]} {
|
if {[catch {save_config} err]} {
|
||||||
error_popup "Failed to completely save options:\n\n$err"
|
error_popup "Failed to completely save options:\n\n$err"
|
||||||
}
|
}
|
||||||
|
reshow_diff
|
||||||
destroy $w
|
destroy $w
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1969,6 +1997,7 @@ proc apply_config {} {
|
|||||||
|
|
||||||
set default_config(gui.trustmtime) false
|
set default_config(gui.trustmtime) false
|
||||||
set default_config(gui.pullsummary) true
|
set default_config(gui.pullsummary) true
|
||||||
|
set default_config(gui.diffcontext) 5
|
||||||
set default_config(gui.fontui) [font configure font_ui]
|
set default_config(gui.fontui) [font configure font_ui]
|
||||||
set default_config(gui.fontdiff) [font configure font_diff]
|
set default_config(gui.fontdiff) [font configure font_diff]
|
||||||
set font_descs {
|
set font_descs {
|
||||||
@ -2318,6 +2347,21 @@ $ui_diff.ctxm add command -label "Decrease Font Size" \
|
|||||||
$ui_diff.ctxm add command -label "Increase Font Size" \
|
$ui_diff.ctxm add command -label "Increase Font Size" \
|
||||||
-font font_ui \
|
-font font_ui \
|
||||||
-command {incr_font_size font_diff 1}
|
-command {incr_font_size font_diff 1}
|
||||||
|
$ui_diff.ctxm add separator
|
||||||
|
$ui_diff.ctxm add command -label "Show Less Context" \
|
||||||
|
-font font_ui \
|
||||||
|
-command {if {$ui_fname_value ne {}
|
||||||
|
&& $repo_config(gui.diffcontext) >= 2} {
|
||||||
|
incr repo_config(gui.diffcontext) -1
|
||||||
|
reshow_diff
|
||||||
|
}}
|
||||||
|
$ui_diff.ctxm add command -label "Show More Context" \
|
||||||
|
-font font_ui \
|
||||||
|
-command {if {$ui_fname_value ne {}} {
|
||||||
|
incr repo_config(gui.diffcontext)
|
||||||
|
reshow_diff
|
||||||
|
}}
|
||||||
|
$ui_diff.ctxm add separator
|
||||||
$ui_diff.ctxm add command -label {Options...} \
|
$ui_diff.ctxm add command -label {Options...} \
|
||||||
-font font_ui \
|
-font font_ui \
|
||||||
-command do_options
|
-command do_options
|
||||||
|
Loading…
Reference in New Issue
Block a user