blob: 1298cae5ac344a5d8d78c6ae9c01e3ffa81214c5 [file] [log] [blame]
Junio C Hamano85151f32018-04-10 00:52:261<?xml version="1.0" encoding="UTF-8"?>
Junio C Hamano52299462006-12-28 00:59:382<!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 Hamano85151f32018-04-10 00:52:267<meta name="generator" content="AsciiDoc 8.6.10" />
Junio C Hamano97bcb482010-11-25 03:16:078<title>git-gc(1)</title>
Junio C Hamano52299462006-12-28 00:59:389<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 Hamano52299462006-12-28 00:59:3825}
26
27body {
28 margin: 1em 5% 1em 5%;
29}
30
Junio C Hamanoba4b9282008-07-06 05:20:3131a {
32 color: blue;
33 text-decoration: underline;
34}
35a:visited {
36 color: fuchsia;
37}
Junio C Hamano52299462006-12-28 00:59:3838
39em {
40 font-style: italic;
Junio C Hamano97bcb482010-11-25 03:16:0741 color: navy;
Junio C Hamano52299462006-12-28 00:59:3842}
43
44strong {
45 font-weight: bold;
Junio C Hamano97bcb482010-11-25 03:16:0746 color: #083194;
Junio C Hamano52299462006-12-28 00:59:3847}
48
Junio C Hamano52299462006-12-28 00:59:3849h1, h2, h3, h4, h5, h6 {
50 color: #527bbd;
Junio C Hamano52299462006-12-28 00:59:3851 margin-top: 1.2em;
52 margin-bottom: 0.5em;
53 line-height: 1.3;
54}
55
Junio C Hamanoba4b9282008-07-06 05:20:3156h1, h2, h3 {
Junio C Hamano52299462006-12-28 00:59:3857 border-bottom: 2px solid silver;
58}
59h2 {
Junio C Hamano52299462006-12-28 00:59:3860 padding-top: 0.5em;
61}
Junio C Hamanoba4b9282008-07-06 05:20:3162h3 {
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 Hamano52299462006-12-28 00:59:3871
72div.sectionbody {
Junio C Hamano52299462006-12-28 00:59:3873 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 Hamano97bcb482010-11-25 03:16:0785ul, 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 Hamano97bcb482010-11-25 03:16:0790
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 Hamano52299462006-12-28 00:59:3895 padding: 0;
96 margin: 0;
97}
Junio C Hamanoc14e6ad2014-10-31 20:25:5398pre {
99 white-space: pre-wrap;
100}
Junio C Hamano52299462006-12-28 00:59:38101
Junio C Hamano9d971152012-12-19 00:43:11102#author {
Junio C Hamano52299462006-12-28 00:59:38103 color: #527bbd;
Junio C Hamano52299462006-12-28 00:59:38104 font-weight: bold;
Junio C Hamanoba4b9282008-07-06 05:20:31105 font-size: 1.1em;
Junio C Hamano52299462006-12-28 00:59:38106}
Junio C Hamano9d971152012-12-19 00:43:11107#email {
Junio C Hamano52299462006-12-28 00:59:38108}
Junio C Hamano9d971152012-12-19 00:43:11109#revnumber, #revdate, #revremark {
Junio C Hamano52299462006-12-28 00:59:38110}
111
Junio C Hamano9d971152012-12-19 00:43:11112#footer {
Junio C Hamano52299462006-12-28 00:59:38113 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 Hamano52299462006-12-28 00:59:38119 float: left;
120 padding-bottom: 0.5em;
121}
Junio C Hamano9d971152012-12-19 00:43:11122#footer-badges {
Junio C Hamano52299462006-12-28 00:59:38123 float: right;
124 padding-bottom: 0.5em;
125}
126
Junio C Hamano9d971152012-12-19 00:43:11127#preamble {
Junio C Hamano97bcb482010-11-25 03:16:07128 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 Hamano52299462006-12-28 00:59:38132div.quoteblock, div.literalblock, div.listingblock, div.sidebarblock,
133div.admonitionblock {
Junio C Hamano7bd050f2011-09-22 06:32:22134 margin-top: 1.0em;
Junio C Hamano52299462006-12-28 00:59:38135 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 Hamano52299462006-12-28 00:59:38142}
143
144div.content { /* Block element content. */
145 padding: 0;
146}
147
148/* Block element titles. */
149div.title, caption.title {
Junio C Hamano97bcb482010-11-25 03:16:07150 color: #527bbd;
Junio C Hamano52299462006-12-28 00:59:38151 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 Hamano52299462006-12-28 00:59:38174 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 Hamano52299462006-12-28 00:59:38181 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 Hamano97bcb482010-11-25 03:16:07187 margin-right: 10%;
Junio C Hamano9d971152012-12-19 00:43:11188 border-left: 5px solid #f0f0f0;
189 color: #888;
Junio C Hamano52299462006-12-28 00:59:38190}
Junio C Hamano7bd050f2011-09-22 06:32:22191
Junio C Hamano97bcb482010-11-25 03:16:07192div.quoteblock > div.attribution {
193 padding-top: 0.5em;
Junio C Hamano52299462006-12-28 00:59:38194 text-align: right;
195}
Junio C Hamano97bcb482010-11-25 03:16:07196
Junio C Hamano9d971152012-12-19 00:43:11197div.verseblock > pre.content {
198 font-family: inherit;
199 font-size: inherit;
Junio C Hamano97bcb482010-11-25 03:16:07200}
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 Hamanoba4b9282008-07-06 05:20:31206div.verseblock + div.attribution {
207 text-align: left;
208}
Junio C Hamano52299462006-12-28 00:59:38209
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 Hamano52299462006-12-28 00:59:38221}
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 Hamano52299462006-12-28 00:59:38226}
227
Junio C Hamano52299462006-12-28 00:59:38228div.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 Hamano97bcb482010-11-25 03:16:07230a.image:visited { color: white; }
Junio C Hamano52299462006-12-28 00:59:38231
232dl {
233 margin-top: 0.8em;
234 margin-bottom: 0.8em;
235}
236dt {
237 margin-top: 0.5em;
238 margin-bottom: 0;
Junio C Hamano97bcb482010-11-25 03:16:07239 font-style: normal;
240 color: navy;
Junio C Hamano52299462006-12-28 00:59:38241}
242dd > *:first-child {
Junio C Hamano97bcb482010-11-25 03:16:07243 margin-top: 0.1em;
Junio C Hamano52299462006-12-28 00:59:38244}
245
246ul, ol {
247 list-style-position: outside;
248}
Junio C Hamano97bcb482010-11-25 03:16:07249ol.arabic {
250 list-style-type: decimal;
251}
252ol.loweralpha {
Junio C Hamano52299462006-12-28 00:59:38253 list-style-type: lower-alpha;
254}
Junio C Hamano97bcb482010-11-25 03:16:07255ol.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 Hamano52299462006-12-28 00:59:38271
Junio C Hamano52299462006-12-28 00:59:38272tfoot {
273 font-weight: bold;
274}
Junio C Hamano97bcb482010-11-25 03:16:07275td > div.verse {
276 white-space: pre;
277}
Junio C Hamano97bcb482010-11-25 03:16:07278
279div.hdlist {
Junio C Hamano52299462006-12-28 00:59:38280 margin-top: 0.8em;
281 margin-bottom: 0.8em;
282}
Junio C Hamano97bcb482010-11-25 03:16:07283div.hdlist tr {
284 padding-bottom: 15px;
Junio C Hamanoba4b9282008-07-06 05:20:31285}
Junio C Hamano97bcb482010-11-25 03:16:07286dt.hdlist1.strong, td.hdlist1.strong {
287 font-weight: bold;
288}
289td.hdlist1 {
Junio C Hamano52299462006-12-28 00:59:38290 vertical-align: top;
Junio C Hamano97bcb482010-11-25 03:16:07291 font-style: normal;
Junio C Hamano52299462006-12-28 00:59:38292 padding-right: 0.8em;
Junio C Hamano97bcb482010-11-25 03:16:07293 color: navy;
Junio C Hamano52299462006-12-28 00:59:38294}
Junio C Hamano97bcb482010-11-25 03:16:07295td.hdlist2 {
Junio C Hamano52299462006-12-28 00:59:38296 vertical-align: top;
297}
Junio C Hamano97bcb482010-11-25 03:16:07298div.hdlist.compact tr {
299 margin: 0;
300 padding-bottom: 0;
301}
302
303.comment {
304 background: yellow;
305}
Junio C Hamano52299462006-12-28 00:59:38306
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 Hamano52299462006-12-28 00:59:38341}
Junio C Hamanoba4b9282008-07-06 05:20:31342
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 Hamanoba4b9282008-07-06 05:20:31352 color: #527bbd;
Junio C Hamanoba4b9282008-07-06 05:20:31353 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 Hamanoba4b9282008-07-06 05:20:31360 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 Hamano97bcb482010-11-25 03:16:07522 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 Hamano97bcb482010-11-25 03:16:07528 border-style: none;
529}
Junio C Hamano9d971152012-12-19 00:43:11530body.manpage div.sectionbody {
531 margin-left: 3em;
Junio C Hamano97bcb482010-11-25 03:16:07532}
533
534@media print {
Junio C Hamano9d971152012-12-19 00:43:11535 body.manpage div#toc { display: none; }
Junio C Hamano97bcb482010-11-25 03:16:07536}
Junio C Hamanoc14e6ad2014-10-31 20:25:53537
538
Junio C Hamano52299462006-12-28 00:59:38539</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 Hamano52299462006-12-28 00:59:38734</head>
Junio C Hamano9d971152012-12-19 00:43:11735<body class="manpage">
Junio C Hamano52299462006-12-28 00:59:38736<div id="header">
737<h1>
738git-gc(1) Manual Page
739</h1>
740<h2>NAME</h2>
741<div class="sectionbody">
742<p>git-gc -
743 Cleanup unnecessary files and optimize the local repository
744</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 Hamano97bcb482010-11-25 03:16:07749<h2 id="_synopsis">SYNOPSIS</h2>
Junio C Hamano52299462006-12-28 00:59:38750<div class="sectionbody">
Junio C Hamano15567bc2011-07-23 00:51:59751<div class="verseblock">
Junio C Hamanob9d9d902018-05-23 07:07:42752<pre class="content"><em>git gc</em> [--aggressive] [--auto] [--quiet] [--prune=&lt;date&gt; | --no-prune] [--force] [--keep-largest-pack]</pre>
Junio C Hamano9d971152012-12-19 00:43:11753<div class="attribution">
Junio C Hamano15567bc2011-07-23 00:51:59754</div></div>
Junio C Hamano52299462006-12-28 00:59:38755</div>
Junio C Hamano9d971152012-12-19 00:43:11756</div>
757<div class="sect1">
Junio C Hamanoba4b9282008-07-06 05:20:31758<h2 id="_description">DESCRIPTION</h2>
Junio C Hamano52299462006-12-28 00:59:38759<div class="sectionbody">
Junio C Hamano97bcb482010-11-25 03:16:07760<div class="paragraph"><p>Runs a number of housekeeping tasks within the current repository,
Junio C Hamano52299462006-12-28 00:59:38761such as compressing file revisions (to reduce disk space and increase
Junio C Hamano85151f32018-04-10 00:52:26762performance), removing unreachable objects which may have been
763created from prior invocations of <em>git add</em>, packing refs, pruning
Junio C Hamanoa4df8ed2018-10-26 06:37:13764reflog, rerere metadata or stale working trees. May also update ancillary
765indexes such as the commit-graph.</p></div>
Junio C Hamano97bcb482010-11-25 03:16:07766<div class="paragraph"><p>Users are encouraged to run this task on a regular basis within
Junio C Hamano52299462006-12-28 00:59:38767each repository to maintain good disk space utilization and good
Junio C Hamanoba4b9282008-07-06 05:20:31768operating performance.</p></div>
Junio C Hamanoc14e6ad2014-10-31 20:25:53769<div class="paragraph"><p>Some git commands may automatically run <em>git gc</em>; see the <code>--auto</code> flag
Junio C Hamano97bcb482010-11-25 03:16:07770below for details. If you know what you&#8217;re doing and all you want is to
Junio C Hamanoba4b9282008-07-06 05:20:31771disable this behavior permanently without further considerations, just do:</p></div>
Junio C Hamanod04b60c2008-03-20 08:46:04772<div class="listingblock">
773<div class="content">
Junio C Hamanoc14e6ad2014-10-31 20:25:53774<pre><code>$ git config --global gc.auto 0</code></pre>
Junio C Hamanod04b60c2008-03-20 08:46:04775</div></div>
Junio C Hamano52299462006-12-28 00:59:38776</div>
Junio C Hamano9d971152012-12-19 00:43:11777</div>
778<div class="sect1">
Junio C Hamanoba4b9282008-07-06 05:20:31779<h2 id="_options">OPTIONS</h2>
Junio C Hamanof65d9282007-01-22 09:00:13780<div class="sectionbody">
Junio C Hamano97bcb482010-11-25 03:16:07781<div class="dlist"><dl>
782<dt class="hdlist1">
Junio C Hamanof2ce2972007-05-20 19:12:09783--aggressive
784</dt>
785<dd>
786<p>
Junio C Hamano1aa40d22010-01-21 17:46:43787 Usually <em>git gc</em> runs very quickly while providing good disk
Junio C Hamano679d22d2007-06-02 21:13:44788 space utilization and performance. This option will cause
Junio C Hamano1aa40d22010-01-21 17:46:43789 <em>git gc</em> to more aggressively optimize the repository at the expense
Junio C Hamanof2ce2972007-05-20 19:12:09790 of taking much more time. The effects of this optimization are
Junio C Hamano679d22d2007-06-02 21:13:44791 persistent, so this option only needs to be used occasionally; every
Junio C Hamanof2ce2972007-05-20 19:12:09792 few hundred changesets or so.
793</p>
794</dd>
Junio C Hamano97bcb482010-11-25 03:16:07795<dt class="hdlist1">
Junio C Hamano1b50ce92007-10-03 12:05:53796--auto
797</dt>
798<dd>
799<p>
Junio C Hamano1aa40d22010-01-21 17:46:43800 With this option, <em>git gc</em> checks whether any housekeeping is
Junio C Hamano764a6672007-10-23 01:23:31801 required; if not, it exits without performing any work.
Junio C Hamanoc14e6ad2014-10-31 20:25:53802 Some git commands run <code>git gc --auto</code> after performing
Junio C Hamano85151f32018-04-10 00:52:26803 operations that could create many loose objects. Housekeeping
804 is required if there are too many loose objects or too many
805 packs in the repository.
Junio C Hamano1b50ce92007-10-03 12:05:53806</p>
Junio C Hamano85151f32018-04-10 00:52:26807<div class="paragraph"><p>If the number of loose objects exceeds the value of the <code>gc.auto</code>
808configuration variable, then all loose objects are combined into a
809single pack using <code>git repack -d -l</code>. Setting the value of <code>gc.auto</code>
810to 0 disables automatic packing of loose objects.</p></div>
Junio C Hamano322c6242015-03-23 21:32:46811<div class="paragraph"><p>If the number of packs exceeds the value of <code>gc.autoPackLimit</code>,
Junio C Hamanob9d9d902018-05-23 07:07:42812then existing packs (except those marked with a <code>.keep</code> file
813or over <code>gc.bigPackThreshold</code> limit)
Junio C Hamanoc14e6ad2014-10-31 20:25:53814are consolidated into a single pack by using the <code>-A</code> option of
Junio C Hamanob9d9d902018-05-23 07:07:42815<em>git repack</em>.
816If the amount of memory is estimated not enough for <code>git repack</code> to
817run smoothly and <code>gc.bigPackThreshold</code> is not set, the largest
818pack will also be excluded (this is the equivalent of running <code>git gc</code>
819with <code>--keep-base-pack</code>).
820Setting <code>gc.autoPackLimit</code> to 0 disables automatic consolidation of
821packs.</p></div>
Junio C Hamano85151f32018-04-10 00:52:26822<div class="paragraph"><p>If houskeeping is required due to many loose objects or packs, all
823other housekeeping tasks (e.g. rerere, working trees, reflog&#8230;) will
824be performed as well.</p></div>
Junio C Hamano1b50ce92007-10-03 12:05:53825</dd>
Junio C Hamano97bcb482010-11-25 03:16:07826<dt class="hdlist1">
Junio C Hamano8bc410e2009-02-15 10:38:19827--prune=&lt;date&gt;
828</dt>
829<dd>
830<p>
831 Prune loose objects older than date (default is 2 weeks ago,
Junio C Hamanoc14e6ad2014-10-31 20:25:53832 overridable by the config variable <code>gc.pruneExpire</code>).
Junio C Hamano56ace3d2017-01-10 23:43:41833 --prune=all prunes loose objects regardless of their age and
834 increases the risk of corruption if another process is writing to
835 the repository concurrently; see "NOTES" below. --prune is on by
836 default.
Junio C Hamano8bc410e2009-02-15 10:38:19837</p>
838</dd>
Junio C Hamano97bcb482010-11-25 03:16:07839<dt class="hdlist1">
Junio C Hamano8bc410e2009-02-15 10:38:19840--no-prune
841</dt>
842<dd>
843<p>
844 Do not prune any loose objects.
845</p>
846</dd>
Junio C Hamano97bcb482010-11-25 03:16:07847<dt class="hdlist1">
Junio C Hamano69a98582008-03-01 18:42:18848--quiet
849</dt>
850<dd>
851<p>
852 Suppress all progress reports.
853</p>
854</dd>
Junio C Hamano535ed7a2013-09-04 20:35:57855<dt class="hdlist1">
856--force
857</dt>
858<dd>
859<p>
Junio C Hamanoc14e6ad2014-10-31 20:25:53860 Force <code>git gc</code> to run even if there may be another <code>git gc</code>
Junio C Hamano535ed7a2013-09-04 20:35:57861 instance running on this repository.
862</p>
863</dd>
Junio C Hamanob9d9d902018-05-23 07:07:42864<dt class="hdlist1">
865--keep-largest-pack
866</dt>
867<dd>
868<p>
869 All packs except the largest pack and those marked with a
870 <code>.keep</code> files are consolidated into a single pack. When this
871 option is used, <code>gc.bigPackThreshold</code> is ignored.
872</p>
873</dd>
Junio C Hamanoba4b9282008-07-06 05:20:31874</dl></div>
Junio C Hamanof65d9282007-01-22 09:00:13875</div>
Junio C Hamano9d971152012-12-19 00:43:11876</div>
877<div class="sect1">
Junio C Hamanob9d9d902018-05-23 07:07:42878<h2 id="_configuration">CONFIGURATION</h2>
Junio C Hamano52299462006-12-28 00:59:38879<div class="sectionbody">
Junio C Hamano042f2142016-06-27 18:05:05880<div class="paragraph"><p>The optional configuration variable <code>gc.reflogExpire</code> can be
Junio C Hamano97bcb482010-11-25 03:16:07881set to indicate how long historical entries within each branch&#8217;s
Junio C Hamano52299462006-12-28 00:59:38882reflog should remain available in this repository. The setting is
883expressed as a length of time, for example <em>90 days</em> or <em>3 months</em>.
Junio C Hamanoba4b9282008-07-06 05:20:31884It defaults to <em>90 days</em>.</p></div>
Junio C Hamano042f2142016-06-27 18:05:05885<div class="paragraph"><p>The optional configuration variable <code>gc.reflogExpireUnreachable</code>
Junio C Hamano52299462006-12-28 00:59:38886can be set to indicate how long historical reflog entries which
887are not part of the current branch should remain available in
888this repository. These types of entries are generally created as
Junio C Hamanoc14e6ad2014-10-31 20:25:53889a result of using <code>git commit --amend</code> or <code>git rebase</code> and are the
Junio C Hamanof9771f62007-01-17 17:42:30890commits prior to the amend or rebase occurring. Since these changes
Junio C Hamano52299462006-12-28 00:59:38891are not part of the current project most users will want to expire
Junio C Hamanoba4b9282008-07-06 05:20:31892them sooner. This option defaults to <em>30 days</em>.</p></div>
Junio C Hamano97bcb482010-11-25 03:16:07893<div class="paragraph"><p>The above two configuration variables can be given to a pattern. For
894example, this sets non-default expiry values only to remote-tracking
Junio C Hamanocc7636a2010-05-21 14:57:53895branches:</p></div>
896<div class="listingblock">
897<div class="content">
Junio C Hamanoc14e6ad2014-10-31 20:25:53898<pre><code>[gc "refs/remotes/*"]
Junio C Hamanocc7636a2010-05-21 14:57:53899 reflogExpire = never
Junio C Hamano322c6242015-03-23 21:32:46900 reflogExpireUnreachable = 3 days</code></pre>
Junio C Hamanocc7636a2010-05-21 14:57:53901</div></div>
Junio C Hamano042f2142016-06-27 18:05:05902<div class="paragraph"><p>The optional configuration variable <code>gc.rerereResolved</code> indicates
Junio C Hamano52299462006-12-28 00:59:38903how long records of conflicted merge you resolved earlier are
Junio C Hamanoba4b9282008-07-06 05:20:31904kept. This defaults to 60 days.</p></div>
Junio C Hamano042f2142016-06-27 18:05:05905<div class="paragraph"><p>The optional configuration variable <code>gc.rerereUnresolved</code> indicates
Junio C Hamano52299462006-12-28 00:59:38906how long records of conflicted merge you have not resolved are
Junio C Hamanoba4b9282008-07-06 05:20:31907kept. This defaults to 15 days.</p></div>
Junio C Hamano042f2142016-06-27 18:05:05908<div class="paragraph"><p>The optional configuration variable <code>gc.packRefs</code> determines if
Junio C Hamanocdd1c332010-12-20 10:08:00909<em>git gc</em> runs <em>git pack-refs</em>. This can be set to "notbare" to enable
Junio C Hamanoe77b0152008-01-12 06:44:17910it within all non-bare repos or it can be set to a boolean value.
Junio C Hamanoba4b9282008-07-06 05:20:31911This defaults to true.</p></div>
Junio C Hamanoace33e42019-01-18 23:16:05912<div class="paragraph"><p>The optional configuration variable <code>gc.writeCommitGraph</code> determines if
Junio C Hamanof09b7cd2018-08-02 23:01:45913<em>git gc</em> should run <em>git commit-graph write</em>. This can be set to a
914boolean value. This defaults to false.</p></div>
Junio C Hamanoccb82522018-05-08 07:52:09915<div class="paragraph"><p>The optional configuration variable <code>gc.aggressiveWindow</code> controls how
Junio C Hamanof2ce2972007-05-20 19:12:09916much time is spent optimizing the delta compression of the objects in
917the repository when the --aggressive option is specified. The larger
918the value, the more time is spent optimizing the delta compression. See
Junio C Hamanoccb82522018-05-08 07:52:09919the documentation for the --window option in <a href="git-repack.html">git-repack(1)</a> for
Junio C Hamanoae4a8f32009-10-04 09:54:54920more details. This defaults to 250.</p></div>
Junio C Hamano042f2142016-06-27 18:05:05921<div class="paragraph"><p>Similarly, the optional configuration variable <code>gc.aggressiveDepth</code>
Junio C Hamanofa0dac32017-02-24 19:02:55922controls --depth option in <a href="git-repack.html">git-repack(1)</a>. This defaults to 50.</p></div>
Junio C Hamano042f2142016-06-27 18:05:05923<div class="paragraph"><p>The optional configuration variable <code>gc.pruneExpire</code> controls how old
Junio C Hamano09a926d2008-03-13 07:55:29924the unreferenced loose objects have to be before they are pruned. The
Junio C Hamanoba4b9282008-07-06 05:20:31925default is "2 weeks ago".</p></div>
Junio C Hamano85151f32018-04-10 00:52:26926<div class="paragraph"><p>Optional configuration variable <code>gc.worktreePruneExpire</code> controls how
927old a stale working tree should be before <code>git worktree prune</code> deletes
928it. Default is "3 months ago".</p></div>
Junio C Hamano52299462006-12-28 00:59:38929</div>
Junio C Hamano9d971152012-12-19 00:43:11930</div>
931<div class="sect1">
Junio C Hamanob9d9d902018-05-23 07:07:42932<h2 id="_notes">NOTES</h2>
Junio C Hamano2f102bb2008-04-26 02:23:37933<div class="sectionbody">
Junio C Hamano56ace3d2017-01-10 23:43:41934<div class="paragraph"><p><em>git gc</em> tries very hard not to delete objects that are referenced
935anywhere in your repository. In
Junio C Hamano2f102bb2008-04-26 02:23:37936particular, it will keep not only objects referenced by your current set
Junio C Hamano97bcb482010-11-25 03:16:07937of branches and tags, but also objects referenced by the index,
938remote-tracking branches, refs saved by <em>git filter-branch</em> in
Junio C Hamano4232bc42009-10-20 07:49:31939refs/original/, or reflogs (which may reference commits in branches
Junio C Hamano56ace3d2017-01-10 23:43:41940that were later amended or rewound).
941If you are expecting some objects to be deleted and they aren&#8217;t, check
Junio C Hamano2f102bb2008-04-26 02:23:37942all of those locations and decide whether it makes sense in your case to
Junio C Hamanoba4b9282008-07-06 05:20:31943remove those references.</p></div>
Junio C Hamano56ace3d2017-01-10 23:43:41944<div class="paragraph"><p>On the other hand, when <em>git gc</em> runs concurrently with another process,
945there is a risk of it deleting an object that the other process is using
946but hasn&#8217;t created a reference to. This may just cause the other process
947to fail or may corrupt the repository if the other process later adds a
948reference to the deleted object. Git has two features that significantly
949mitigate this problem:</p></div>
950<div class="olist arabic"><ol class="arabic">
951<li>
952<p>
953Any object with modification time newer than the <code>--prune</code> date is kept,
954 along with everything reachable from it.
955</p>
956</li>
957<li>
958<p>
959Most operations that add an object to the database update the
960 modification time of the object if it is already present so that #1
961 applies.
962</p>
963</li>
964</ol></div>
965<div class="paragraph"><p>However, these features fall short of a complete solution, so users who
966run commands concurrently have to live with some risk of corruption (which
967seems to be low in practice) unless they turn off automatic garbage
968collection with <em>git config gc.auto 0</em>.</p></div>
Junio C Hamano2f102bb2008-04-26 02:23:37969</div>
Junio C Hamano9d971152012-12-19 00:43:11970</div>
971<div class="sect1">
Junio C Hamano3e3aa812010-07-05 23:25:23972<h2 id="_hooks">HOOKS</h2>
973<div class="sectionbody">
Junio C Hamano97bcb482010-11-25 03:16:07974<div class="paragraph"><p>The <em>git gc --auto</em> command will run the <em>pre-auto-gc</em> hook. See
Junio C Hamanoa28a9202012-06-21 07:08:23975<a href="githooks.html">githooks(5)</a> for more information.</p></div>
Junio C Hamano3e3aa812010-07-05 23:25:23976</div>
Junio C Hamano9d971152012-12-19 00:43:11977</div>
978<div class="sect1">
Junio C Hamanoba4b9282008-07-06 05:20:31979<h2 id="_see_also">SEE ALSO</h2>
Junio C Hamano52299462006-12-28 00:59:38980<div class="sectionbody">
Junio C Hamanoa28a9202012-06-21 07:08:23981<div class="paragraph"><p><a href="git-prune.html">git-prune(1)</a>
982<a href="git-reflog.html">git-reflog(1)</a>
983<a href="git-repack.html">git-repack(1)</a>
984<a href="git-rerere.html">git-rerere(1)</a></p></div>
Junio C Hamano52299462006-12-28 00:59:38985</div>
Junio C Hamano9d971152012-12-19 00:43:11986</div>
987<div class="sect1">
Junio C Hamanoba4b9282008-07-06 05:20:31988<h2 id="_git">GIT</h2>
Junio C Hamano52299462006-12-28 00:59:38989<div class="sectionbody">
Junio C Hamanoa28a9202012-06-21 07:08:23990<div class="paragraph"><p>Part of the <a href="git.html">git(1)</a> suite</p></div>
Junio C Hamano52299462006-12-28 00:59:38991</div>
Junio C Hamano7bd050f2011-09-22 06:32:22992</div>
Junio C Hamano9d971152012-12-19 00:43:11993</div>
Junio C Hamano7bd050f2011-09-22 06:32:22994<div id="footnotes"><hr /></div>
Junio C Hamano52299462006-12-28 00:59:38995<div id="footer">
996<div id="footer-text">
Junio C Hamano2ef0ba32018-01-26 23:13:53997Last updated
Junio C Hamanoace33e42019-01-18 23:16:05998 2019-01-18 15:15:21 PST
Junio C Hamano52299462006-12-28 00:59:38999</div>
1000</div>
1001</body>
1002</html>