blob: 0333875cc4a75b3e04a95c4b3e210bbfbba38ef0 [file] [log] [blame]
Junio C Hamano944ce252018-05-30 22:25:261<?xml version="1.0" encoding="UTF-8"?>
Junio C Hamanob33fb4f2006-04-18 21:30: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>
Junio C Hamano9d971152012-12-19 00:43:116<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 Hamano103b5722011-01-31 05:03:458<title>git-annotate(1)</title>
Junio C Hamanob33fb4f2006-04-18 21:30:519<style type="text/css">
Junio C Hamano9d971152012-12-19 00:43:1110/* 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;
Junio C Hamanob33fb4f2006-04-18 21:30:5125}
26
27body {
28 margin: 1em 5% 1em 5%;
29}
30
Junio C Hamanof87ade62008-09-07 06:05:5131a {
32 color: blue;
33 text-decoration: underline;
34}
35a:visited {
36 color: fuchsia;
37}
Junio C Hamanob33fb4f2006-04-18 21:30:5138
39em {
40 font-style: italic;
Junio C Hamano103b5722011-01-31 05:03:4541 color: navy;
Junio C Hamanob33fb4f2006-04-18 21:30:5142}
43
44strong {
45 font-weight: bold;
Junio C Hamano103b5722011-01-31 05:03:4546 color: #083194;
Junio C Hamanob33fb4f2006-04-18 21:30:5147}
48
Junio C Hamanob33fb4f2006-04-18 21:30:5149h1, h2, h3, h4, h5, h6 {
50 color: #527bbd;
Junio C Hamanob33fb4f2006-04-18 21:30:5151 margin-top: 1.2em;
52 margin-bottom: 0.5em;
53 line-height: 1.3;
54}
55
Junio C Hamanof87ade62008-09-07 06:05:5156h1, h2, h3 {
Junio C Hamanob33fb4f2006-04-18 21:30:5157 border-bottom: 2px solid silver;
58}
59h2 {
Junio C Hamanob33fb4f2006-04-18 21:30:5160 padding-top: 0.5em;
61}
Junio C Hamanof87ade62008-09-07 06:05:5162h3 {
63 float: left;
64}
65h3 + * {
66 clear: left;
67}
Junio C Hamano9d971152012-12-19 00:43:1168h5 {
69 font-size: 1.0em;
70}
Junio C Hamanob33fb4f2006-04-18 21:30:5171
72div.sectionbody {
Junio C Hamanob33fb4f2006-04-18 21:30:5173 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
Junio C Hamano103b5722011-01-31 05:03:4585ul, ol, li > p {
86 margin-top: 0;
87}
Junio C Hamano9d971152012-12-19 00:43:1188ul > li { color: #aaa; }
89ul > li > * { color: black; }
Junio C Hamano103b5722011-01-31 05:03:4590
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 Hamanob33fb4f2006-04-18 21:30:5195 padding: 0;
96 margin: 0;
97}
Junio C Hamanoc14e6ad2014-10-31 20:25:5398pre {
99 white-space: pre-wrap;
100}
Junio C Hamanob33fb4f2006-04-18 21:30:51101
Junio C Hamano9d971152012-12-19 00:43:11102#author {
Junio C Hamanob33fb4f2006-04-18 21:30:51103 color: #527bbd;
Junio C Hamanob33fb4f2006-04-18 21:30:51104 font-weight: bold;
Junio C Hamanof87ade62008-09-07 06:05:51105 font-size: 1.1em;
Junio C Hamanob33fb4f2006-04-18 21:30:51106}
Junio C Hamano9d971152012-12-19 00:43:11107#email {
Junio C Hamanob33fb4f2006-04-18 21:30:51108}
Junio C Hamano9d971152012-12-19 00:43:11109#revnumber, #revdate, #revremark {
Junio C Hamanob33fb4f2006-04-18 21:30:51110}
111
Junio C Hamano9d971152012-12-19 00:43:11112#footer {
Junio C Hamanob33fb4f2006-04-18 21:30:51113 font-size: small;
114 border-top: 2px solid silver;
115 padding-top: 0.5em;
116 margin-top: 4.0em;
117}
Junio C Hamano9d971152012-12-19 00:43:11118#footer-text {
Junio C Hamanob33fb4f2006-04-18 21:30:51119 float: left;
120 padding-bottom: 0.5em;
121}
Junio C Hamano9d971152012-12-19 00:43:11122#footer-badges {
Junio C Hamanob33fb4f2006-04-18 21:30:51123 float: right;
124 padding-bottom: 0.5em;
125}
126
Junio C Hamano9d971152012-12-19 00:43:11127#preamble {
Junio C Hamano103b5722011-01-31 05:03:45128 margin-top: 1.5em;
129 margin-bottom: 1.5em;
130}
Junio C Hamano9d971152012-12-19 00:43:11131div.imageblock, div.exampleblock, div.verseblock,
Junio C Hamanob33fb4f2006-04-18 21:30:51132div.quoteblock, div.literalblock, div.listingblock, div.sidebarblock,
133div.admonitionblock {
Junio C Hamano7bd050f2011-09-22 06:32:22134 margin-top: 1.0em;
Junio C Hamanob33fb4f2006-04-18 21:30:51135 margin-bottom: 1.5em;
136}
137div.admonitionblock {
Junio C Hamano7bd050f2011-09-22 06:32:22138 margin-top: 2.0em;
139 margin-bottom: 2.0em;
140 margin-right: 10%;
141 color: #606060;
Junio C Hamanob33fb4f2006-04-18 21:30:51142}
143
144div.content { /* Block element content. */
145 padding: 0;
146}
147
148/* Block element titles. */
149div.title, caption.title {
Junio C Hamano103b5722011-01-31 05:03:45150 color: #527bbd;
Junio C Hamanob33fb4f2006-04-18 21:30:51151 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;
Junio C Hamano9d971152012-12-19 00:43:11172 border: 1px solid #dddddd;
173 border-left: 4px solid #f0f0f0;
Junio C Hamanob33fb4f2006-04-18 21:30:51174 padding: 0.5em;
175}
176
177div.listingblock > div.content {
Junio C Hamano9d971152012-12-19 00:43:11178 border: 1px solid #dddddd;
179 border-left: 5px solid #f0f0f0;
180 background: #f8f8f8;
Junio C Hamanob33fb4f2006-04-18 21:30:51181 padding: 0.5em;
182}
183
Junio C Hamano7bd050f2011-09-22 06:32:22184div.quoteblock, div.verseblock {
185 padding-left: 1.0em;
186 margin-left: 1.0em;
Junio C Hamano103b5722011-01-31 05:03:45187 margin-right: 10%;
Junio C Hamano9d971152012-12-19 00:43:11188 border-left: 5px solid #f0f0f0;
189 color: #888;
Junio C Hamanob33fb4f2006-04-18 21:30:51190}
Junio C Hamano7bd050f2011-09-22 06:32:22191
Junio C Hamano103b5722011-01-31 05:03:45192div.quoteblock > div.attribution {
193 padding-top: 0.5em;
Junio C Hamanob33fb4f2006-04-18 21:30:51194 text-align: right;
195}
Junio C Hamano103b5722011-01-31 05:03:45196
Junio C Hamano9d971152012-12-19 00:43:11197div.verseblock > pre.content {
198 font-family: inherit;
199 font-size: inherit;
Junio C Hamano103b5722011-01-31 05:03:45200}
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. */
Junio C Hamanof87ade62008-09-07 06:05:51206div.verseblock + div.attribution {
207 text-align: left;
208}
Junio C Hamanob33fb4f2006-04-18 21:30:51209
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;
Junio C Hamano7bd050f2011-09-22 06:32:22220 border-left: 3px solid #dddddd;
Junio C Hamanob33fb4f2006-04-18 21:30:51221}
222
223div.exampleblock > div.content {
Junio C Hamano7bd050f2011-09-22 06:32:22224 border-left: 3px solid #dddddd;
225 padding-left: 0.5em;
Junio C Hamanob33fb4f2006-04-18 21:30:51226}
227
Junio C Hamanob33fb4f2006-04-18 21:30:51228div.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 Hamano103b5722011-01-31 05:03:45230a.image:visited { color: white; }
Junio C Hamanob33fb4f2006-04-18 21:30:51231
232dl {
233 margin-top: 0.8em;
234 margin-bottom: 0.8em;
235}
236dt {
237 margin-top: 0.5em;
238 margin-bottom: 0;
Junio C Hamano103b5722011-01-31 05:03:45239 font-style: normal;
240 color: navy;
Junio C Hamanob33fb4f2006-04-18 21:30:51241}
242dd > *:first-child {
Junio C Hamano103b5722011-01-31 05:03:45243 margin-top: 0.1em;
Junio C Hamanob33fb4f2006-04-18 21:30:51244}
245
246ul, ol {
247 list-style-position: outside;
248}
Junio C Hamano103b5722011-01-31 05:03:45249ol.arabic {
250 list-style-type: decimal;
251}
252ol.loweralpha {
Junio C Hamanob33fb4f2006-04-18 21:30:51253 list-style-type: lower-alpha;
254}
Junio C Hamano103b5722011-01-31 05:03:45255ol.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}
Junio C Hamanob33fb4f2006-04-18 21:30:51271
Junio C Hamanob33fb4f2006-04-18 21:30:51272tfoot {
273 font-weight: bold;
274}
Junio C Hamano103b5722011-01-31 05:03:45275td > div.verse {
276 white-space: pre;
277}
Junio C Hamano103b5722011-01-31 05:03:45278
279div.hdlist {
Junio C Hamanob33fb4f2006-04-18 21:30:51280 margin-top: 0.8em;
281 margin-bottom: 0.8em;
282}
Junio C Hamano103b5722011-01-31 05:03:45283div.hdlist tr {
284 padding-bottom: 15px;
Junio C Hamanof87ade62008-09-07 06:05:51285}
Junio C Hamano103b5722011-01-31 05:03:45286dt.hdlist1.strong, td.hdlist1.strong {
287 font-weight: bold;
288}
289td.hdlist1 {
Junio C Hamanob33fb4f2006-04-18 21:30:51290 vertical-align: top;
Junio C Hamano103b5722011-01-31 05:03:45291 font-style: normal;
Junio C Hamanob33fb4f2006-04-18 21:30:51292 padding-right: 0.8em;
Junio C Hamano103b5722011-01-31 05:03:45293 color: navy;
Junio C Hamanob33fb4f2006-04-18 21:30:51294}
Junio C Hamano103b5722011-01-31 05:03:45295td.hdlist2 {
Junio C Hamanob33fb4f2006-04-18 21:30:51296 vertical-align: top;
297}
Junio C Hamano103b5722011-01-31 05:03:45298div.hdlist.compact tr {
299 margin: 0;
300 padding-bottom: 0;
301}
302
303.comment {
304 background: yellow;
305}
Junio C Hamanob33fb4f2006-04-18 21:30:51306
Junio C Hamano7bd050f2011-09-22 06:32:22307.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
Junio C Hamano9d971152012-12-19 00:43:11334div.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;
Junio C Hamanob33fb4f2006-04-18 21:30:51341}
Junio C Hamanof87ade62008-09-07 06:05:51342
Junio C Hamano9d971152012-12-19 00:43:11343@media print {
344 #footer-badges { display: none; }
345}
346
347#toc {
Junio C Hamano7bd050f2011-09-22 06:32:22348 margin-bottom: 2.5em;
349}
350
Junio C Hamano9d971152012-12-19 00:43:11351#toctitle {
Junio C Hamanof87ade62008-09-07 06:05:51352 color: #527bbd;
Junio C Hamanof87ade62008-09-07 06:05:51353 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 Hamanof87ade62008-09-07 06:05: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}
Junio C Hamano9d971152012-12-19 00:43:11375
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 Hamano9d971152012-12-19 00:43:11419
420/*
421 * xhtml11 specific
422 *
423 * */
424
425div.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
458table.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 {
Junio C Hamano103b5722011-01-31 05:03:45522 padding-top: 0.5em;
523 padding-bottom: 0.5em;
524 border-top: 2px solid silver;
525 border-bottom: 2px solid silver;
526}
Junio C Hamano9d971152012-12-19 00:43:11527body.manpage h2 {
Junio C Hamano103b5722011-01-31 05:03:45528 border-style: none;
529}
Junio C Hamano9d971152012-12-19 00:43:11530body.manpage div.sectionbody {
531 margin-left: 3em;
Junio C Hamano103b5722011-01-31 05:03:45532}
533
534@media print {
Junio C Hamano9d971152012-12-19 00:43:11535 body.manpage div#toc { display: none; }
Junio C Hamano103b5722011-01-31 05:03:45536}
Junio C Hamanoc14e6ad2014-10-31 20:25:53537
538
Junio C Hamanob33fb4f2006-04-18 21:30:51539</style>
Junio C Hamano7bd050f2011-09-22 06:32:22540<script type="text/javascript">
541/*<![CDATA[*/
Junio C Hamano7bd050f2011-09-22 06:32:22542var 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 Hamano7bd050f2011-09-22 06:32:22584 // 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");
Junio C Hamano9d971152012-12-19 00:43:11603 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 Hamano9d971152012-12-19 00:43:11613 && 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.
Junio C Hamano7bd050f2011-09-22 06:32:22622 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 () {
Junio C Hamano9d971152012-12-19 00:43:11649 // Delete existing footnote entries in case we're reloading the footnodes.
650 var i;
Junio C Hamano7bd050f2011-09-22 06:32:22651 var noteholder = document.getElementById("footnotes");
Junio C Hamano9d971152012-12-19 00:43:11652 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 Hamano9d971152012-12-19 00:43:11659 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");
Junio C Hamano7bd050f2011-09-22 06:32:22667 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++;
Junio C Hamano9d971152012-12-19 00:43:11673 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 }
Junio C Hamano7bd050f2011-09-22 06:32:22683 noteholder.innerHTML +=
684 "<div class='footnote' id='_footnote_" + n + "'>" +
685 "<a href='#_footnoteref_" + n + "' title='Return to text'>" +
686 n + "</a>. " + note + "</div>";
Junio C Hamano7bd050f2011-09-22 06:32:22687 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 }
Junio C Hamano9d971152012-12-19 00:43:11706},
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;
Junio C Hamano7bd050f2011-09-22 06:32:22728}
729
730}
Junio C Hamano9d971152012-12-19 00:43:11731asciidoc.install();
Junio C Hamano7bd050f2011-09-22 06:32:22732/*]]>*/
733</script>
Junio C Hamanob33fb4f2006-04-18 21:30:51734</head>
Junio C Hamano9d971152012-12-19 00:43:11735<body class="manpage">
Junio C Hamanob33fb4f2006-04-18 21:30:51736<div id="header">
737<h1>
738git-annotate(1) Manual Page
739</h1>
740<h2>NAME</h2>
741<div class="sectionbody">
742<p>git-annotate -
Junio C Hamano7924d5e2009-03-03 08:28:48743 Annotate file lines with commit information
Junio C Hamanob33fb4f2006-04-18 21:30:51744</p>
745</div>
746</div>
Junio C Hamano7bd050f2011-09-22 06:32:22747<div id="content">
Junio C Hamano9d971152012-12-19 00:43:11748<div class="sect1">
Junio C Hamano103b5722011-01-31 05:03:45749<h2 id="_synopsis">SYNOPSIS</h2>
Junio C Hamanob33fb4f2006-04-18 21:30:51750<div class="sectionbody">
Junio C Hamano15567bc2011-07-23 00:51:59751<div class="verseblock">
Junio C Hamanoc9cb5172018-06-01 07:13:44752<pre class="content"><em>git annotate</em> [&lt;options&gt;] &lt;file&gt; [&lt;revision&gt;]</pre>
Junio C Hamano9d971152012-12-19 00:43:11753<div class="attribution">
Junio C Hamano15567bc2011-07-23 00:51:59754</div></div>
Junio C Hamanob33fb4f2006-04-18 21:30:51755</div>
Junio C Hamano9d971152012-12-19 00:43:11756</div>
757<div class="sect1">
Junio C Hamanof87ade62008-09-07 06:05:51758<h2 id="_description">DESCRIPTION</h2>
Junio C Hamanob33fb4f2006-04-18 21:30:51759<div class="sectionbody">
Junio C Hamano103b5722011-01-31 05:03:45760<div class="paragraph"><p>Annotates each line in the given file with information from the commit
Junio C Hamano7924d5e2009-03-03 08:28:48761which introduced the line. Optionally annotates from a given revision.</p></div>
Junio C Hamanoa28a9202012-06-21 07:08:23762<div class="paragraph"><p>The only difference between this command and <a href="git-blame.html">git-blame(1)</a> is that
Junio C Hamanof87ade62008-09-07 06:05:51763they use slightly different output formats, and this command exists only
Junio C Hamano7924d5e2009-03-03 08:28:48764for backward compatibility to support existing scripts, and provide a more
Junio C Hamanof87ade62008-09-07 06:05:51765familiar command name for people coming from other SCM systems.</p></div>
Junio C Hamanob33fb4f2006-04-18 21:30:51766</div>
Junio C Hamano9d971152012-12-19 00:43:11767</div>
768<div class="sect1">
Junio C Hamanof87ade62008-09-07 06:05:51769<h2 id="_options">OPTIONS</h2>
Junio C Hamanob33fb4f2006-04-18 21:30:51770<div class="sectionbody">
Junio C Hamano103b5722011-01-31 05:03:45771<div class="dlist"><dl>
772<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11773-b
Junio C Hamanob33fb4f2006-04-18 21:30:51774</dt>
775<dd>
776<p>
Junio C Hamano0e3cb532007-04-17 08:28:11777 Show blank SHA-1 for boundary commits. This can also
Junio C Hamanoc14e6ad2014-10-31 20:25:53778 be controlled via the <code>blame.blankboundary</code> config option.
Junio C Hamanob33fb4f2006-04-18 21:30:51779</p>
780</dd>
Junio C Hamano103b5722011-01-31 05:03:45781<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11782--root
Junio C Hamanob33fb4f2006-04-18 21:30:51783</dt>
784<dd>
785<p>
Junio C Hamano0e3cb532007-04-17 08:28:11786 Do not treat root commits as boundaries. This can also be
Junio C Hamano322c6242015-03-23 21:32:46787 controlled via the <code>blame.showRoot</code> config option.
Junio C Hamanob33fb4f2006-04-18 21:30:51788</p>
789</dd>
Junio C Hamano103b5722011-01-31 05:03:45790<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11791--show-stats
Junio C Hamanob33fb4f2006-04-18 21:30:51792</dt>
793<dd>
794<p>
Junio C Hamano0e3cb532007-04-17 08:28:11795 Include additional statistics at the end of blame output.
Junio C Hamanob33fb4f2006-04-18 21:30:51796</p>
797</dd>
Junio C Hamano103b5722011-01-31 05:03:45798<dt class="hdlist1">
Junio C Hamano58f587a2013-07-22 19:20:59799-L &lt;start&gt;,&lt;end&gt;
800</dt>
801<dt class="hdlist1">
Junio C Hamanodd5004a2015-05-06 19:33:32802-L :&lt;funcname&gt;
Junio C Hamanob33fb4f2006-04-18 21:30:51803</dt>
804<dd>
805<p>
Junio C Hamano8eac2682013-09-09 22:35:20806 Annotate only the given line range. May be specified multiple times.
807 Overlapping ranges are allowed.
Junio C Hamanob33fb4f2006-04-18 21:30:51808</p>
Junio C Hamano8eac2682013-09-09 22:35:20809<div class="paragraph"><p>&lt;start&gt; and &lt;end&gt; are optional. &#8220;-L &lt;start&gt;&#8221; or &#8220;-L &lt;start&gt;,&#8221; spans from
810&lt;start&gt; to end of file. &#8220;-L ,&lt;end&gt;&#8221; spans from start of file to &lt;end&gt;.</p></div>
Junio C Hamano58f587a2013-07-22 19:20:59811<div class="paragraph"><p>&lt;start&gt; and &lt;end&gt; can take one of these forms:</p></div>
Junio C Hamano103b5722011-01-31 05:03:45812<div class="ulist"><ul>
Junio C Hamano9882a522007-04-27 08:22:22813<li>
814<p>
815number
816</p>
Junio C Hamano103b5722011-01-31 05:03:45817<div class="paragraph"><p>If &lt;start&gt; or &lt;end&gt; is a number, it specifies an
Junio C Hamanof87ade62008-09-07 06:05:51818absolute line number (lines count from 1).</p></div>
Junio C Hamano9882a522007-04-27 08:22:22819</li>
820<li>
821<p>
822/regex/
823</p>
Junio C Hamano103b5722011-01-31 05:03:45824<div class="paragraph"><p>This form will use the first line matching the given
Junio C Hamano8eac2682013-09-09 22:35:20825POSIX regex. If &lt;start&gt; is a regex, it will search from the end of
Junio C Hamanoc14e6ad2014-10-31 20:25:53826the previous <code>-L</code> range, if any, otherwise from the start of file.
Junio C Hamano8eac2682013-09-09 22:35:20827If &lt;start&gt; is &#8220;^/regex/&#8221;, it will search from the start of file.
828If &lt;end&gt; is a regex, it will search
Junio C Hamanof87ade62008-09-07 06:05:51829starting at the line given by &lt;start&gt;.</p></div>
Junio C Hamano9882a522007-04-27 08:22:22830</li>
831<li>
832<p>
833+offset or -offset
834</p>
Junio C Hamano103b5722011-01-31 05:03:45835<div class="paragraph"><p>This is only valid for &lt;end&gt; and will specify a number
Junio C Hamanof87ade62008-09-07 06:05:51836of lines before or after the line given by &lt;start&gt;.</p></div>
Junio C Hamano9882a522007-04-27 08:22:22837</li>
Junio C Hamanof87ade62008-09-07 06:05:51838</ul></div>
Junio C Hamanodd5004a2015-05-06 19:33:32839<div class="paragraph"><p>If &#8220;:&lt;funcname&gt;&#8221; is given in place of &lt;start&gt; and &lt;end&gt;, it is a
840regular expression that denotes the range from the first funcname line
841that matches &lt;funcname&gt;, up to the next funcname line. &#8220;:&lt;funcname&gt;&#8221;
842searches from the end of the previous <code>-L</code> range, if any, otherwise
843from the start of file. &#8220;^:&lt;funcname&gt;&#8221; searches from the start of
844file.</p></div>
Junio C Hamanob33fb4f2006-04-18 21:30:51845</dd>
Junio C Hamano103b5722011-01-31 05:03:45846<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11847-l
848</dt>
849<dd>
850<p>
851 Show long rev (Default: off).
852</p>
853</dd>
Junio C Hamano103b5722011-01-31 05:03:45854<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11855-t
856</dt>
857<dd>
858<p>
859 Show raw timestamp (Default: off).
860</p>
861</dd>
Junio C Hamano103b5722011-01-31 05:03:45862<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11863-S &lt;revs-file&gt;
864</dt>
865<dd>
866<p>
Junio C Hamanoa28a9202012-06-21 07:08:23867 Use revisions from revs-file instead of calling <a href="git-rev-list.html">git-rev-list(1)</a>.
Junio C Hamano0e3cb532007-04-17 08:28:11868</p>
869</dd>
Junio C Hamano103b5722011-01-31 05:03:45870<dt class="hdlist1">
Junio C Hamano20829a42016-10-10 23:24:44871--reverse &lt;rev&gt;..&lt;rev&gt;
Junio C Hamanoa6455f62009-02-20 08:33:08872</dt>
873<dd>
874<p>
875 Walk history forward instead of backward. Instead of showing
876 the revision in which a line appeared, this shows the last
877 revision in which a line has existed. This requires a range of
878 revision like START..END where the path to blame exists in
Junio C Hamano20829a42016-10-10 23:24:44879 START. <code>git blame --reverse START</code> is taken as <code>git blame
880 --reverse START..HEAD</code> for convenience.
Junio C Hamanoa6455f62009-02-20 08:33:08881</p>
882</dd>
Junio C Hamano103b5722011-01-31 05:03:45883<dt class="hdlist1">
Junio C Hamanoeb415992008-06-08 22:49:47884-p
885</dt>
Junio C Hamano103b5722011-01-31 05:03:45886<dt class="hdlist1">
Junio C Hamanoeb415992008-06-08 22:49:47887--porcelain
Junio C Hamano0e3cb532007-04-17 08:28:11888</dt>
889<dd>
890<p>
891 Show in a format designed for machine consumption.
892</p>
893</dd>
Junio C Hamano103b5722011-01-31 05:03:45894<dt class="hdlist1">
Junio C Hamano2a294cd2011-05-23 23:06:31895--line-porcelain
896</dt>
897<dd>
898<p>
899 Show the porcelain format, but output commit information for
900 each line, not just the first time a commit is referenced.
901 Implies --porcelain.
902</p>
903</dd>
904<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11905--incremental
906</dt>
907<dd>
908<p>
909 Show the result incrementally in a format designed for
910 machine consumption.
911</p>
912</dd>
Junio C Hamano103b5722011-01-31 05:03:45913<dt class="hdlist1">
Junio C Hamanoaa17c7c2008-11-03 04:36:58914--encoding=&lt;encoding&gt;
915</dt>
916<dd>
917<p>
918 Specifies the encoding used to output author names
Junio C Hamanoc14e6ad2014-10-31 20:25:53919 and commit summaries. Setting it to <code>none</code> makes blame
Junio C Hamanoaa17c7c2008-11-03 04:36:58920 output unconverted data. For more information see the
Junio C Hamanoa28a9202012-06-21 07:08:23921 discussion about encoding in the <a href="git-log.html">git-log(1)</a>
Junio C Hamanoaa17c7c2008-11-03 04:36:58922 manual page.
923</p>
924</dd>
Junio C Hamano103b5722011-01-31 05:03:45925<dt class="hdlist1">
Junio C Hamano0e3cb532007-04-17 08:28:11926--contents &lt;file&gt;
927</dt>
928<dd>
929<p>
930 When &lt;rev&gt; is not specified, the command annotates the
931 changes starting backwards from the working tree copy.
932 This flag makes the command pretend as if the working
Junio C Hamano49dccaf2008-02-10 10:48:01933 tree copy has the contents of the named file (specify
Junio C Hamanoc14e6ad2014-10-31 20:25:53934 <code>-</code> to make the command read from the standard input).
Junio C Hamano0e3cb532007-04-17 08:28:11935</p>
936</dd>
Junio C Hamano103b5722011-01-31 05:03:45937<dt class="hdlist1">
Junio C Hamanoea6a7642009-03-11 23:56:19938--date &lt;format&gt;
939</dt>
940<dd>
941<p>
Junio C Hamano1eb56092015-10-05 20:39:53942 Specifies the format used to output dates. If --date is not
Junio C Hamanoea6a7642009-03-11 23:56:19943 provided, the value of the blame.date config variable is
944 used. If the blame.date config variable is also not set, the
Junio C Hamano1eb56092015-10-05 20:39:53945 iso format is used. For supported values, see the discussion
Junio C Hamanoa28a9202012-06-21 07:08:23946 of the --date option at <a href="git-log.html">git-log(1)</a>.
Junio C Hamanoea6a7642009-03-11 23:56:19947</p>
948</dd>
Junio C Hamano103b5722011-01-31 05:03:45949<dt class="hdlist1">
Junio C Hamanoa7da1ba2016-01-13 00:19:45950--[no-]progress
951</dt>
952<dd>
953<p>
954 Progress status is reported on the standard error stream
955 by default when it is attached to a terminal. This flag
956 enables progress reporting even if not attached to a
957 terminal. Can&#8217;t use <code>--progress</code> together with <code>--porcelain</code>
958 or <code>--incremental</code>.
959</p>
960</dd>
961<dt class="hdlist1">
Junio C Hamanofa0dac32017-02-24 19:02:55962-M[&lt;num&gt;]
Junio C Hamano0e3cb532007-04-17 08:28:11963</dt>
964<dd>
965<p>
Junio C Hamano0e8c0b02010-04-12 15:45:55966 Detect moved or copied lines within a file. When a commit
967 moves or copies a block of lines (e.g. the original file
968 has A and then B, and the commit changes it to B and then
969 A), the traditional <em>blame</em> algorithm notices only half of
970 the movement and typically blames the lines that were moved
971 up (i.e. B) to the parent and assigns blame to the lines that
972 were moved down (i.e. A) to the child commit. With this
973 option, both groups of lines are blamed on the parent by
974 running extra passes of inspection.
Junio C Hamano0e3cb532007-04-17 08:28:11975</p>
Junio C Hamano103b5722011-01-31 05:03:45976<div class="paragraph"><p>&lt;num&gt; is optional but it is the lower bound on the number of
Junio C Hamano076ffcc2013-02-06 05:13:21977alphanumeric characters that Git must detect as moving/copying
Junio C Hamano0e3cb532007-04-17 08:28:11978within a file for it to associate those lines with the parent
Junio C Hamanocc7636a2010-05-21 14:57:53979commit. The default value is 20.</p></div>
Junio C Hamano0e3cb532007-04-17 08:28:11980</dd>
Junio C Hamano103b5722011-01-31 05:03:45981<dt class="hdlist1">
Junio C Hamanofa0dac32017-02-24 19:02:55982-C[&lt;num&gt;]
Junio C Hamano0e3cb532007-04-17 08:28:11983</dt>
984<dd>
985<p>
Junio C Hamanoc14e6ad2014-10-31 20:25:53986 In addition to <code>-M</code>, detect lines moved or copied from other
Junio C Hamano0e3cb532007-04-17 08:28:11987 files that were modified in the same commit. This is
988 useful when you reorganize your program and move code
989 around across files. When this option is given twice,
Junio C Hamano5ca1dd12010-01-17 02:44:04990 the command additionally looks for copies from other
991 files in the commit that creates the file. When this
992 option is given three times, the command additionally
993 looks for copies from other files in any commit.
Junio C Hamano0e3cb532007-04-17 08:28:11994</p>
Junio C Hamano103b5722011-01-31 05:03:45995<div class="paragraph"><p>&lt;num&gt; is optional but it is the lower bound on the number of
Junio C Hamano076ffcc2013-02-06 05:13:21996alphanumeric characters that Git must detect as moving/copying
Junio C Hamano0e3cb532007-04-17 08:28:11997between files for it to associate those lines with the parent
Junio C Hamanocc7636a2010-05-21 14:57:53998commit. And the default value is 40. If there are more than one
Junio C Hamanoc14e6ad2014-10-31 20:25:53999<code>-C</code> options given, the &lt;num&gt; argument of the last <code>-C</code> will
Junio C Hamanocc7636a2010-05-21 14:57:531000take effect.</p></div>
Junio C Hamano0e3cb532007-04-17 08:28:111001</dd>
Junio C Hamano103b5722011-01-31 05:03:451002<dt class="hdlist1">
Junio C Hamanoeb415992008-06-08 22:49:471003-h
1004</dt>
Junio C Hamanob33fb4f2006-04-18 21:30:511005<dd>
1006<p>
1007 Show help message.
1008</p>
1009</dd>
Junio C Hamanof87ade62008-09-07 06:05:511010</dl></div>
Junio C Hamanob33fb4f2006-04-18 21:30:511011</div>
Junio C Hamano9d971152012-12-19 00:43:111012</div>
1013<div class="sect1">
Junio C Hamanof87ade62008-09-07 06:05:511014<h2 id="_see_also">SEE ALSO</h2>
Junio C Hamanob33fb4f2006-04-18 21:30:511015<div class="sectionbody">
Junio C Hamanoa28a9202012-06-21 07:08:231016<div class="paragraph"><p><a href="git-blame.html">git-blame(1)</a></p></div>
Junio C Hamanob33fb4f2006-04-18 21:30:511017</div>
Junio C Hamano9d971152012-12-19 00:43:111018</div>
1019<div class="sect1">
Junio C Hamanof87ade62008-09-07 06:05:511020<h2 id="_git">GIT</h2>
Junio C Hamanob33fb4f2006-04-18 21:30:511021<div class="sectionbody">
Junio C Hamanoa28a9202012-06-21 07:08:231022<div class="paragraph"><p>Part of the <a href="git.html">git(1)</a> suite</p></div>
Junio C Hamanob33fb4f2006-04-18 21:30:511023</div>
Junio C Hamano7bd050f2011-09-22 06:32:221024</div>
Junio C Hamano9d971152012-12-19 00:43:111025</div>
Junio C Hamano7bd050f2011-09-22 06:32:221026<div id="footnotes"><hr /></div>
Junio C Hamanob33fb4f2006-04-18 21:30:511027<div id="footer">
1028<div id="footer-text">
Junio C Hamano2ef0ba32018-01-26 23:13:531029Last updated
Junio C Hamanoc01eecf2019-05-30 18:17:471030 2018-06-01 00:13:01 PDT
Junio C Hamanob33fb4f2006-04-18 21:30:511031</div>
1032</div>
1033</body>
1034</html>