trace2: document the supported values of GIT_TRACE2* env variables

The descriptions of the GIT_TRACE2* environment variables link to the
technical docs for further details on the supported values.  However,
a link like this only really works if the docs are viewed in a browser
and the full documentation is available.  OTOH, in 'man git' there are
no links to conveniently click on, and distro-shipped git packages
tend to include only the man pages, while the technical docs and the
docs in html format are in a separate 'git-doc' package.

So let's describe the supported values to make the manpage more
self-contained, but still keep the references to the technical docs
because the details of the SID, and the JSON and perf output formats
are definitely beyond the scope of 'man git'.

Signed-off-by: SZEDER Gábor <szeder.dev@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
SZEDER Gábor 2019-05-19 16:43:09 +02:00 committed by Junio C Hamano
parent e4b75d6a1d
commit 4e0d3aa18a

View File

@ -665,21 +665,48 @@ of clones and fetches.
Output from `GIT_TRACE2` is a simple text-based format for human Output from `GIT_TRACE2` is a simple text-based format for human
readability. readability.
+ +
The `GIT_TRACE2` variables can take many values. Any value available to If this variable is set to "1", "2" or "true" (comparison
the `GIT_TRACE` variables is also available to `GIT_TRACE2`. The `GIT_TRACE2` is case insensitive), trace messages will be printed to
variables can also specify a Unix Domain Socket. See stderr.
link:technical/api-trace2.html[Trace2 documentation] for full details. +
If the variable is set to an integer value greater than 2
and lower than 10 (strictly) then Git will interpret this
value as an open file descriptor and will try to write the
trace messages into this file descriptor.
+
Alternatively, if the variable is set to an absolute path
(starting with a '/' character), Git will interpret this
as a file path and will try to append the trace messages
to it. If the path already exists and is a directory, the
trace messages will be written to files (one per process)
in that directory, named according to the last component
of the SID and an optional counter (to avoid filename
collisions).
+
In addition, if the variable is set to
`af_unix:[<socket_type>:]<absolute-pathname>`, Git will try
to open the path as a Unix Domain Socket. The socket type
can be either `stream` or `dgram`.
+
Unsetting the variable, or setting it to empty, "0" or
"false" (case insensitive) disables trace messages.
+
See link:technical/api-trace2.html[Trace2 documentation]
for full details.
`GIT_TRACE2_EVENT`:: `GIT_TRACE2_EVENT`::
This setting writes a JSON-based format that is suited for machine This setting writes a JSON-based format that is suited for machine
interpretation. See link:technical/api-trace2.html[Trace2 documentation] interpretation.
for full details. See `GIT_TRACE2` for available trace output options and
link:technical/api-trace2.html[Trace2 documentation] for full details.
`GIT_TRACE2_PERF`:: `GIT_TRACE2_PERF`::
In addition to the text-based messages available in `GIT_TRACE2`, this In addition to the text-based messages available in `GIT_TRACE2`, this
setting writes a column-based format for understanding nesting setting writes a column-based format for understanding nesting
regions. See link:technical/api-trace2.html[Trace2 documentation] regions.
for full details. See `GIT_TRACE2` for available trace output options and
link:technical/api-trace2.html[Trace2 documentation] for full details.
`GIT_REDACT_COOKIES`:: `GIT_REDACT_COOKIES`::
This can be set to a comma-separated list of strings. When a curl trace This can be set to a comma-separated list of strings. When a curl trace