Merge branch 'maint-1.5.4' into maint

* maint-1.5.4:
  bisect: fix bad rev checking in "git bisect good"
  revision.c: make --date-order overriddable
  Fix section about backdating tags in the git-tag docs
  Document option --only of git commit
  Documentation/git-request-pull: Fixed a typo ("send" -> "end")
This commit is contained in:
Junio C Hamano 2008-04-11 23:55:55 -07:00
commit eed81838f0
7 changed files with 34 additions and 13 deletions

View File

@ -139,6 +139,17 @@ but can be used to amend a merge commit.
as well. This is usually not what you want unless you as well. This is usually not what you want unless you
are concluding a conflicted merge. are concluding a conflicted merge.
-o|--only::
Make a commit only from the paths specified on the
command line, disregarding any contents that have been
staged so far. This is the default mode of operation of
'git commit' if any paths are given on the command line,
in which case this option can be omitted.
If this option is specified together with '--amend', then
no paths need be specified, which can be used to amend
the last commit without committing changes that have
already been staged.
-u|--untracked-files:: -u|--untracked-files::
Show all untracked files, also those in uninteresting Show all untracked files, also those in uninteresting
directories, in the "Untracked files:" section of commit directories, in the "Untracked files:" section of commit

View File

@ -24,7 +24,7 @@ OPTIONS
URL to include in the summary. URL to include in the summary.
<end>:: <end>::
Commit to send at; defaults to HEAD. Commit to end at; defaults to HEAD.
Author Author
------ ------

View File

@ -233,14 +233,14 @@ the tag object affects, for example, the ordering of tags in the
gitweb interface. gitweb interface.
To set the date used in future tag objects, set the environment To set the date used in future tag objects, set the environment
variable GIT_AUTHOR_DATE to one or more of the date and time. The variable GIT_COMMITTER_DATE to one or more of the date and time. The
date and time can be specified in a number of ways; the most common date and time can be specified in a number of ways; the most common
is "YYYY-MM-DD HH:MM". is "YYYY-MM-DD HH:MM".
An example follows. An example follows.
------------ ------------
$ GIT_AUTHOR_DATE="2006-10-02 10:31" git tag -s v1.0.1 $ GIT_COMMITTER_DATE="2006-10-02 10:31" git tag -s v1.0.1
------------ ------------

View File

@ -98,7 +98,7 @@ static struct option builtin_commit_options[] = {
OPT_BOOLEAN('a', "all", &all, "commit all changed files"), OPT_BOOLEAN('a', "all", &all, "commit all changed files"),
OPT_BOOLEAN('i', "include", &also, "add specified files to index for commit"), OPT_BOOLEAN('i', "include", &also, "add specified files to index for commit"),
OPT_BOOLEAN(0, "interactive", &interactive, "interactively add files"), OPT_BOOLEAN(0, "interactive", &interactive, "interactively add files"),
OPT_BOOLEAN('o', "only", &only, ""), OPT_BOOLEAN('o', "only", &only, "commit only specified files"),
OPT_BOOLEAN('n', "no-verify", &no_verify, "bypass pre-commit hook"), OPT_BOOLEAN('n', "no-verify", &no_verify, "bypass pre-commit hook"),
OPT_BOOLEAN(0, "amend", &amend, "amend previous commit"), OPT_BOOLEAN(0, "amend", &amend, "amend previous commit"),
OPT_BOOLEAN(0, "untracked-files", &untracked_files, "show all untracked files"), OPT_BOOLEAN(0, "untracked-files", &untracked_files, "show all untracked files"),

View File

@ -151,20 +151,16 @@ bisect_state() {
rev=$(git rev-parse --verify HEAD) || rev=$(git rev-parse --verify HEAD) ||
die "Bad rev input: HEAD" die "Bad rev input: HEAD"
bisect_write "$state" "$rev" ;; bisect_write "$state" "$rev" ;;
2,bad) 2,bad|*,good|*,skip)
rev=$(git rev-parse --verify "$2^{commit}") ||
die "Bad rev input: $2"
bisect_write "$state" "$rev" ;;
*,good|*,skip)
shift shift
revs=$(git rev-parse --revs-only --no-flags "$@") && for rev in "$@"
test '' != "$revs" || die "Bad rev input: $@"
for rev in $revs
do do
rev=$(git rev-parse --verify "$rev^{commit}") || rev=$(git rev-parse --verify "$rev^{commit}") ||
die "Bad rev commit: $rev^{commit}" die "Bad rev input: $rev"
bisect_write "$state" "$rev" bisect_write "$state" "$rev"
done ;; done ;;
*,bad)
die "'git bisect bad' can take only one argument." ;;
*) *)
usage ;; usage ;;
esac esac

View File

@ -1083,6 +1083,7 @@ int setup_revisions(int argc, const char **argv, struct rev_info *revs, const ch
continue; continue;
} }
if (!strcmp(arg, "--topo-order")) { if (!strcmp(arg, "--topo-order")) {
revs->lifo = 1;
revs->topo_order = 1; revs->topo_order = 1;
continue; continue;
} }

View File

@ -71,6 +71,19 @@ test_expect_success 'bisect start with one bad and good' '
git bisect next git bisect next
' '
test_expect_success 'bisect good and bad fails if not given only revs' '
git bisect reset &&
git bisect start &&
test_must_fail git bisect good foo $HASH1 &&
test_must_fail git bisect good $HASH1 bar &&
test_must_fail git bisect bad frotz &&
test_must_fail git bisect bad $HASH3 $HASH4 &&
test_must_fail git bisect skip bar $HASH3 &&
test_must_fail git bisect skip $HASH1 foo &&
git bisect good $HASH1 &&
git bisect bad $HASH4
'
test_expect_success 'bisect reset: back in the master branch' ' test_expect_success 'bisect reset: back in the master branch' '
git bisect reset && git bisect reset &&
echo "* master" > branch.expect && echo "* master" > branch.expect &&