Merge branch 'maint'
* maint: Update draft release notes for 1.6.0.2 stash: refresh the index before deciding if the work tree is dirty Mention the fact that 'git annotate' is only for backward compatibility. "blame -c" should be compatible with "annotate" git-gui: Fix diff parsing for lines starting with "--" or "++" git-gui: Fix string escaping in po2msg.sh git gui: show diffs with a minimum of 1 context line git-gui: update all remaining translations to French. git-gui: Update french translation
This commit is contained in:
commit
4a09bc9664
@ -18,19 +18,32 @@ Fixes since v1.6.0.1
|
|||||||
with GIT_WORK_TREE environment settings.
|
with GIT_WORK_TREE environment settings.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
* "git apply --unidiff-zero" incorrectly applied a -U0 patch that inserts
|
* "git apply --unidiff-zero" incorrectly applied a -U0 patch that inserts
|
||||||
a new line before the second line.
|
a new line before the second line.
|
||||||
|
|
||||||
|
* "git blame -c" did not exactly work like "git annotate" when range
|
||||||
|
boundaries are involved.
|
||||||
|
|
||||||
* "git clone $there $here/" with extra trailing slashes after explicit
|
* "git clone $there $here/" with extra trailing slashes after explicit
|
||||||
local directory name $here did not work as expected.
|
local directory name $here did not work as expected.
|
||||||
|
|
||||||
* "git diff --dirstat -M" did not add changes in subdirectories up
|
* "git diff --dirstat -M" did not add changes in subdirectories up
|
||||||
correctly for renamed paths.
|
correctly for renamed paths.
|
||||||
|
|
||||||
|
* "git diff --cumulative" did not imply "--dirstat".
|
||||||
|
|
||||||
* "git for-each-ref refs/heads/" did not work as expected.
|
* "git for-each-ref refs/heads/" did not work as expected.
|
||||||
|
|
||||||
* "git log --grep=pattern -i" did not ignore case.
|
* "git gui" allowed users to feed patch without any context to be applied.
|
||||||
|
|
||||||
|
* "git gui" botched parsing "diff" output when a line that begins with two
|
||||||
|
dashes and a space gets removed or a line that begins with two pluses
|
||||||
|
and a space gets added.
|
||||||
|
|
||||||
|
* "git gui" translation updates and i18n fixes.
|
||||||
|
|
||||||
|
* "git log -i --grep=pattern" did not ignore case; neither "git log -E
|
||||||
|
--grep=pattern" triggered extended regexp.
|
||||||
|
|
||||||
* "git log --pretty="%ad" --date=short" did not use short format when
|
* "git log --pretty="%ad" --date=short" did not use short format when
|
||||||
showing the timestamp.
|
showing the timestamp.
|
||||||
@ -38,6 +51,9 @@ Fixes since v1.6.0.1
|
|||||||
* Build procedure for "git shell" that used stub versions of some
|
* Build procedure for "git shell" that used stub versions of some
|
||||||
functions and globals was not understood by linkers on some platforms.
|
functions and globals was not understood by linkers on some platforms.
|
||||||
|
|
||||||
|
* "git stash" was fooled by a stat-dirty but otherwise unmodified paths
|
||||||
|
and refused to work until the user refreshed the index.
|
||||||
|
|
||||||
* "git verify-pack -v" did not work correctly when given more than one
|
* "git verify-pack -v" did not work correctly when given more than one
|
||||||
packfile.
|
packfile.
|
||||||
|
|
||||||
@ -45,6 +61,7 @@ Also contains many documentation updates.
|
|||||||
|
|
||||||
--
|
--
|
||||||
exec >/var/tmp/1
|
exec >/var/tmp/1
|
||||||
O=v1.6.0.1-49-g6a42cfe
|
O=v1.6.0.1-61-g1eff26c
|
||||||
echo O=$(git describe maint)
|
echo O=$(git describe maint)
|
||||||
git shortlog --no-merges $O..maint
|
git shortlog --no-merges $O..maint
|
||||||
|
|
||||||
|
@ -14,6 +14,11 @@ DESCRIPTION
|
|||||||
Annotates each line in the given file with information from the commit
|
Annotates each line in the given file with information from the commit
|
||||||
which introduced the line. Optionally annotate from a given revision.
|
which introduced the line. Optionally annotate from a given revision.
|
||||||
|
|
||||||
|
The only difference between this command and linkgit:git-blame[1] is that
|
||||||
|
they use slightly different output formats, and this command exists only
|
||||||
|
for backward compatibility to support existing scripts, and provide more
|
||||||
|
familiar command name for people coming from other SCM systems.
|
||||||
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
-------
|
-------
|
||||||
include::blame-options.txt[]
|
include::blame-options.txt[]
|
||||||
|
@ -38,7 +38,6 @@ static int show_root;
|
|||||||
static int reverse;
|
static int reverse;
|
||||||
static int blank_boundary;
|
static int blank_boundary;
|
||||||
static int incremental;
|
static int incremental;
|
||||||
static int cmd_is_annotate;
|
|
||||||
static int xdl_opts = XDF_NEED_MINIMAL;
|
static int xdl_opts = XDF_NEED_MINIMAL;
|
||||||
static struct string_list mailmap;
|
static struct string_list mailmap;
|
||||||
|
|
||||||
@ -1682,7 +1681,7 @@ static void emit_other(struct scoreboard *sb, struct blame_entry *ent, int opt)
|
|||||||
if (suspect->commit->object.flags & UNINTERESTING) {
|
if (suspect->commit->object.flags & UNINTERESTING) {
|
||||||
if (blank_boundary)
|
if (blank_boundary)
|
||||||
memset(hex, ' ', length);
|
memset(hex, ' ', length);
|
||||||
else if (!cmd_is_annotate) {
|
else if (!(opt & OUTPUT_ANNOTATE_COMPAT)) {
|
||||||
length--;
|
length--;
|
||||||
putchar('^');
|
putchar('^');
|
||||||
}
|
}
|
||||||
@ -2313,8 +2312,7 @@ int cmd_blame(int argc, const char **argv, const char *prefix)
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct parse_opt_ctx_t ctx;
|
struct parse_opt_ctx_t ctx;
|
||||||
|
int cmd_is_annotate = !strcmp(argv[0], "annotate");
|
||||||
cmd_is_annotate = !strcmp(argv[0], "annotate");
|
|
||||||
|
|
||||||
git_config(git_blame_config, NULL);
|
git_config(git_blame_config, NULL);
|
||||||
init_revisions(&revs, NULL);
|
init_revisions(&revs, NULL);
|
||||||
@ -2342,6 +2340,9 @@ int cmd_blame(int argc, const char **argv, const char *prefix)
|
|||||||
parse_done:
|
parse_done:
|
||||||
argc = parse_options_end(&ctx);
|
argc = parse_options_end(&ctx);
|
||||||
|
|
||||||
|
if (cmd_is_annotate)
|
||||||
|
output_option |= OUTPUT_ANNOTATE_COMPAT;
|
||||||
|
|
||||||
if (DIFF_OPT_TST(&revs.diffopt, FIND_COPIES_HARDER))
|
if (DIFF_OPT_TST(&revs.diffopt, FIND_COPIES_HARDER))
|
||||||
opt |= (PICKAXE_BLAME_COPY | PICKAXE_BLAME_MOVE |
|
opt |= (PICKAXE_BLAME_COPY | PICKAXE_BLAME_MOVE |
|
||||||
PICKAXE_BLAME_COPY_HARDER);
|
PICKAXE_BLAME_COPY_HARDER);
|
||||||
|
@ -1932,7 +1932,7 @@ proc show_more_context {} {
|
|||||||
|
|
||||||
proc show_less_context {} {
|
proc show_less_context {} {
|
||||||
global repo_config
|
global repo_config
|
||||||
if {$repo_config(gui.diffcontext) >= 1} {
|
if {$repo_config(gui.diffcontext) > 1} {
|
||||||
incr repo_config(gui.diffcontext) -1
|
incr repo_config(gui.diffcontext) -1
|
||||||
reshow_diff
|
reshow_diff
|
||||||
}
|
}
|
||||||
|
@ -175,7 +175,7 @@ proc show_diff {path w {lno {}} {scroll_pos {}}} {
|
|||||||
|
|
||||||
lappend cmd -p
|
lappend cmd -p
|
||||||
lappend cmd --no-color
|
lappend cmd --no-color
|
||||||
if {$repo_config(gui.diffcontext) >= 0} {
|
if {$repo_config(gui.diffcontext) >= 1} {
|
||||||
lappend cmd "-U$repo_config(gui.diffcontext)"
|
lappend cmd "-U$repo_config(gui.diffcontext)"
|
||||||
}
|
}
|
||||||
if {$w eq $ui_index} {
|
if {$w eq $ui_index} {
|
||||||
@ -192,6 +192,7 @@ proc show_diff {path w {lno {}} {scroll_pos {}}} {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set ::current_diff_inheader 1
|
||||||
fconfigure $fd \
|
fconfigure $fd \
|
||||||
-blocking 0 \
|
-blocking 0 \
|
||||||
-encoding binary \
|
-encoding binary \
|
||||||
@ -207,18 +208,21 @@ proc read_diff {fd scroll_pos} {
|
|||||||
while {[gets $fd line] >= 0} {
|
while {[gets $fd line] >= 0} {
|
||||||
# -- Cleanup uninteresting diff header lines.
|
# -- Cleanup uninteresting diff header lines.
|
||||||
#
|
#
|
||||||
if { [string match {diff --git *} $line]
|
if {$::current_diff_inheader} {
|
||||||
|| [string match {diff --cc *} $line]
|
if { [string match {diff --git *} $line]
|
||||||
|| [string match {diff --combined *} $line]
|
|| [string match {diff --cc *} $line]
|
||||||
|| [string match {--- *} $line]
|
|| [string match {diff --combined *} $line]
|
||||||
|| [string match {+++ *} $line]} {
|
|| [string match {--- *} $line]
|
||||||
append current_diff_header $line "\n"
|
|| [string match {+++ *} $line]} {
|
||||||
continue
|
append current_diff_header $line "\n"
|
||||||
|
continue
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if {[string match {index *} $line]} continue
|
if {[string match {index *} $line]} continue
|
||||||
if {$line eq {deleted file mode 120000}} {
|
if {$line eq {deleted file mode 120000}} {
|
||||||
set line "deleted symlink"
|
set line "deleted symlink"
|
||||||
}
|
}
|
||||||
|
set ::current_diff_inheader 0
|
||||||
|
|
||||||
# -- Automatically detect if this is a 3 way diff.
|
# -- Automatically detect if this is a 3 way diff.
|
||||||
#
|
#
|
||||||
|
@ -125,7 +125,7 @@ proc do_options {} {
|
|||||||
{b gui.matchtrackingbranch {mc "Match Tracking Branches"}}
|
{b gui.matchtrackingbranch {mc "Match Tracking Branches"}}
|
||||||
{b gui.fastcopyblame {mc "Blame Copy Only On Changed Files"}}
|
{b gui.fastcopyblame {mc "Blame Copy Only On Changed Files"}}
|
||||||
{i-20..200 gui.copyblamethreshold {mc "Minimum Letters To Blame Copy On"}}
|
{i-20..200 gui.copyblamethreshold {mc "Minimum Letters To Blame Copy On"}}
|
||||||
{i-0..99 gui.diffcontext {mc "Number of Diff Context Lines"}}
|
{i-1..99 gui.diffcontext {mc "Number of Diff Context Lines"}}
|
||||||
{i-0..99 gui.commitmsgwidth {mc "Commit Message Text Width"}}
|
{i-0..99 gui.commitmsgwidth {mc "Commit Message Text Width"}}
|
||||||
{t gui.newbranchtemplate {mc "New Branch Name Template"}}
|
{t gui.newbranchtemplate {mc "New Branch Name Template"}}
|
||||||
} {
|
} {
|
||||||
|
918
git-gui/po/fr.po
918
git-gui/po/fr.po
File diff suppressed because it is too large
Load Diff
@ -11,8 +11,8 @@ proc u2a {s} {
|
|||||||
foreach i [split $s ""] {
|
foreach i [split $s ""] {
|
||||||
scan $i %c c
|
scan $i %c c
|
||||||
if {$c<128} {
|
if {$c<128} {
|
||||||
# escape '[', '\' and ']'
|
# escape '[', '\', '$' and ']'
|
||||||
if {$c == 0x5b || $c == 0x5d} {
|
if {$c == 0x5b || $c == 0x5d || $c == 0x24} {
|
||||||
append res "\\"
|
append res "\\"
|
||||||
}
|
}
|
||||||
append res $i
|
append res $i
|
||||||
|
@ -39,6 +39,7 @@ clear_stash () {
|
|||||||
create_stash () {
|
create_stash () {
|
||||||
stash_msg="$1"
|
stash_msg="$1"
|
||||||
|
|
||||||
|
git update-index -q --refresh
|
||||||
if no_changes
|
if no_changes
|
||||||
then
|
then
|
||||||
exit 0
|
exit 0
|
||||||
@ -101,6 +102,7 @@ save_stash () {
|
|||||||
|
|
||||||
stash_msg="$*"
|
stash_msg="$*"
|
||||||
|
|
||||||
|
git update-index -q --refresh
|
||||||
if no_changes
|
if no_changes
|
||||||
then
|
then
|
||||||
echo 'No local changes to save'
|
echo 'No local changes to save'
|
||||||
@ -150,6 +152,7 @@ show_stash () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
apply_stash () {
|
apply_stash () {
|
||||||
|
git update-index -q --refresh &&
|
||||||
git diff-files --quiet --ignore-submodules ||
|
git diff-files --quiet --ignore-submodules ||
|
||||||
die 'Cannot restore on top of a dirty state'
|
die 'Cannot restore on top of a dirty state'
|
||||||
|
|
||||||
|
@ -488,4 +488,17 @@ test_expect_success 'cvs co -c (shows module database)' '
|
|||||||
! grep -v "^master[ ]\+master$" < out
|
! grep -v "^master[ ]\+master$" < out
|
||||||
'
|
'
|
||||||
|
|
||||||
|
#------------
|
||||||
|
# CVS ANNOTATE
|
||||||
|
#------------
|
||||||
|
|
||||||
|
cd "$WORKDIR"
|
||||||
|
test_expect_success 'cvs annotate' '
|
||||||
|
cd cvswork &&
|
||||||
|
GIT_CONFIG="$git_config" cvs annotate merge >../out &&
|
||||||
|
sed -e "s/ .*//" ../out >../actual &&
|
||||||
|
for i in 3 1 1 1 1 1 1 1 2 4; do echo 1.$i; done >../expect &&
|
||||||
|
test_cmp ../expect ../actual
|
||||||
|
'
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
Loading…
Reference in New Issue
Block a user