Merge branch 'maint'

* maint:
  Yet more 1.5.3.5 fixes mentioned in release notes
  cvsserver: Use exit 1 instead of die when req_Root fails.
  git-blame shouldn't crash if run in an unmerged tree
  git-config: print error message if the config file cannot be read
  fixing output of non-fast-forward output of post-receive-email
This commit is contained in:
Shawn O. Pearce 2007-10-18 03:11:17 -04:00
commit e75c55844f
6 changed files with 92 additions and 4 deletions

View File

@ -10,9 +10,14 @@ Fixes since v1.5.3.4
* "git-config --file" failed if the argument used a relative path * "git-config --file" failed if the argument used a relative path
as it changed directories before opening the file. as it changed directories before opening the file.
* "git-config --file" now displays a proper error message if it
cannot read the file specified on the command line.
* "git-config", "git-diff", "git-apply" failed if run from a * "git-config", "git-diff", "git-apply" failed if run from a
subdirectory with relative GIT_DIR and GIT_WORK_TREE set. subdirectory with relative GIT_DIR and GIT_WORK_TREE set.
* "git-blame" crashed if run during a merge conflict.
* "git-add -i" did not handle single line hunks correctly. * "git-add -i" did not handle single line hunks correctly.
* "git-rebase -i" failed if external diff drivers were used for one * "git-rebase -i" failed if external diff drivers were used for one
@ -33,6 +38,9 @@ Fixes since v1.5.3.4
* "git-instaweb" no longer fails on Mac OS X. * "git-instaweb" no longer fails on Mac OS X.
* post-receive-email example hook fixed was fixed for
non-fast-forward updates.
* Documentation updates for supported (but previously undocumented) * Documentation updates for supported (but previously undocumented)
options of "git-archive" and "git-reflog". options of "git-archive" and "git-reflog".

View File

@ -175,7 +175,10 @@ int cmd_config(int argc, const char **argv, const char *prefix)
else if (!strcmp(argv[1], "--list") || !strcmp(argv[1], "-l")) { else if (!strcmp(argv[1], "--list") || !strcmp(argv[1], "-l")) {
if (argc != 2) if (argc != 2)
usage(git_config_set_usage); usage(git_config_set_usage);
return git_config(show_all_config); if (git_config(show_all_config) < 0 && file && errno)
die("unable to read config file %s: %s", file,
strerror(errno));
return 0;
} }
else if (!strcmp(argv[1], "--global")) { else if (!strcmp(argv[1], "--global")) {
char *home = getenv("HOME"); char *home = getenv("HOME");

View File

@ -331,7 +331,7 @@ generate_update_branch_email()
echo " via $rev ($revtype)" echo " via $rev ($revtype)"
done done
if [ -z "$fastforward" ]; then if [ "$fast_forward" ]; then
echo " from $oldrev ($oldrev_type)" echo " from $oldrev ($oldrev_type)"
else else
# 1. Existing revisions were removed. In this case newrev is a # 1. Existing revisions were removed. In this case newrev is a

View File

@ -145,8 +145,10 @@ if ($state->{method} eq 'pserver') {
} }
my $request = $1; my $request = $1;
$line = <STDIN>; chomp $line; $line = <STDIN>; chomp $line;
req_Root('root', $line) # reuse Root unless (req_Root('root', $line)) { # reuse Root
or die "E Invalid root $line \n"; print "E Invalid root $line \n";
exit 1;
}
$line = <STDIN>; chomp $line; $line = <STDIN>; chomp $line;
unless ($line eq 'anonymous') { unless ($line eq 'anonymous') {
print "E Only anonymous user allowed via pserver\n"; print "E Only anonymous user allowed via pserver\n";

View File

@ -149,6 +149,8 @@ static int ce_match_stat_basic(struct cache_entry *ce, struct stat *st)
else if (ce_compare_gitlink(ce)) else if (ce_compare_gitlink(ce))
changed |= DATA_CHANGED; changed |= DATA_CHANGED;
return changed; return changed;
case 0: /* Special case: unmerged file in index */
return MODE_CHANGED | DATA_CHANGED | TYPE_CHANGED;
default: default:
die("internal error: ce_mode is %o", ntohl(ce->ce_mode)); die("internal error: ce_mode is %o", ntohl(ce->ce_mode));
} }

73
t/t8004-blame.sh Executable file
View File

@ -0,0 +1,73 @@
#!/bin/sh
# Based on a test case submitted by Björn Steinbrink.
test_description='git blame on conflicted files'
. ./test-lib.sh
test_expect_success 'setup first case' '
# Create the old file
echo "Old line" > file1 &&
git add file1 &&
git commit --author "Old Line <ol@localhost>" -m file1.a &&
# Branch
git checkout -b foo &&
# Do an ugly move and change
git rm file1 &&
echo "New line ..." > file2 &&
echo "... and more" >> file2 &&
git add file2 &&
git commit --author "U Gly <ug@localhost>" -m ugly &&
# Back to master and change something
git checkout master &&
echo "
bla" >> file1 &&
git commit --author "Old Line <ol@localhost>" -a -m file1.b &&
# Back to foo and merge master
git checkout foo &&
if git merge master; then
echo needed conflict here
exit 1
else
echo merge failed - resolving automatically
fi &&
echo "New line ...
... and more
bla
Even more" > file2 &&
git rm file1 &&
git commit --author "M Result <mr@localhost>" -a -m merged &&
# Back to master and change file1 again
git checkout master &&
sed s/bla/foo/ <file1 >X &&
rm file1 &&
mv X file1 &&
git commit --author "No Bla <nb@localhost>" -a -m replace &&
# Try to merge into foo again
git checkout foo &&
if git merge master; then
echo needed conflict here
exit 1
else
echo merge failed - test is setup
fi
'
test_expect_success \
'blame runs on unconflicted file while other file has conflicts' '
git blame file2
'
test_expect_success 'blame runs on conflicted file in stages 1,3' '
git blame file1
'
test_done