diff options
author | Jeff King <peff@peff.net> | 2015-06-16 13:23:20 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-06-16 13:24:22 -0700 |
commit | 323598387d900263c4980b43b8a96c43cdd7b6c7 (patch) | |
tree | 3d52379c0cabf02e52a05586ab9c2baa6e3a68f7 /trace.h | |
parent | d6d1a75e51cf90650ac6e2cdcd8d108324b6fdb9 (diff) | |
download | git-323598387d900263c4980b43b8a96c43cdd7b6c7.tar.gz |
pkt-line: support tracing verbatim pack contentsjk/pkt-log-pack
When debugging the pack protocol, it is sometimes useful to
store the verbatim pack that we sent or received on the
wire. Looking at the on-disk result is often not helpful for
a few reasons:
1. If the operation is a clone, we destroy the repo on
failure, leaving nothing on disk.
2. If the pack is small, we unpack it immediately, and the
full pack never hits the disk.
3. If we feed the pack to "index-pack --fix-thin", the
resulting pack has the extra delta bases added to it.
We already have a GIT_TRACE_PACKET mechanism for tracing
packets. Let's extend it with GIT_TRACE_PACKFILE to dump the
verbatim packfile.
There are a few other positive fallouts that come from
rearranging this code:
- We currently disable the packet trace after seeing the
PACK header, even though we may get human-readable lines
on other sidebands; now we include them in the trace.
- We currently try to print "PACK ..." in the trace to
indicate that the packfile has started. But because we
disable packet tracing, we never printed this line. We
will now do so.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'trace.h')
-rw-r--r-- | trace.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -18,6 +18,7 @@ extern int trace_want(struct trace_key *key); extern void trace_disable(struct trace_key *key); extern uint64_t getnanotime(void); extern void trace_command_performance(const char **argv); +extern void trace_verbatim(struct trace_key *key, const void *buf, unsigned len); #ifndef HAVE_VARIADIC_MACROS |