Max Horn writes:
>>
> On 06.07.2012, at 21:18, Junio C Hamano wrote:
>
>> Max Horn writes:
>>
> +'{caret}!', e.g. 'HEAD{caret}!'::
> + A suffix '{caret}' followed by an exclamation mark
> + means commit '' but forces all of its parents to be excluded. For
> + commands that deal with a single revision, this is the same as '".
Is this sentence correct? "git commit -C 'HEAD^!'" might be a
command that expects a single revision, but I do not think it is the
same as "git commit -C HEAD".
>>>
>>> Ignoring the exact words I used for the moment, what I meant is
>>> that these two commands should be functionally
>>> equivalent. Aren't they?
>>
>> No. When a single commit is wanted HEAD^! shouldn't be used, and
>> they cannot be functionally equivalent. I haven't tried but I think
>> "commit -C HEAD^!" would give you a syntax error.
>
> Indeed, it says
> fatal: could not lookup commit HEAD^!
>
> I'll iterate over this once more.
Let's do this instead.
-- >8 --
Subject: Enumerate revision range specifiers in the documentation
It was a bit hard to learn how ^@, ^! and various other
forms of range specification are used, because they were discussed
mostly in the prose part of the documentation, unlike various forms
of extended SHA-1 expressions that are listed in enumerated list.
Also add a few more examples showing use of , .. and
^! forms, stolen from a patch by Max Horn.
Signed-off-by: Junio C Hamano
---
Documentation/revisions.txt | 31 +++
1 file changed, 31 insertions(+)
diff --git a/Documentation/revisions.txt b/Documentation/revisions.txt
index f4f6f28..6506ec6 100644
--- a/Documentation/revisions.txt
+++ b/Documentation/revisions.txt
@@ -218,13 +218,44 @@ and its parent commits exist. The 'r1{caret}@' notation
means all
parents of 'r1'. 'r1{caret}!' includes commit 'r1' but excludes
all of its parents.
+To summarize:
+
+''::
+ Include commits that are reachable from (i.e. ancestors of)
+ .
+
+'{caret}'::
+ Exclude commits that are reachable from (i.e. ancestors of)
+ .
+
+'..'::
+ Include commits that are reachable from but exclude
+ those that are reachable from .
+
+'...'::
+ Include commits that are reachable from either or
+but exclude those that are reachable from both.
+
+'{caret}@', e.g. 'HEAD{caret}@'::
+ A suffix '{caret}' followed by an at sign is the same as listing
+ all parents of '' (meaning, include anything reachable from
+ its parents, but not the commit itself).
+
+'{caret}!', e.g. 'HEAD{caret}!'::
+ A suffix '{caret}' followed by an exclamation mark is the same
+ as giving commit '' and then all its parents prefixed with
+ '{caret}' to exclude them (and their ancestors).
+
Here are a handful of examples:
DG H D
D F G H I J D F
^G D H D
^D B E I J F B
+ B..C C
B...CG H D E B C
^D B C E I J F B C
+ CI J F C
C^@ I J F
+ C^! C
F^! DG H D F
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html