blob: 311969285652dab5f54fabf116157c3b165e13f8 [file] [log] [blame]
Junio C Hamano944ce252018-05-30 22:25:261<?xml version="1.0" encoding="UTF-8"?>
Junio C Hamanodbe51052014-07-22 19:39:512<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
3 "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
4<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
5<head>
6<meta http-equiv="Content-Type" content="application/xhtml+xml; charset=UTF-8" />
Junio C Hamano944ce252018-05-30 22:25:267<meta name="generator" content="AsciiDoc 8.6.10" />
Junio C Hamanodbe51052014-07-22 19:39:518<title>trace API</title>
9<style type="text/css">
10/* Shared CSS for AsciiDoc xhtml11 and html5 backends */
11
12/* Default font. */
13body {
14 font-family: Georgia,serif;
15}
16
17/* Title font. */
18h1, h2, h3, h4, h5, h6,
19div.title, caption.title,
20thead, p.table.header,
21#toctitle,
22#author, #revnumber, #revdate, #revremark,
23#footer {
24 font-family: Arial,Helvetica,sans-serif;
25}
26
27body {
28 margin: 1em 5% 1em 5%;
29}
30
31a {
32 color: blue;
33 text-decoration: underline;
34}
35a:visited {
36 color: fuchsia;
37}
38
39em {
40 font-style: italic;
41 color: navy;
42}
43
44strong {
45 font-weight: bold;
46 color: #083194;
47}
48
49h1, h2, h3, h4, h5, h6 {
50 color: #527bbd;
51 margin-top: 1.2em;
52 margin-bottom: 0.5em;
53 line-height: 1.3;
54}
55
56h1, h2, h3 {
57 border-bottom: 2px solid silver;
58}
59h2 {
60 padding-top: 0.5em;
61}
62h3 {
63 float: left;
64}
65h3 + * {
66 clear: left;
67}
68h5 {
69 font-size: 1.0em;
70}
71
72div.sectionbody {
73 margin-left: 0;
74}
75
76hr {
77 border: 1px solid silver;
78}
79
80p {
81 margin-top: 0.5em;
82 margin-bottom: 0.5em;
83}
84
85ul, ol, li > p {
86 margin-top: 0;
87}
88ul > li { color: #aaa; }
89ul > li > * { color: black; }
90
Junio C Hamanoc14e6ad2014-10-31 20:25:5391.monospaced, code, pre {
92 font-family: "Courier New", Courier, monospace;
93 font-size: inherit;
94 color: navy;
Junio C Hamanodbe51052014-07-22 19:39:5195 padding: 0;
96 margin: 0;
97}
Junio C Hamanoc14e6ad2014-10-31 20:25:5398pre {
99 white-space: pre-wrap;
100}
Junio C Hamanodbe51052014-07-22 19:39:51101
102#author {
103 color: #527bbd;
104 font-weight: bold;
105 font-size: 1.1em;
106}
107#email {
108}
109#revnumber, #revdate, #revremark {
110}
111
112#footer {
113 font-size: small;
114 border-top: 2px solid silver;
115 padding-top: 0.5em;
116 margin-top: 4.0em;
117}
118#footer-text {
119 float: left;
120 padding-bottom: 0.5em;
121}
122#footer-badges {
123 float: right;
124 padding-bottom: 0.5em;
125}
126
127#preamble {
128 margin-top: 1.5em;
129 margin-bottom: 1.5em;
130}
131div.imageblock, div.exampleblock, div.verseblock,
132div.quoteblock, div.literalblock, div.listingblock, div.sidebarblock,
133div.admonitionblock {
134 margin-top: 1.0em;
135 margin-bottom: 1.5em;
136}
137div.admonitionblock {
138 margin-top: 2.0em;
139 margin-bottom: 2.0em;
140 margin-right: 10%;
141 color: #606060;
142}
143
144div.content { /* Block element content. */
145 padding: 0;
146}
147
148/* Block element titles. */
149div.title, caption.title {
150 color: #527bbd;
151 font-weight: bold;
152 text-align: left;
153 margin-top: 1.0em;
154 margin-bottom: 0.5em;
155}
156div.title + * {
157 margin-top: 0;
158}
159
160td div.title:first-child {
161 margin-top: 0.0em;
162}
163div.content div.title:first-child {
164 margin-top: 0.0em;
165}
166div.content + div.title {
167 margin-top: 0.0em;
168}
169
170div.sidebarblock > div.content {
171 background: #ffffee;
172 border: 1px solid #dddddd;
173 border-left: 4px solid #f0f0f0;
174 padding: 0.5em;
175}
176
177div.listingblock > div.content {
178 border: 1px solid #dddddd;
179 border-left: 5px solid #f0f0f0;
180 background: #f8f8f8;
181 padding: 0.5em;
182}
183
184div.quoteblock, div.verseblock {
185 padding-left: 1.0em;
186 margin-left: 1.0em;
187 margin-right: 10%;
188 border-left: 5px solid #f0f0f0;
189 color: #888;
190}
191
192div.quoteblock > div.attribution {
193 padding-top: 0.5em;
194 text-align: right;
195}
196
197div.verseblock > pre.content {
198 font-family: inherit;
199 font-size: inherit;
200}
201div.verseblock > div.attribution {
202 padding-top: 0.75em;
203 text-align: left;
204}
205/* DEPRECATED: Pre version 8.2.7 verse style literal block. */
206div.verseblock + div.attribution {
207 text-align: left;
208}
209
210div.admonitionblock .icon {
211 vertical-align: top;
212 font-size: 1.1em;
213 font-weight: bold;
214 text-decoration: underline;
215 color: #527bbd;
216 padding-right: 0.5em;
217}
218div.admonitionblock td.content {
219 padding-left: 0.5em;
220 border-left: 3px solid #dddddd;
221}
222
223div.exampleblock > div.content {
224 border-left: 3px solid #dddddd;
225 padding-left: 0.5em;
226}
227
228div.imageblock div.content { padding-left: 0; }
Junio C Hamanoc14e6ad2014-10-31 20:25:53229span.image img { border-style: none; vertical-align: text-bottom; }
Junio C Hamanodbe51052014-07-22 19:39:51230a.image:visited { color: white; }
231
232dl {
233 margin-top: 0.8em;
234 margin-bottom: 0.8em;
235}
236dt {
237 margin-top: 0.5em;
238 margin-bottom: 0;
239 font-style: normal;
240 color: navy;
241}
242dd > *:first-child {
243 margin-top: 0.1em;
244}
245
246ul, ol {
247 list-style-position: outside;
248}
249ol.arabic {
250 list-style-type: decimal;
251}
252ol.loweralpha {
253 list-style-type: lower-alpha;
254}
255ol.upperalpha {
256 list-style-type: upper-alpha;
257}
258ol.lowerroman {
259 list-style-type: lower-roman;
260}
261ol.upperroman {
262 list-style-type: upper-roman;
263}
264
265div.compact ul, div.compact ol,
266div.compact p, div.compact p,
267div.compact div, div.compact div {
268 margin-top: 0.1em;
269 margin-bottom: 0.1em;
270}
271
272tfoot {
273 font-weight: bold;
274}
275td > div.verse {
276 white-space: pre;
277}
278
279div.hdlist {
280 margin-top: 0.8em;
281 margin-bottom: 0.8em;
282}
283div.hdlist tr {
284 padding-bottom: 15px;
285}
286dt.hdlist1.strong, td.hdlist1.strong {
287 font-weight: bold;
288}
289td.hdlist1 {
290 vertical-align: top;
291 font-style: normal;
292 padding-right: 0.8em;
293 color: navy;
294}
295td.hdlist2 {
296 vertical-align: top;
297}
298div.hdlist.compact tr {
299 margin: 0;
300 padding-bottom: 0;
301}
302
303.comment {
304 background: yellow;
305}
306
307.footnote, .footnoteref {
308 font-size: 0.8em;
309}
310
311span.footnote, span.footnoteref {
312 vertical-align: super;
313}
314
315#footnotes {
316 margin: 20px 0 20px 0;
317 padding: 7px 0 0 0;
318}
319
320#footnotes div.footnote {
321 margin: 0 0 5px 0;
322}
323
324#footnotes hr {
325 border: none;
326 border-top: 1px solid silver;
327 height: 1px;
328 text-align: left;
329 margin-left: 0;
330 width: 20%;
331 min-width: 100px;
332}
333
334div.colist td {
335 padding-right: 0.5em;
336 padding-bottom: 0.3em;
337 vertical-align: top;
338}
339div.colist td img {
340 margin-top: 0.3em;
341}
342
343@media print {
344 #footer-badges { display: none; }
345}
346
347#toc {
348 margin-bottom: 2.5em;
349}
350
351#toctitle {
352 color: #527bbd;
353 font-size: 1.1em;
354 font-weight: bold;
355 margin-top: 1.0em;
356 margin-bottom: 0.1em;
357}
358
Junio C Hamanoc14e6ad2014-10-31 20:25:53359div.toclevel0, div.toclevel1, div.toclevel2, div.toclevel3, div.toclevel4 {
Junio C Hamanodbe51052014-07-22 19:39:51360 margin-top: 0;
361 margin-bottom: 0;
362}
363div.toclevel2 {
364 margin-left: 2em;
365 font-size: 0.9em;
366}
367div.toclevel3 {
368 margin-left: 4em;
369 font-size: 0.9em;
370}
371div.toclevel4 {
372 margin-left: 6em;
373 font-size: 0.9em;
374}
375
376span.aqua { color: aqua; }
377span.black { color: black; }
378span.blue { color: blue; }
379span.fuchsia { color: fuchsia; }
380span.gray { color: gray; }
381span.green { color: green; }
382span.lime { color: lime; }
383span.maroon { color: maroon; }
384span.navy { color: navy; }
385span.olive { color: olive; }
386span.purple { color: purple; }
387span.red { color: red; }
388span.silver { color: silver; }
389span.teal { color: teal; }
390span.white { color: white; }
391span.yellow { color: yellow; }
392
393span.aqua-background { background: aqua; }
394span.black-background { background: black; }
395span.blue-background { background: blue; }
396span.fuchsia-background { background: fuchsia; }
397span.gray-background { background: gray; }
398span.green-background { background: green; }
399span.lime-background { background: lime; }
400span.maroon-background { background: maroon; }
401span.navy-background { background: navy; }
402span.olive-background { background: olive; }
403span.purple-background { background: purple; }
404span.red-background { background: red; }
405span.silver-background { background: silver; }
406span.teal-background { background: teal; }
407span.white-background { background: white; }
408span.yellow-background { background: yellow; }
409
410span.big { font-size: 2em; }
411span.small { font-size: 0.6em; }
412
413span.underline { text-decoration: underline; }
414span.overline { text-decoration: overline; }
415span.line-through { text-decoration: line-through; }
416
Junio C Hamanoc14e6ad2014-10-31 20:25:53417div.unbreakable { page-break-inside: avoid; }
418
Junio C Hamanodbe51052014-07-22 19:39:51419
420/*
421 * xhtml11 specific
422 *
423 * */
424
Junio C Hamanodbe51052014-07-22 19:39:51425div.tableblock {
426 margin-top: 1.0em;
427 margin-bottom: 1.5em;
428}
429div.tableblock > table {
430 border: 3px solid #527bbd;
431}
432thead, p.table.header {
433 font-weight: bold;
434 color: #527bbd;
435}
436p.table {
437 margin-top: 0;
438}
439/* Because the table frame attribute is overriden by CSS in most browsers. */
440div.tableblock > table[frame="void"] {
441 border-style: none;
442}
443div.tableblock > table[frame="hsides"] {
444 border-left-style: none;
445 border-right-style: none;
446}
447div.tableblock > table[frame="vsides"] {
448 border-top-style: none;
449 border-bottom-style: none;
450}
451
452
453/*
454 * html5 specific
455 *
456 * */
457
Junio C Hamanodbe51052014-07-22 19:39:51458table.tableblock {
459 margin-top: 1.0em;
460 margin-bottom: 1.5em;
461}
462thead, p.tableblock.header {
463 font-weight: bold;
464 color: #527bbd;
465}
466p.tableblock {
467 margin-top: 0;
468}
469table.tableblock {
470 border-width: 3px;
471 border-spacing: 0px;
472 border-style: solid;
473 border-color: #527bbd;
474 border-collapse: collapse;
475}
476th.tableblock, td.tableblock {
477 border-width: 1px;
478 padding: 4px;
479 border-style: solid;
480 border-color: #527bbd;
481}
482
483table.tableblock.frame-topbot {
484 border-left-style: hidden;
485 border-right-style: hidden;
486}
487table.tableblock.frame-sides {
488 border-top-style: hidden;
489 border-bottom-style: hidden;
490}
491table.tableblock.frame-none {
492 border-style: hidden;
493}
494
495th.tableblock.halign-left, td.tableblock.halign-left {
496 text-align: left;
497}
498th.tableblock.halign-center, td.tableblock.halign-center {
499 text-align: center;
500}
501th.tableblock.halign-right, td.tableblock.halign-right {
502 text-align: right;
503}
504
505th.tableblock.valign-top, td.tableblock.valign-top {
506 vertical-align: top;
507}
508th.tableblock.valign-middle, td.tableblock.valign-middle {
509 vertical-align: middle;
510}
511th.tableblock.valign-bottom, td.tableblock.valign-bottom {
512 vertical-align: bottom;
513}
514
515
516/*
517 * manpage specific
518 *
519 * */
520
521body.manpage h1 {
522 padding-top: 0.5em;
523 padding-bottom: 0.5em;
524 border-top: 2px solid silver;
525 border-bottom: 2px solid silver;
526}
527body.manpage h2 {
528 border-style: none;
529}
530body.manpage div.sectionbody {
531 margin-left: 3em;
532}
533
534@media print {
535 body.manpage div#toc { display: none; }
536}
Junio C Hamanoc14e6ad2014-10-31 20:25:53537
538
Junio C Hamanodbe51052014-07-22 19:39:51539</style>
540<script type="text/javascript">
541/*<![CDATA[*/
542var asciidoc = { // Namespace.
543
544/////////////////////////////////////////////////////////////////////
545// Table Of Contents generator
546/////////////////////////////////////////////////////////////////////
547
548/* Author: Mihai Bazon, September 2002
549 * http://students.infoiasi.ro/~mishoo
550 *
551 * Table Of Content generator
552 * Version: 0.4
553 *
554 * Feel free to use this script under the terms of the GNU General Public
555 * License, as long as you do not remove or alter this notice.
556 */
557
558 /* modified by Troy D. Hanson, September 2006. License: GPL */
559 /* modified by Stuart Rackham, 2006, 2009. License: GPL */
560
561// toclevels = 1..4.
562toc: function (toclevels) {
563
564 function getText(el) {
565 var text = "";
566 for (var i = el.firstChild; i != null; i = i.nextSibling) {
567 if (i.nodeType == 3 /* Node.TEXT_NODE */) // IE doesn't speak constants.
568 text += i.data;
569 else if (i.firstChild != null)
570 text += getText(i);
571 }
572 return text;
573 }
574
575 function TocEntry(el, text, toclevel) {
576 this.element = el;
577 this.text = text;
578 this.toclevel = toclevel;
579 }
580
581 function tocEntries(el, toclevels) {
582 var result = new Array;
Junio C Hamanoc14e6ad2014-10-31 20:25:53583 var re = new RegExp('[hH]([1-'+(toclevels+1)+'])');
Junio C Hamanodbe51052014-07-22 19:39:51584 // Function that scans the DOM tree for header elements (the DOM2
585 // nodeIterator API would be a better technique but not supported by all
586 // browsers).
587 var iterate = function (el) {
588 for (var i = el.firstChild; i != null; i = i.nextSibling) {
589 if (i.nodeType == 1 /* Node.ELEMENT_NODE */) {
590 var mo = re.exec(i.tagName);
591 if (mo && (i.getAttribute("class") || i.getAttribute("className")) != "float") {
592 result[result.length] = new TocEntry(i, getText(i), mo[1]-1);
593 }
594 iterate(i);
595 }
596 }
597 }
598 iterate(el);
599 return result;
600 }
601
602 var toc = document.getElementById("toc");
603 if (!toc) {
604 return;
605 }
606
607 // Delete existing TOC entries in case we're reloading the TOC.
608 var tocEntriesToRemove = [];
609 var i;
610 for (i = 0; i < toc.childNodes.length; i++) {
611 var entry = toc.childNodes[i];
Junio C Hamanoc14e6ad2014-10-31 20:25:53612 if (entry.nodeName.toLowerCase() == 'div'
Junio C Hamanodbe51052014-07-22 19:39:51613 && entry.getAttribute("class")
614 && entry.getAttribute("class").match(/^toclevel/))
615 tocEntriesToRemove.push(entry);
616 }
617 for (i = 0; i < tocEntriesToRemove.length; i++) {
618 toc.removeChild(tocEntriesToRemove[i]);
619 }
620
621 // Rebuild TOC entries.
622 var entries = tocEntries(document.getElementById("content"), toclevels);
623 for (var i = 0; i < entries.length; ++i) {
624 var entry = entries[i];
625 if (entry.element.id == "")
626 entry.element.id = "_toc_" + i;
627 var a = document.createElement("a");
628 a.href = "#" + entry.element.id;
629 a.appendChild(document.createTextNode(entry.text));
630 var div = document.createElement("div");
631 div.appendChild(a);
632 div.className = "toclevel" + entry.toclevel;
633 toc.appendChild(div);
634 }
635 if (entries.length == 0)
636 toc.parentNode.removeChild(toc);
637},
638
639
640/////////////////////////////////////////////////////////////////////
641// Footnotes generator
642/////////////////////////////////////////////////////////////////////
643
644/* Based on footnote generation code from:
645 * http://www.brandspankingnew.net/archive/2005/07/format_footnote.html
646 */
647
648footnotes: function () {
649 // Delete existing footnote entries in case we're reloading the footnodes.
650 var i;
651 var noteholder = document.getElementById("footnotes");
652 if (!noteholder) {
653 return;
654 }
655 var entriesToRemove = [];
656 for (i = 0; i < noteholder.childNodes.length; i++) {
657 var entry = noteholder.childNodes[i];
Junio C Hamanoc14e6ad2014-10-31 20:25:53658 if (entry.nodeName.toLowerCase() == 'div' && entry.getAttribute("class") == "footnote")
Junio C Hamanodbe51052014-07-22 19:39:51659 entriesToRemove.push(entry);
660 }
661 for (i = 0; i < entriesToRemove.length; i++) {
662 noteholder.removeChild(entriesToRemove[i]);
663 }
664
665 // Rebuild footnote entries.
666 var cont = document.getElementById("content");
667 var spans = cont.getElementsByTagName("span");
668 var refs = {};
669 var n = 0;
670 for (i=0; i<spans.length; i++) {
671 if (spans[i].className == "footnote") {
672 n++;
673 var note = spans[i].getAttribute("data-note");
674 if (!note) {
675 // Use [\s\S] in place of . so multi-line matches work.
676 // Because JavaScript has no s (dotall) regex flag.
677 note = spans[i].innerHTML.match(/\s*\[([\s\S]*)]\s*/)[1];
678 spans[i].innerHTML =
679 "[<a id='_footnoteref_" + n + "' href='#_footnote_" + n +
680 "' title='View footnote' class='footnote'>" + n + "</a>]";
681 spans[i].setAttribute("data-note", note);
682 }
683 noteholder.innerHTML +=
684 "<div class='footnote' id='_footnote_" + n + "'>" +
685 "<a href='#_footnoteref_" + n + "' title='Return to text'>" +
686 n + "</a>. " + note + "</div>";
687 var id =spans[i].getAttribute("id");
688 if (id != null) refs["#"+id] = n;
689 }
690 }
691 if (n == 0)
692 noteholder.parentNode.removeChild(noteholder);
693 else {
694 // Process footnoterefs.
695 for (i=0; i<spans.length; i++) {
696 if (spans[i].className == "footnoteref") {
697 var href = spans[i].getElementsByTagName("a")[0].getAttribute("href");
698 href = href.match(/#.*/)[0]; // Because IE return full URL.
699 n = refs[href];
700 spans[i].innerHTML =
701 "[<a href='#_footnote_" + n +
702 "' title='View footnote' class='footnote'>" + n + "</a>]";
703 }
704 }
705 }
706},
707
708install: function(toclevels) {
709 var timerId;
710
711 function reinstall() {
712 asciidoc.footnotes();
713 if (toclevels) {
714 asciidoc.toc(toclevels);
715 }
716 }
717
718 function reinstallAndRemoveTimer() {
719 clearInterval(timerId);
720 reinstall();
721 }
722
723 timerId = setInterval(reinstall, 500);
724 if (document.addEventListener)
725 document.addEventListener("DOMContentLoaded", reinstallAndRemoveTimer, false);
726 else
727 window.onload = reinstallAndRemoveTimer;
728}
729
730}
731asciidoc.install();
732/*]]>*/
733</script>
734</head>
735<body class="article">
736<div id="header">
737<h1>trace API</h1>
738</div>
739<div id="content">
740<div id="preamble">
741<div class="sectionbody">
742<div class="paragraph"><p>The trace API can be used to print debug messages to stderr or a file. Trace
Junio C Hamanoc14e6ad2014-10-31 20:25:53743code is inactive unless explicitly enabled by setting <code>GIT_TRACE*</code> environment
Junio C Hamanodbe51052014-07-22 19:39:51744variables.</p></div>
Junio C Hamanoc14e6ad2014-10-31 20:25:53745<div class="paragraph"><p>The trace implementation automatically adds <code>timestamp file:line ... \n</code> to
Junio C Hamanodbe51052014-07-22 19:39:51746all trace messages. E.g.:</p></div>
747<div class="listingblock">
748<div class="content">
Junio C Hamanoc14e6ad2014-10-31 20:25:53749<pre><code>23:59:59.123456 git.c:312 trace: built-in: git 'foo'
75000:00:00.000001 builtin/foo.c:99 foo: some message</code></pre>
Junio C Hamanodbe51052014-07-22 19:39:51751</div></div>
752</div>
753</div>
754<div class="sect1">
755<h2 id="_data_structures">Data Structures</h2>
756<div class="sectionbody">
757<div class="dlist"><dl>
758<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53759<code>struct trace_key</code>
Junio C Hamanodbe51052014-07-22 19:39:51760</dt>
761<dd>
762<p>
763 Defines a trace key (or category). The default (for API functions that
Junio C Hamanoc14e6ad2014-10-31 20:25:53764 don&#8217;t take a key) is <code>GIT_TRACE</code>.
Junio C Hamanodbe51052014-07-22 19:39:51765</p>
Junio C Hamanoc14e6ad2014-10-31 20:25:53766<div class="paragraph"><p>E.g. to define a trace key controlled by environment variable <code>GIT_TRACE_FOO</code>:</p></div>
Junio C Hamanodbe51052014-07-22 19:39:51767<div class="listingblock">
768<div class="content">
Junio C Hamanoc14e6ad2014-10-31 20:25:53769<pre><code>static struct trace_key trace_foo = TRACE_KEY_INIT(FOO);
Junio C Hamanodbe51052014-07-22 19:39:51770
771static void trace_print_foo(const char *message)
772{
Junio C Hamano5996b672016-04-13 22:01:41773 trace_printf_key(&amp;trace_foo, "%s", message);
Junio C Hamanoc14e6ad2014-10-31 20:25:53774}</code></pre>
Junio C Hamanodbe51052014-07-22 19:39:51775</div></div>
Junio C Hamanoc14e6ad2014-10-31 20:25:53776<div class="paragraph"><p>Note: don&#8217;t use <code>const</code> as the trace implementation stores internal state in
777the <code>trace_key</code> structure.</p></div>
Junio C Hamanodbe51052014-07-22 19:39:51778</dd>
779</dl></div>
780</div>
781</div>
782<div class="sect1">
783<h2 id="_functions">Functions</h2>
784<div class="sectionbody">
785<div class="dlist"><dl>
786<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53787<code>int trace_want(struct trace_key *key)</code>
Junio C Hamanodbe51052014-07-22 19:39:51788</dt>
789<dd>
790<p>
791 Checks whether the trace key is enabled. Used to prevent expensive
792 string formatting before calling one of the printing APIs.
793</p>
794</dd>
795<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53796<code>void trace_disable(struct trace_key *key)</code>
Junio C Hamanodbe51052014-07-22 19:39:51797</dt>
798<dd>
799<p>
800 Disables tracing for the specified key, even if the environment
801 variable was set.
802</p>
803</dd>
804<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53805<code>void trace_printf(const char *format, ...)</code>
Junio C Hamanodbe51052014-07-22 19:39:51806</dt>
807<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53808<code>void trace_printf_key(struct trace_key *key, const char *format, ...)</code>
Junio C Hamanodbe51052014-07-22 19:39:51809</dt>
810<dd>
811<p>
812 Prints a formatted message, similar to printf.
813</p>
814</dd>
815<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53816<code>void trace_argv_printf(const char **argv, const char *format, ...)`</code>
Junio C Hamanodbe51052014-07-22 19:39:51817</dt>
818<dd>
819<p>
820 Prints a formatted message, followed by a quoted list of arguments.
821</p>
822</dd>
823<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53824<code>void trace_strbuf(struct trace_key *key, const struct strbuf *data)</code>
Junio C Hamanodbe51052014-07-22 19:39:51825</dt>
826<dd>
827<p>
828 Prints the strbuf, without additional formatting (i.e. doesn&#8217;t
Junio C Hamanoc14e6ad2014-10-31 20:25:53829 choke on <code>%</code> or even <code>\0</code>).
Junio C Hamanodbe51052014-07-22 19:39:51830</p>
831</dd>
832<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53833<code>uint64_t getnanotime(void)</code>
Junio C Hamanodbe51052014-07-22 19:39:51834</dt>
835<dd>
836<p>
837 Returns nanoseconds since the epoch (01/01/1970), typically used
838 for performance measurements.
839</p>
840<div class="paragraph"><p>Currently there are high precision timer implementations for Linux (using
Junio C Hamanoc14e6ad2014-10-31 20:25:53841<code>clock_gettime(CLOCK_MONOTONIC)</code>) and Windows (<code>QueryPerformanceCounter</code>).
842Other platforms use <code>gettimeofday</code> as time source.</p></div>
Junio C Hamanodbe51052014-07-22 19:39:51843</dd>
844<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53845<code>void trace_performance(uint64_t nanos, const char *format, ...)</code>
Junio C Hamanodbe51052014-07-22 19:39:51846</dt>
847<dt class="hdlist1">
Junio C Hamanoc14e6ad2014-10-31 20:25:53848<code>void trace_performance_since(uint64_t start, const char *format, ...)</code>
Junio C Hamanodbe51052014-07-22 19:39:51849</dt>
850<dd>
851<p>
852 Prints the elapsed time (in nanoseconds), or elapsed time since
Junio C Hamanoc14e6ad2014-10-31 20:25:53853 <code>start</code>, followed by a formatted message. Enabled via environment
854 variable <code>GIT_TRACE_PERFORMANCE</code>. Used for manual profiling, e.g.:
Junio C Hamanodbe51052014-07-22 19:39:51855</p>
856<div class="listingblock">
857<div class="content">
Junio C Hamanoc14e6ad2014-10-31 20:25:53858<pre><code>uint64_t start = getnanotime();
Junio C Hamanodbe51052014-07-22 19:39:51859/* code section to measure */
Junio C Hamanoc14e6ad2014-10-31 20:25:53860trace_performance_since(start, "foobar");</code></pre>
Junio C Hamanodbe51052014-07-22 19:39:51861</div></div>
862<div class="listingblock">
863<div class="content">
Junio C Hamanoc14e6ad2014-10-31 20:25:53864<pre><code>uint64_t t = 0;
Junio C Hamanodbe51052014-07-22 19:39:51865for (;;) {
866 /* ignore */
867 t -= getnanotime();
868 /* code section to measure */
869 t += getnanotime();
870 /* ignore */
871}
Junio C Hamanoc14e6ad2014-10-31 20:25:53872trace_performance(t, "frotz");</code></pre>
Junio C Hamanodbe51052014-07-22 19:39:51873</div></div>
874</dd>
875</dl></div>
876</div>
877</div>
Junio C Hamanobec5da42016-04-06 22:58:21878<div class="sect1">
879<h2 id="_bugs_amp_caveats">Bugs &amp; Caveats</h2>
880<div class="sectionbody">
881<div class="paragraph"><p>GIT_TRACE_* environment variables can be used to tell Git to show
882trace output to its standard error stream. Git can often spawn a pager
883internally to run its subcommand and send its standard output and
884standard error to it.</p></div>
885<div class="paragraph"><p>Because GIT_TRACE_PERFORMANCE trace is generated only at the very end
886of the program with atexit(), which happens after the pager exits, it
887would not work well if you send its log to the standard error output
888and let Git spawn the pager at the same time.</p></div>
889<div class="paragraph"><p>As a work around, you can for example use <em>--no-pager</em>, or set
890GIT_TRACE_PERFORMANCE to another file descriptor which is redirected
891to stderr, or set GIT_TRACE_PERFORMANCE to a file specified by its
892absolute path.</p></div>
893<div class="paragraph"><p>For example instead of the following command which by default may not
894print any performance information:</p></div>
895<div class="listingblock">
896<div class="content">
897<pre><code>GIT_TRACE_PERFORMANCE=2 git log -1</code></pre>
898</div></div>
899<div class="paragraph"><p>you may want to use:</p></div>
900<div class="listingblock">
901<div class="content">
902<pre><code>GIT_TRACE_PERFORMANCE=2 git --no-pager log -1</code></pre>
903</div></div>
904<div class="paragraph"><p>or:</p></div>
905<div class="listingblock">
906<div class="content">
907<pre><code>GIT_TRACE_PERFORMANCE=3 3&gt;&amp;2 git log -1</code></pre>
908</div></div>
909<div class="paragraph"><p>or:</p></div>
910<div class="listingblock">
911<div class="content">
912<pre><code>GIT_TRACE_PERFORMANCE=/path/to/log/file git log -1</code></pre>
913</div></div>
914</div>
915</div>
Junio C Hamanodbe51052014-07-22 19:39:51916</div>
917<div id="footnotes"><hr /></div>
918<div id="footer">
919<div id="footer-text">
Junio C Hamano2ef0ba32018-01-26 23:13:53920Last updated
Junio C Hamano49bcf742018-06-13 22:04:15921 2018-01-26 15:11:04 PST
Junio C Hamanodbe51052014-07-22 19:39:51922</div>
923</div>
924</body>
925</html>