2005-08-15 02:24:36 +02:00
|
|
|
git-shortlog(1)
|
|
|
|
===============
|
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
2010-01-10 00:33:00 +01:00
|
|
|
git-shortlog - Summarize 'git log' output
|
2005-08-15 02:24:36 +02:00
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2007-04-19 00:10:22 +02:00
|
|
|
[verse]
|
2018-04-17 21:15:27 +02:00
|
|
|
'git shortlog' [<options>] [<revision range>] [[--] <path>...]
|
2018-03-10 12:52:10 +01:00
|
|
|
git log --pretty=short | 'git shortlog' [<options>]
|
2005-08-15 02:24:36 +02:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
2010-01-10 00:33:00 +01:00
|
|
|
Summarizes 'git log' output in a format suitable for inclusion
|
2012-09-14 00:27:09 +02:00
|
|
|
in release announcements. Each commit will be grouped by author and title.
|
2006-06-07 20:32:33 +02:00
|
|
|
|
|
|
|
Additionally, "[PATCH]" will be stripped from the commit description.
|
|
|
|
|
2010-05-04 04:57:10 +02:00
|
|
|
If no revisions are passed on the command line and either standard input
|
|
|
|
is not a terminal or there is no current branch, 'git shortlog' will
|
|
|
|
output a summary of the log read from standard input, without
|
|
|
|
reference to the current repository.
|
|
|
|
|
2006-10-06 21:39:09 +02:00
|
|
|
OPTIONS
|
|
|
|
-------
|
|
|
|
|
2008-06-08 03:36:09 +02:00
|
|
|
-n::
|
|
|
|
--numbered::
|
2006-10-06 21:39:09 +02:00
|
|
|
Sort output according to the number of commits per author instead
|
|
|
|
of author alphabetic order.
|
|
|
|
|
2008-06-08 03:36:09 +02:00
|
|
|
-s::
|
|
|
|
--summary::
|
2007-01-17 16:32:41 +01:00
|
|
|
Suppress commit description and provide a commit count summary only.
|
2006-10-06 21:39:09 +02:00
|
|
|
|
2008-06-08 03:36:09 +02:00
|
|
|
-e::
|
|
|
|
--email::
|
2007-12-11 13:33:12 +01:00
|
|
|
Show the email address of each author.
|
|
|
|
|
2010-10-08 19:31:18 +02:00
|
|
|
--format[=<format>]::
|
2010-05-04 04:59:55 +02:00
|
|
|
Instead of the commit subject, use some other information to
|
|
|
|
describe each commit. '<format>' can be any string accepted
|
docs: stop using asciidoc no-inline-literal
In asciidoc 7, backticks like `foo` produced a typographic
effect, but did not otherwise affect the syntax. In asciidoc
8, backticks introduce an "inline literal" inside which markup
is not interpreted. To keep compatibility with existing
documents, asciidoc 8 has a "no-inline-literal" attribute to
keep the old behavior. We enabled this so that the
documentation could be built on either version.
It has been several years now, and asciidoc 7 is no longer
in wide use. We can now decide whether or not we want
inline literals on their own merits, which are:
1. The source is much easier to read when the literal
contains punctuation. You can use `master~1` instead
of `master{tilde}1`.
2. They are less error-prone. Because of point (1), we
tend to make mistakes and forget the extra layer of
quoting.
This patch removes the no-inline-literal attribute from the
Makefile and converts every use of backticks in the
documentation to an inline literal (they must be cleaned up,
or the example above would literally show "{tilde}" in the
output).
Problematic sites were found by grepping for '`.*[{\\]' and
examined and fixed manually. The results were then verified
by comparing the output of "html2text" on the set of
generated html pages. Doing so revealed that in addition to
making the source more readable, this patch fixes several
formatting bugs:
- HTML rendering used the ellipsis character instead of
literal "..." in code examples (like "git log A...B")
- some code examples used the right-arrow character
instead of '->' because they failed to quote
- api-config.txt did not quote tilde, and the resulting
HTML contained a bogus snippet like:
<tt><sub></tt> foo <tt></sub>bar</tt>
which caused some parsers to choke and omit whole
sections of the page.
- git-commit.txt confused ``foo`` (backticks inside a
literal) with ``foo'' (matched double-quotes)
- mentions of `A U Thor <author@example.com>` used to
erroneously auto-generate a mailto footnote for
author@example.com
- the description of --word-diff=plain incorrectly showed
the output as "[-removed-] and {added}", not "{+added+}".
- using "prime" notation like:
commit `C` and its replacement `C'`
confused asciidoc into thinking that everything between
the first backtick and the final apostrophe were meant
to be inside matched quotes
- asciidoc got confused by the escaping of some of our
asterisks. In particular,
`credential.\*` and `credential.<url>.\*`
properly escaped the asterisk in the first case, but
literally passed through the backslash in the second
case.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2012-04-26 10:51:57 +02:00
|
|
|
by the `--format` option of 'git log', such as '* [%h] %s'.
|
2010-05-04 04:59:55 +02:00
|
|
|
(See the "PRETTY FORMATS" section of linkgit:git-log[1].)
|
|
|
|
|
|
|
|
Each pretty-printed commit will be rewrapped before it is shown.
|
|
|
|
|
2020-09-27 10:39:59 +02:00
|
|
|
--group=<type>::
|
|
|
|
Group commits based on `<type>`. If no `--group` option is
|
|
|
|
specified, the default is `author`. `<type>` is one of:
|
|
|
|
+
|
|
|
|
- `author`, commits are grouped by author
|
|
|
|
- `committer`, commits are grouped by committer (the same as `-c`)
|
2020-09-27 10:40:04 +02:00
|
|
|
- `trailer:<field>`, the `<field>` is interpreted as a case-insensitive
|
|
|
|
commit message trailer (see linkgit:git-interpret-trailers[1]). For
|
|
|
|
example, if your project uses `Reviewed-by` trailers, you might want
|
|
|
|
to see who has been reviewing with
|
|
|
|
`git shortlog -ns --group=trailer:reviewed-by`.
|
|
|
|
+
|
|
|
|
Note that commits that do not include the trailer will not be counted.
|
|
|
|
Likewise, commits with multiple trailers (e.g., multiple signoffs) may
|
2020-09-27 10:40:07 +02:00
|
|
|
be counted more than once (but only once per unique trailer value in
|
|
|
|
that commit).
|
2020-09-27 10:40:04 +02:00
|
|
|
+
|
|
|
|
The contents of each trailer value are taken literally and completely.
|
|
|
|
No mailmap is applied, and the `-e` option has no effect (if the trailer
|
|
|
|
contains a username and email, they are both always shown).
|
2020-09-27 10:39:59 +02:00
|
|
|
|
2016-12-16 14:51:41 +01:00
|
|
|
-c::
|
|
|
|
--committer::
|
2020-09-27 10:39:59 +02:00
|
|
|
This is an alias for `--group=committer`.
|
2016-12-16 14:51:41 +01:00
|
|
|
|
2008-04-13 00:38:20 +02:00
|
|
|
-w[<width>[,<indent1>[,<indent2>]]]::
|
|
|
|
Linewrap the output by wrapping each line at `width`. The first
|
|
|
|
line of each entry is indented by `indent1` spaces, and the second
|
|
|
|
and subsequent lines are indented by `indent2` spaces. `width`,
|
|
|
|
`indent1`, and `indent2` default to 76, 6 and 9 respectively.
|
2013-01-09 21:16:45 +01:00
|
|
|
+
|
|
|
|
If width is `0` (zero) then indent the lines of the output without wrapping
|
|
|
|
them.
|
2008-04-13 00:38:20 +02:00
|
|
|
|
2013-04-22 07:30:30 +02:00
|
|
|
<revision range>::
|
|
|
|
Show only commits in the specified revision range. When no
|
|
|
|
<revision range> is specified, it defaults to `HEAD` (i.e. the
|
|
|
|
whole history leading to the current commit). `origin..HEAD`
|
|
|
|
specifies all the commits reachable from the current commit
|
|
|
|
(i.e. `HEAD`), but not from `origin`. For a complete list of
|
|
|
|
ways to spell <revision range>, see the "Specifying Ranges"
|
|
|
|
section of linkgit:gitrevisions[7].
|
|
|
|
|
2018-04-17 21:15:27 +02:00
|
|
|
[--] <path>...::
|
2013-04-22 07:30:30 +02:00
|
|
|
Consider only commits that are enough to explain how the files
|
|
|
|
that match the specified paths came to be.
|
|
|
|
+
|
git-[short]log.txt: unify quoted standalone --
In git-log.txt, we have an instance of \--, which is known to sometimes
render badly. This one is even worse than normal though, since ``\-- ''
(with or without that trailing space) appears to be entirely broken,
both in HTML and manpages, both with AsciiDoc (version 8.6.9) and
Asciidoctor (version 1.5.4).
Further down in git-log.txt we have a ``--'', which renders good. In
git-shortlog.txt, we use "\-- " (including the quotes and the space),
which happens to look fairly good. I failed to find any other similar
instances. So all in all, we quote a double-dash in three different
places and do it differently each time, with various degrees of success.
Switch all of these to `--`. This sets the double-dash in monospace and
matches what we usually do with example command line usages and options.
Note that we drop the trailing space as well, since `-- ` does not
render well. These should still be clear enough since just a few lines
above each instance, the space is clearly visible in a longer context.
Signed-off-by: Martin Ågren <martin.agren@gmail.com>
2018-04-17 21:15:28 +02:00
|
|
|
Paths may need to be prefixed with `--` to separate them from
|
2013-04-22 07:30:30 +02:00
|
|
|
options or the revision range, when confusion arises.
|
2009-02-08 15:34:31 +01:00
|
|
|
|
2019-11-08 20:26:27 +01:00
|
|
|
:git-shortlog: 1
|
|
|
|
include::rev-list-options.txt[]
|
|
|
|
|
2009-02-08 15:34:31 +01:00
|
|
|
MAPPING AUTHORS
|
|
|
|
---------------
|
|
|
|
|
|
|
|
The `.mailmap` feature is used to coalesce together commits by the same
|
|
|
|
person in the shortlog, where their name and/or email address was
|
|
|
|
spelled differently.
|
|
|
|
|
|
|
|
include::mailmap.txt[]
|
2009-02-08 15:34:29 +01:00
|
|
|
|
2005-08-15 02:24:36 +02:00
|
|
|
GIT
|
|
|
|
---
|
2008-06-06 09:07:32 +02:00
|
|
|
Part of the linkgit:git[1] suite
|