OSDN Git Service

Add Git official document to help
[tortoisegit/TortoiseGitJp.git] / doc / source / en / TortoiseGit / git_doc / git-diff-tree.html.xml
1 <?xml version="1.0" encoding="UTF-8"?>\r
2 <!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">\r
3 \r
4 <article lang="en" id="git-diff-tree(1)">\r
5 <articleinfo>\r
6     <title>git-diff-tree(1)</title>\r
7         <indexterm>\r
8                 <primary>git-diff-tree(1)</primary>\r
9         </indexterm>\r
10 </articleinfo>\r
11 <simplesect id="_name">\r
12 <title>NAME</title>\r
13 <simpara>git-diff-tree - Compares the content and mode of blobs found via two tree objects</simpara>\r
14 </simplesect>\r
15 <simplesect id="_synopsis">\r
16 <title>SYNOPSIS</title>\r
17 <blockquote>\r
18 <literallayout><emphasis>git diff-tree</emphasis> [--stdin] [-m] [-s] [-v] [--no-commit-id] [--pretty]\r
19               [-t] [-r] [-c | --cc] [--root] [&lt;common diff options&gt;]\r
20               &lt;tree-ish&gt; [&lt;tree-ish&gt;] [&lt;path&gt;&#8230;]</literallayout>\r
21 </blockquote>\r
22 </simplesect>\r
23 <simplesect id="_description">\r
24 <title>DESCRIPTION</title>\r
25 <simpara>Compares the content and mode of the blobs found via two tree objects.</simpara>\r
26 <simpara>If there is only one &lt;tree-ish&gt; given, the commit is compared with its parents\r
27 (see --stdin below).</simpara>\r
28 <simpara>Note that <emphasis>git-diff-tree</emphasis> can use the tree encapsulated in a commit object.</simpara>\r
29 </simplesect>\r
30 <simplesect id="_options">\r
31 <title>OPTIONS</title>\r
32 <variablelist>\r
33 <varlistentry>\r
34 <term>\r
35 -p\r
36 </term>\r
37 <term>\r
38 -u\r
39 </term>\r
40 <listitem>\r
41 <simpara>\r
42         Generate patch (see section on generating patches).\r
43         \r
44 </simpara>\r
45 </listitem>\r
46 </varlistentry>\r
47 <varlistentry>\r
48 <term>\r
49 -U&lt;n&gt;\r
50 </term>\r
51 <term>\r
52 --unified=&lt;n&gt;\r
53 </term>\r
54 <listitem>\r
55 <simpara>\r
56         Generate diffs with &lt;n&gt; lines of context instead of\r
57         the usual three. Implies "-p".\r
58 </simpara>\r
59 </listitem>\r
60 </varlistentry>\r
61 <varlistentry>\r
62 <term>\r
63 --raw\r
64 </term>\r
65 <listitem>\r
66 <simpara>\r
67         Generate the raw format.\r
68          This is the default.\r
69 </simpara>\r
70 </listitem>\r
71 </varlistentry>\r
72 <varlistentry>\r
73 <term>\r
74 --patch-with-raw\r
75 </term>\r
76 <listitem>\r
77 <simpara>\r
78         Synonym for "-p --raw".\r
79 </simpara>\r
80 </listitem>\r
81 </varlistentry>\r
82 <varlistentry>\r
83 <term>\r
84 --patience\r
85 </term>\r
86 <listitem>\r
87 <simpara>\r
88         Generate a diff using the "patience diff" algorithm.\r
89 </simpara>\r
90 </listitem>\r
91 </varlistentry>\r
92 <varlistentry>\r
93 <term>\r
94 --stat[=width[,name-width]]\r
95 </term>\r
96 <listitem>\r
97 <simpara>\r
98         Generate a diffstat.  You can override the default\r
99         output width for 80-column terminal by "--stat=width".\r
100         The width of the filename part can be controlled by\r
101         giving another width to it separated by a comma.\r
102 </simpara>\r
103 </listitem>\r
104 </varlistentry>\r
105 <varlistentry>\r
106 <term>\r
107 --numstat\r
108 </term>\r
109 <listitem>\r
110 <simpara>\r
111         Similar to --stat, but shows number of added and\r
112         deleted lines in decimal notation and pathname without\r
113         abbreviation, to make it more machine friendly.  For\r
114         binary files, outputs two <literal>-</literal> instead of saying\r
115         <literal>0 0</literal>.\r
116 </simpara>\r
117 </listitem>\r
118 </varlistentry>\r
119 <varlistentry>\r
120 <term>\r
121 --shortstat\r
122 </term>\r
123 <listitem>\r
124 <simpara>\r
125         Output only the last line of the --stat format containing total\r
126         number of modified files, as well as number of added and deleted\r
127         lines.\r
128 </simpara>\r
129 </listitem>\r
130 </varlistentry>\r
131 <varlistentry>\r
132 <term>\r
133 --dirstat[=limit]\r
134 </term>\r
135 <listitem>\r
136 <simpara>\r
137         Output the distribution of relative amount of changes (number of lines added or\r
138         removed) for each sub-directory. Directories with changes below\r
139         a cut-off percent (3% by default) are not shown. The cut-off percent\r
140         can be set with "--dirstat=limit". Changes in a child directory is not\r
141         counted for the parent directory, unless "--cumulative" is used.\r
142 </simpara>\r
143 </listitem>\r
144 </varlistentry>\r
145 <varlistentry>\r
146 <term>\r
147 --dirstat-by-file[=limit]\r
148 </term>\r
149 <listitem>\r
150 <simpara>\r
151         Same as --dirstat, but counts changed files instead of lines.\r
152 </simpara>\r
153 </listitem>\r
154 </varlistentry>\r
155 <varlistentry>\r
156 <term>\r
157 --summary\r
158 </term>\r
159 <listitem>\r
160 <simpara>\r
161         Output a condensed summary of extended header information\r
162         such as creations, renames and mode changes.\r
163 </simpara>\r
164 </listitem>\r
165 </varlistentry>\r
166 <varlistentry>\r
167 <term>\r
168 --patch-with-stat\r
169 </term>\r
170 <listitem>\r
171 <simpara>\r
172         Synonym for "-p --stat".\r
173         \r
174 </simpara>\r
175 </listitem>\r
176 </varlistentry>\r
177 <varlistentry>\r
178 <term>\r
179 -z\r
180 </term>\r
181 <listitem>\r
182 <simpara>\r
183         NUL-line termination on output.  This affects the --raw\r
184         output field terminator.  Also output from commands such\r
185         as "git-log" will be delimited with NUL between commits.\r
186 </simpara>\r
187 </listitem>\r
188 </varlistentry>\r
189 <varlistentry>\r
190 <term>\r
191 --name-only\r
192 </term>\r
193 <listitem>\r
194 <simpara>\r
195         Show only names of changed files.\r
196 </simpara>\r
197 </listitem>\r
198 </varlistentry>\r
199 <varlistentry>\r
200 <term>\r
201 --name-status\r
202 </term>\r
203 <listitem>\r
204 <simpara>\r
205         Show only names and status of changed files. See the description\r
206         of the <literal>--diff-filter</literal> option on what the status letters mean.\r
207 </simpara>\r
208 </listitem>\r
209 </varlistentry>\r
210 <varlistentry>\r
211 <term>\r
212 --color\r
213 </term>\r
214 <listitem>\r
215 <simpara>\r
216         Show colored diff.\r
217 </simpara>\r
218 </listitem>\r
219 </varlistentry>\r
220 <varlistentry>\r
221 <term>\r
222 --no-color\r
223 </term>\r
224 <listitem>\r
225 <simpara>\r
226         Turn off colored diff, even when the configuration file\r
227         gives the default to color output.\r
228 </simpara>\r
229 </listitem>\r
230 </varlistentry>\r
231 <varlistentry>\r
232 <term>\r
233 --color-words[=&lt;regex&gt;]\r
234 </term>\r
235 <listitem>\r
236 <simpara>\r
237         Show colored word diff, i.e., color words which have changed.\r
238         By default, words are separated by whitespace.\r
239 </simpara>\r
240 <simpara>When a &lt;regex&gt; is specified, every non-overlapping match of the\r
241 &lt;regex&gt; is considered a word.  Anything between these matches is\r
242 considered whitespace and ignored(!) for the purposes of finding\r
243 differences.  You may want to append <literal>|[^[:space:]]</literal> to your regular\r
244 expression to make sure that it matches all non-whitespace characters.\r
245 A match that contains a newline is silently truncated(!) at the\r
246 newline.</simpara>\r
247 <simpara>The regex can also be set via a diff driver or configuration option, see\r
248 <xref linkend="gitattributes(1)"/> or <xref linkend="git-config(1)"/>.  Giving it explicitly\r
249 overrides any diff driver or configuration setting.  Diff drivers\r
250 override configuration settings.</simpara>\r
251 </listitem>\r
252 </varlistentry>\r
253 <varlistentry>\r
254 <term>\r
255 --no-renames\r
256 </term>\r
257 <listitem>\r
258 <simpara>\r
259         Turn off rename detection, even when the configuration\r
260         file gives the default to do so.\r
261 </simpara>\r
262 </listitem>\r
263 </varlistentry>\r
264 <varlistentry>\r
265 <term>\r
266 --check\r
267 </term>\r
268 <listitem>\r
269 <simpara>\r
270         Warn if changes introduce trailing whitespace\r
271         or an indent that uses a space before a tab. Exits with\r
272         non-zero status if problems are found. Not compatible with\r
273         --exit-code.\r
274 </simpara>\r
275 </listitem>\r
276 </varlistentry>\r
277 <varlistentry>\r
278 <term>\r
279 --full-index\r
280 </term>\r
281 <listitem>\r
282 <simpara>\r
283         Instead of the first handful of characters, show the full\r
284         pre- and post-image blob object names on the "index"\r
285         line when generating patch format output.\r
286 </simpara>\r
287 </listitem>\r
288 </varlistentry>\r
289 <varlistentry>\r
290 <term>\r
291 --binary\r
292 </term>\r
293 <listitem>\r
294 <simpara>\r
295         In addition to --full-index, output "binary diff" that\r
296         can be applied with "git apply".\r
297 </simpara>\r
298 </listitem>\r
299 </varlistentry>\r
300 <varlistentry>\r
301 <term>\r
302 --abbrev[=&lt;n&gt;]\r
303 </term>\r
304 <listitem>\r
305 <simpara>\r
306         Instead of showing the full 40-byte hexadecimal object\r
307         name in diff-raw format output and diff-tree header\r
308         lines, show only a partial prefix.  This is\r
309         independent of --full-index option above, which controls\r
310         the diff-patch output format.  Non default number of\r
311         digits can be specified with --abbrev=&lt;n&gt;.\r
312 </simpara>\r
313 </listitem>\r
314 </varlistentry>\r
315 <varlistentry>\r
316 <term>\r
317 -B\r
318 </term>\r
319 <listitem>\r
320 <simpara>\r
321         Break complete rewrite changes into pairs of delete and create.\r
322 </simpara>\r
323 </listitem>\r
324 </varlistentry>\r
325 <varlistentry>\r
326 <term>\r
327 -M\r
328 </term>\r
329 <listitem>\r
330 <simpara>\r
331         Detect renames.\r
332 </simpara>\r
333 </listitem>\r
334 </varlistentry>\r
335 <varlistentry>\r
336 <term>\r
337 -C\r
338 </term>\r
339 <listitem>\r
340 <simpara>\r
341         Detect copies as well as renames.  See also <literal>--find-copies-harder</literal>.\r
342 </simpara>\r
343 </listitem>\r
344 </varlistentry>\r
345 <varlistentry>\r
346 <term>\r
347 --diff-filter=[ACDMRTUXB*]\r
348 </term>\r
349 <listitem>\r
350 <simpara>\r
351         Select only files that are Added (<literal>A</literal>), Copied (<literal>C</literal>),\r
352         Deleted (<literal>D</literal>), Modified (<literal>M</literal>), Renamed (<literal>R</literal>), have their\r
353         type (i.e. regular file, symlink, submodule, &#8230;) changed (<literal>T</literal>),\r
354         are Unmerged (<literal>U</literal>), are\r
355         Unknown (<literal>X</literal>), or have had their pairing Broken (<literal>B</literal>).\r
356         Any combination of the filter characters may be used.\r
357         When <literal>*</literal> (All-or-none) is added to the combination, all\r
358         paths are selected if there is any file that matches\r
359         other criteria in the comparison; if there is no file\r
360         that matches other criteria, nothing is selected.\r
361 </simpara>\r
362 </listitem>\r
363 </varlistentry>\r
364 <varlistentry>\r
365 <term>\r
366 --find-copies-harder\r
367 </term>\r
368 <listitem>\r
369 <simpara>\r
370         For performance reasons, by default, <literal>-C</literal> option finds copies only\r
371         if the original file of the copy was modified in the same\r
372         changeset.  This flag makes the command\r
373         inspect unmodified files as candidates for the source of\r
374         copy.  This is a very expensive operation for large\r
375         projects, so use it with caution.  Giving more than one\r
376         <literal>-C</literal> option has the same effect.\r
377 </simpara>\r
378 </listitem>\r
379 </varlistentry>\r
380 <varlistentry>\r
381 <term>\r
382 -l&lt;num&gt;\r
383 </term>\r
384 <listitem>\r
385 <simpara>\r
386         -M and -C options require O(n^2) processing time where n\r
387         is the number of potential rename/copy targets.  This\r
388         option prevents rename/copy detection from running if\r
389         the number of rename/copy targets exceeds the specified\r
390         number.\r
391 </simpara>\r
392 </listitem>\r
393 </varlistentry>\r
394 <varlistentry>\r
395 <term>\r
396 -S&lt;string&gt;\r
397 </term>\r
398 <listitem>\r
399 <simpara>\r
400         Look for differences that contain the change in &lt;string&gt;.\r
401 </simpara>\r
402 </listitem>\r
403 </varlistentry>\r
404 <varlistentry>\r
405 <term>\r
406 --pickaxe-all\r
407 </term>\r
408 <listitem>\r
409 <simpara>\r
410         When -S finds a change, show all the changes in that\r
411         changeset, not just the files that contain the change\r
412         in &lt;string&gt;.\r
413 </simpara>\r
414 </listitem>\r
415 </varlistentry>\r
416 <varlistentry>\r
417 <term>\r
418 --pickaxe-regex\r
419 </term>\r
420 <listitem>\r
421 <simpara>\r
422         Make the &lt;string&gt; not a plain string but an extended POSIX\r
423         regex to match.\r
424 </simpara>\r
425 </listitem>\r
426 </varlistentry>\r
427 <varlistentry>\r
428 <term>\r
429 -O&lt;orderfile&gt;\r
430 </term>\r
431 <listitem>\r
432 <simpara>\r
433         Output the patch in the order specified in the\r
434         &lt;orderfile&gt;, which has one shell glob pattern per line.\r
435 </simpara>\r
436 </listitem>\r
437 </varlistentry>\r
438 <varlistentry>\r
439 <term>\r
440 -R\r
441 </term>\r
442 <listitem>\r
443 <simpara>\r
444         Swap two inputs; that is, show differences from index or\r
445         on-disk file to tree contents.\r
446 </simpara>\r
447 </listitem>\r
448 </varlistentry>\r
449 <varlistentry>\r
450 <term>\r
451 --relative[=&lt;path&gt;]\r
452 </term>\r
453 <listitem>\r
454 <simpara>\r
455         When run from a subdirectory of the project, it can be\r
456         told to exclude changes outside the directory and show\r
457         pathnames relative to it with this option.  When you are\r
458         not in a subdirectory (e.g. in a bare repository), you\r
459         can name which subdirectory to make the output relative\r
460         to by giving a &lt;path&gt; as an argument.\r
461 </simpara>\r
462 </listitem>\r
463 </varlistentry>\r
464 <varlistentry>\r
465 <term>\r
466 -a\r
467 </term>\r
468 <term>\r
469 --text\r
470 </term>\r
471 <listitem>\r
472 <simpara>\r
473         Treat all files as text.\r
474 </simpara>\r
475 </listitem>\r
476 </varlistentry>\r
477 <varlistentry>\r
478 <term>\r
479 --ignore-space-at-eol\r
480 </term>\r
481 <listitem>\r
482 <simpara>\r
483         Ignore changes in whitespace at EOL.\r
484 </simpara>\r
485 </listitem>\r
486 </varlistentry>\r
487 <varlistentry>\r
488 <term>\r
489 -b\r
490 </term>\r
491 <term>\r
492 --ignore-space-change\r
493 </term>\r
494 <listitem>\r
495 <simpara>\r
496         Ignore changes in amount of whitespace.  This ignores whitespace\r
497         at line end, and considers all other sequences of one or\r
498         more whitespace characters to be equivalent.\r
499 </simpara>\r
500 </listitem>\r
501 </varlistentry>\r
502 <varlistentry>\r
503 <term>\r
504 -w\r
505 </term>\r
506 <term>\r
507 --ignore-all-space\r
508 </term>\r
509 <listitem>\r
510 <simpara>\r
511         Ignore whitespace when comparing lines.  This ignores\r
512         differences even if one line has whitespace where the other\r
513         line has none.\r
514 </simpara>\r
515 </listitem>\r
516 </varlistentry>\r
517 <varlistentry>\r
518 <term>\r
519 --inter-hunk-context=&lt;lines&gt;\r
520 </term>\r
521 <listitem>\r
522 <simpara>\r
523         Show the context between diff hunks, up to the specified number\r
524         of lines, thereby fusing hunks that are close to each other.\r
525 </simpara>\r
526 </listitem>\r
527 </varlistentry>\r
528 <varlistentry>\r
529 <term>\r
530 --exit-code\r
531 </term>\r
532 <listitem>\r
533 <simpara>\r
534         Make the program exit with codes similar to diff(1).\r
535         That is, it exits with 1 if there were differences and\r
536         0 means no differences.\r
537 </simpara>\r
538 </listitem>\r
539 </varlistentry>\r
540 <varlistentry>\r
541 <term>\r
542 --quiet\r
543 </term>\r
544 <listitem>\r
545 <simpara>\r
546         Disable all output of the program. Implies --exit-code.\r
547 </simpara>\r
548 </listitem>\r
549 </varlistentry>\r
550 <varlistentry>\r
551 <term>\r
552 --ext-diff\r
553 </term>\r
554 <listitem>\r
555 <simpara>\r
556         Allow an external diff helper to be executed. If you set an\r
557         external diff driver with <xref linkend="gitattributes(5)"/>, you need\r
558         to use this option with <xref linkend="git-log(1)"/> and friends.\r
559 </simpara>\r
560 </listitem>\r
561 </varlistentry>\r
562 <varlistentry>\r
563 <term>\r
564 --no-ext-diff\r
565 </term>\r
566 <listitem>\r
567 <simpara>\r
568         Disallow external diff drivers.\r
569 </simpara>\r
570 </listitem>\r
571 </varlistentry>\r
572 <varlistentry>\r
573 <term>\r
574 --ignore-submodules\r
575 </term>\r
576 <listitem>\r
577 <simpara>\r
578         Ignore changes to submodules in the diff generation.\r
579 </simpara>\r
580 </listitem>\r
581 </varlistentry>\r
582 <varlistentry>\r
583 <term>\r
584 --src-prefix=&lt;prefix&gt;\r
585 </term>\r
586 <listitem>\r
587 <simpara>\r
588         Show the given source prefix instead of "a/".\r
589 </simpara>\r
590 </listitem>\r
591 </varlistentry>\r
592 <varlistentry>\r
593 <term>\r
594 --dst-prefix=&lt;prefix&gt;\r
595 </term>\r
596 <listitem>\r
597 <simpara>\r
598         Show the given destination prefix instead of "b/".\r
599 </simpara>\r
600 </listitem>\r
601 </varlistentry>\r
602 <varlistentry>\r
603 <term>\r
604 --no-prefix\r
605 </term>\r
606 <listitem>\r
607 <simpara>\r
608         Do not show any source or destination prefix.\r
609 </simpara>\r
610 </listitem>\r
611 </varlistentry>\r
612 </variablelist>\r
613 <simpara>For more detailed explanation on these common options, see also\r
614 <xref linkend="gitdiffcore(7)"/>.</simpara>\r
615 <variablelist>\r
616 <varlistentry>\r
617 <term>\r
618 &lt;tree-ish&gt;\r
619 </term>\r
620 <listitem>\r
621 <simpara>\r
622         The id of a tree object.\r
623 </simpara>\r
624 </listitem>\r
625 </varlistentry>\r
626 <varlistentry>\r
627 <term>\r
628 &lt;path&gt;&#8230;\r
629 </term>\r
630 <listitem>\r
631 <simpara>\r
632         If provided, the results are limited to a subset of files\r
633         matching one of these prefix strings.\r
634         i.e., file matches <literal>/^&lt;pattern1&gt;|&lt;pattern2&gt;|&#8230;/</literal>\r
635         Note that this parameter does not provide any wildcard or regexp\r
636         features.\r
637 </simpara>\r
638 </listitem>\r
639 </varlistentry>\r
640 <varlistentry>\r
641 <term>\r
642 -r\r
643 </term>\r
644 <listitem>\r
645 <simpara>\r
646         recurse into sub-trees\r
647 </simpara>\r
648 </listitem>\r
649 </varlistentry>\r
650 <varlistentry>\r
651 <term>\r
652 -t\r
653 </term>\r
654 <listitem>\r
655 <simpara>\r
656         show tree entry itself as well as subtrees.  Implies -r.\r
657 </simpara>\r
658 </listitem>\r
659 </varlistentry>\r
660 <varlistentry>\r
661 <term>\r
662 --root\r
663 </term>\r
664 <listitem>\r
665 <simpara>\r
666         When <emphasis>--root</emphasis> is specified the initial commit will be shown as a big\r
667         creation event. This is equivalent to a diff against the NULL tree.\r
668 </simpara>\r
669 </listitem>\r
670 </varlistentry>\r
671 <varlistentry>\r
672 <term>\r
673 --stdin\r
674 </term>\r
675 <listitem>\r
676 <simpara>\r
677         When <emphasis>--stdin</emphasis> is specified, the command does not take\r
678         &lt;tree-ish&gt; arguments from the command line.  Instead, it\r
679         reads lines containing either two &lt;tree&gt;, one &lt;commit&gt;, or a\r
680         list of &lt;commit&gt; from its standard input.  (Use a single space\r
681         as separator.)\r
682 </simpara>\r
683 <simpara>When two trees are given, it compares the first tree with the second.\r
684 When a single commit is given, it compares the commit with its\r
685 parents.  The remaining commits, when given, are used as if they are\r
686 parents of the first commit.</simpara>\r
687 <simpara>When comparing two trees, the ID of both trees (separated by a space\r
688 and terminated by a newline) is printed before the difference.  When\r
689 comparing commits, the ID of the first (or only) commit, followed by a\r
690 newline, is printed.</simpara>\r
691 <simpara>The following flags further affect the behavior when comparing\r
692 commits (but not trees).</simpara>\r
693 </listitem>\r
694 </varlistentry>\r
695 <varlistentry>\r
696 <term>\r
697 -m\r
698 </term>\r
699 <listitem>\r
700 <simpara>\r
701         By default, <emphasis>git-diff-tree --stdin</emphasis> does not show\r
702         differences for merge commits.  With this flag, it shows\r
703         differences to that commit from all of its parents. See\r
704         also <emphasis>-c</emphasis>.\r
705 </simpara>\r
706 </listitem>\r
707 </varlistentry>\r
708 <varlistentry>\r
709 <term>\r
710 -s\r
711 </term>\r
712 <listitem>\r
713 <simpara>\r
714         By default, <emphasis>git-diff-tree --stdin</emphasis> shows differences,\r
715         either in machine-readable form (without <emphasis>-p</emphasis>) or in patch\r
716         form (with <emphasis>-p</emphasis>).  This output can be suppressed.  It is\r
717         only useful with <emphasis>-v</emphasis> flag.\r
718 </simpara>\r
719 </listitem>\r
720 </varlistentry>\r
721 <varlistentry>\r
722 <term>\r
723 -v\r
724 </term>\r
725 <listitem>\r
726 <simpara>\r
727         This flag causes <emphasis>git-diff-tree --stdin</emphasis> to also show\r
728         the commit message before the differences.\r
729 </simpara>\r
730 </listitem>\r
731 </varlistentry>\r
732 <varlistentry>\r
733 <term>\r
734 --pretty[=<emphasis>&lt;format&gt;</emphasis>]\r
735 </term>\r
736 <listitem>\r
737 <simpara>\r
738         Pretty-print the contents of the commit logs in a given format,\r
739         where <emphasis>&lt;format&gt;</emphasis> can be one of <emphasis>oneline</emphasis>, <emphasis>short</emphasis>, <emphasis>medium</emphasis>,\r
740         <emphasis>full</emphasis>, <emphasis>fuller</emphasis>, <emphasis>email</emphasis>, <emphasis>raw</emphasis> and <emphasis>format:&lt;string&gt;</emphasis>.\r
741         When omitted, the format defaults to <emphasis>medium</emphasis>.\r
742 </simpara>\r
743 <simpara>Note: you can specify the default pretty format in the repository\r
744 configuration (see <xref linkend="git-config(1)"/>).</simpara>\r
745 </listitem>\r
746 </varlistentry>\r
747 <varlistentry>\r
748 <term>\r
749 --abbrev-commit\r
750 </term>\r
751 <listitem>\r
752 <simpara>\r
753         Instead of showing the full 40-byte hexadecimal commit object\r
754         name, show only a partial prefix.  Non default number of\r
755         digits can be specified with "--abbrev=&lt;n&gt;" (which also modifies\r
756         diff output, if it is displayed).\r
757 </simpara>\r
758 <simpara>This should make "--pretty=oneline" a whole lot more readable for\r
759 people using 80-column terminals.</simpara>\r
760 </listitem>\r
761 </varlistentry>\r
762 <varlistentry>\r
763 <term>\r
764 --encoding[=&lt;encoding&gt;]\r
765 </term>\r
766 <listitem>\r
767 <simpara>\r
768         The commit objects record the encoding used for the log message\r
769         in their encoding header; this option can be used to tell the\r
770         command to re-code the commit log message in the encoding\r
771         preferred by the user.  For non plumbing commands this\r
772         defaults to UTF-8.\r
773 </simpara>\r
774 </listitem>\r
775 </varlistentry>\r
776 <varlistentry>\r
777 <term>\r
778 --no-commit-id\r
779 </term>\r
780 <listitem>\r
781 <simpara>\r
782         <emphasis>git-diff-tree</emphasis> outputs a line with the commit ID when\r
783         applicable.  This flag suppressed the commit ID output.\r
784 </simpara>\r
785 </listitem>\r
786 </varlistentry>\r
787 <varlistentry>\r
788 <term>\r
789 -c\r
790 </term>\r
791 <listitem>\r
792 <simpara>\r
793         This flag changes the way a merge commit is displayed\r
794         (which means it is useful only when the command is given\r
795         one &lt;tree-ish&gt;, or <emphasis>--stdin</emphasis>).  It shows the differences\r
796         from each of the parents to the merge result simultaneously\r
797         instead of showing pairwise diff between a parent and the\r
798         result one at a time (which is what the <emphasis>-m</emphasis> option does).\r
799         Furthermore, it lists only files which were modified\r
800         from all parents.\r
801 </simpara>\r
802 </listitem>\r
803 </varlistentry>\r
804 <varlistentry>\r
805 <term>\r
806 --cc\r
807 </term>\r
808 <listitem>\r
809 <simpara>\r
810         This flag changes the way a merge commit patch is displayed,\r
811         in a similar way to the <emphasis>-c</emphasis> option. It implies the <emphasis>-c</emphasis>\r
812         and <emphasis>-p</emphasis> options and further compresses the patch output\r
813         by omitting uninteresting hunks whose the contents in the parents\r
814         have only two variants and the merge result picks one of them\r
815         without modification.  When all hunks are uninteresting, the commit\r
816         itself and the commit log message is not shown, just like in any other\r
817         "empty diff" case.\r
818 </simpara>\r
819 </listitem>\r
820 </varlistentry>\r
821 <varlistentry>\r
822 <term>\r
823 --always\r
824 </term>\r
825 <listitem>\r
826 <simpara>\r
827         Show the commit itself and the commit log message even\r
828         if the diff itself is empty.\r
829 </simpara>\r
830 </listitem>\r
831 </varlistentry>\r
832 </variablelist>\r
833 </simplesect>\r
834 <simplesect id="_pretty_formats">\r
835 <title>PRETTY FORMATS</title>\r
836 <simpara>If the commit is a merge, and if the pretty-format\r
837 is not <emphasis>oneline</emphasis>, <emphasis>email</emphasis> or <emphasis>raw</emphasis>, an additional line is\r
838 inserted before the <emphasis>Author:</emphasis> line.  This line begins with\r
839 "Merge: " and the sha1s of ancestral commits are printed,\r
840 separated by spaces.  Note that the listed commits may not\r
841 necessarily be the list of the <emphasis role="strong">direct</emphasis> parent commits if you\r
842 have limited your view of history: for example, if you are\r
843 only interested in changes related to a certain directory or\r
844 file.</simpara>\r
845 <simpara>Here are some additional details for each format:</simpara>\r
846 <itemizedlist>\r
847 <listitem>\r
848 <simpara>\r
849 <emphasis>oneline</emphasis>\r
850 </simpara>\r
851 <literallayout class="monospaced">&lt;sha1&gt; &lt;title line&gt;</literallayout>\r
852 <simpara>This is designed to be as compact as possible.</simpara>\r
853 </listitem>\r
854 <listitem>\r
855 <simpara>\r
856 <emphasis>short</emphasis>\r
857 </simpara>\r
858 <literallayout class="monospaced">commit &lt;sha1&gt;\r
859 Author: &lt;author&gt;</literallayout>\r
860 <literallayout class="monospaced">&lt;title line&gt;</literallayout>\r
861 </listitem>\r
862 <listitem>\r
863 <simpara>\r
864 <emphasis>medium</emphasis>\r
865 </simpara>\r
866 <literallayout class="monospaced">commit &lt;sha1&gt;\r
867 Author: &lt;author&gt;\r
868 Date:   &lt;author date&gt;</literallayout>\r
869 <literallayout class="monospaced">&lt;title line&gt;</literallayout>\r
870 <literallayout class="monospaced">&lt;full commit message&gt;</literallayout>\r
871 </listitem>\r
872 <listitem>\r
873 <simpara>\r
874 <emphasis>full</emphasis>\r
875 </simpara>\r
876 <literallayout class="monospaced">commit &lt;sha1&gt;\r
877 Author: &lt;author&gt;\r
878 Commit: &lt;committer&gt;</literallayout>\r
879 <literallayout class="monospaced">&lt;title line&gt;</literallayout>\r
880 <literallayout class="monospaced">&lt;full commit message&gt;</literallayout>\r
881 </listitem>\r
882 <listitem>\r
883 <simpara>\r
884 <emphasis>fuller</emphasis>\r
885 </simpara>\r
886 <literallayout class="monospaced">commit &lt;sha1&gt;\r
887 Author:     &lt;author&gt;\r
888 AuthorDate: &lt;author date&gt;\r
889 Commit:     &lt;committer&gt;\r
890 CommitDate: &lt;committer date&gt;</literallayout>\r
891 <literallayout class="monospaced">&lt;title line&gt;</literallayout>\r
892 <literallayout class="monospaced">&lt;full commit message&gt;</literallayout>\r
893 </listitem>\r
894 <listitem>\r
895 <simpara>\r
896 <emphasis>email</emphasis>\r
897 </simpara>\r
898 <literallayout class="monospaced">From &lt;sha1&gt; &lt;date&gt;\r
899 From: &lt;author&gt;\r
900 Date: &lt;author date&gt;\r
901 Subject: [PATCH] &lt;title line&gt;</literallayout>\r
902 <literallayout class="monospaced">&lt;full commit message&gt;</literallayout>\r
903 </listitem>\r
904 <listitem>\r
905 <simpara>\r
906 <emphasis>raw</emphasis>\r
907 </simpara>\r
908 <simpara>The <emphasis>raw</emphasis> format shows the entire commit exactly as\r
909 stored in the commit object.  Notably, the SHA1s are\r
910 displayed in full, regardless of whether --abbrev or\r
911 --no-abbrev are used, and <emphasis>parents</emphasis> information show the\r
912 true parent commits, without taking grafts nor history\r
913 simplification into account.</simpara>\r
914 </listitem>\r
915 <listitem>\r
916 <simpara>\r
917 <emphasis>format:</emphasis>\r
918 </simpara>\r
919 <simpara>The <emphasis>format:</emphasis> format allows you to specify which information\r
920 you want to show. It works a little bit like printf format,\r
921 with the notable exception that you get a newline with <emphasis>%n</emphasis>\r
922 instead of <emphasis>\n</emphasis>.</simpara>\r
923 <simpara>E.g, <emphasis>format:"The author of %h was %an, %ar%nThe title was &gt;&gt;%s&lt;&lt;%n"</emphasis>\r
924 would show something like this:</simpara>\r
925 <literallayout>The author of fe6e0ee was Junio C Hamano, 23 hours ago\r
926 The title was &gt;&gt;t4119: test autocomputing -p&lt;n&gt; for traditional diff input.&lt;&lt;</literallayout>\r
927 <simpara>The placeholders are:</simpara>\r
928 <itemizedlist>\r
929 <listitem>\r
930 <simpara>\r
931 <emphasis>%H</emphasis>: commit hash\r
932 </simpara>\r
933 </listitem>\r
934 <listitem>\r
935 <simpara>\r
936 <emphasis>%h</emphasis>: abbreviated commit hash\r
937 </simpara>\r
938 </listitem>\r
939 <listitem>\r
940 <simpara>\r
941 <emphasis>%T</emphasis>: tree hash\r
942 </simpara>\r
943 </listitem>\r
944 <listitem>\r
945 <simpara>\r
946 <emphasis>%t</emphasis>: abbreviated tree hash\r
947 </simpara>\r
948 </listitem>\r
949 <listitem>\r
950 <simpara>\r
951 <emphasis>%P</emphasis>: parent hashes\r
952 </simpara>\r
953 </listitem>\r
954 <listitem>\r
955 <simpara>\r
956 <emphasis>%p</emphasis>: abbreviated parent hashes\r
957 </simpara>\r
958 </listitem>\r
959 <listitem>\r
960 <simpara>\r
961 <emphasis>%an</emphasis>: author name\r
962 </simpara>\r
963 </listitem>\r
964 <listitem>\r
965 <simpara>\r
966 <emphasis>%aN</emphasis>: author name (respecting .mailmap)\r
967 </simpara>\r
968 </listitem>\r
969 <listitem>\r
970 <simpara>\r
971 <emphasis>%ae</emphasis>: author email\r
972 </simpara>\r
973 </listitem>\r
974 <listitem>\r
975 <simpara>\r
976 <emphasis>%aE</emphasis>: author email (respecting .mailmap)\r
977 </simpara>\r
978 </listitem>\r
979 <listitem>\r
980 <simpara>\r
981 <emphasis>%ad</emphasis>: author date (format respects --date= option)\r
982 </simpara>\r
983 </listitem>\r
984 <listitem>\r
985 <simpara>\r
986 <emphasis>%aD</emphasis>: author date, RFC2822 style\r
987 </simpara>\r
988 </listitem>\r
989 <listitem>\r
990 <simpara>\r
991 <emphasis>%ar</emphasis>: author date, relative\r
992 </simpara>\r
993 </listitem>\r
994 <listitem>\r
995 <simpara>\r
996 <emphasis>%at</emphasis>: author date, UNIX timestamp\r
997 </simpara>\r
998 </listitem>\r
999 <listitem>\r
1000 <simpara>\r
1001 <emphasis>%ai</emphasis>: author date, ISO 8601 format\r
1002 </simpara>\r
1003 </listitem>\r
1004 <listitem>\r
1005 <simpara>\r
1006 <emphasis>%cn</emphasis>: committer name\r
1007 </simpara>\r
1008 </listitem>\r
1009 <listitem>\r
1010 <simpara>\r
1011 <emphasis>%cN</emphasis>: committer name (respecting .mailmap)\r
1012 </simpara>\r
1013 </listitem>\r
1014 <listitem>\r
1015 <simpara>\r
1016 <emphasis>%ce</emphasis>: committer email\r
1017 </simpara>\r
1018 </listitem>\r
1019 <listitem>\r
1020 <simpara>\r
1021 <emphasis>%cE</emphasis>: committer email (respecting .mailmap)\r
1022 </simpara>\r
1023 </listitem>\r
1024 <listitem>\r
1025 <simpara>\r
1026 <emphasis>%cd</emphasis>: committer date\r
1027 </simpara>\r
1028 </listitem>\r
1029 <listitem>\r
1030 <simpara>\r
1031 <emphasis>%cD</emphasis>: committer date, RFC2822 style\r
1032 </simpara>\r
1033 </listitem>\r
1034 <listitem>\r
1035 <simpara>\r
1036 <emphasis>%cr</emphasis>: committer date, relative\r
1037 </simpara>\r
1038 </listitem>\r
1039 <listitem>\r
1040 <simpara>\r
1041 <emphasis>%ct</emphasis>: committer date, UNIX timestamp\r
1042 </simpara>\r
1043 </listitem>\r
1044 <listitem>\r
1045 <simpara>\r
1046 <emphasis>%ci</emphasis>: committer date, ISO 8601 format\r
1047 </simpara>\r
1048 </listitem>\r
1049 <listitem>\r
1050 <simpara>\r
1051 <emphasis>%d</emphasis>: ref names, like the --decorate option of <xref linkend="git-log(1)"/>\r
1052 </simpara>\r
1053 </listitem>\r
1054 <listitem>\r
1055 <simpara>\r
1056 <emphasis>%e</emphasis>: encoding\r
1057 </simpara>\r
1058 </listitem>\r
1059 <listitem>\r
1060 <simpara>\r
1061 <emphasis>%s</emphasis>: subject\r
1062 </simpara>\r
1063 </listitem>\r
1064 <listitem>\r
1065 <simpara>\r
1066 <emphasis>%b</emphasis>: body\r
1067 </simpara>\r
1068 </listitem>\r
1069 <listitem>\r
1070 <simpara>\r
1071 <emphasis>%Cred</emphasis>: switch color to red\r
1072 </simpara>\r
1073 </listitem>\r
1074 <listitem>\r
1075 <simpara>\r
1076 <emphasis>%Cgreen</emphasis>: switch color to green\r
1077 </simpara>\r
1078 </listitem>\r
1079 <listitem>\r
1080 <simpara>\r
1081 <emphasis>%Cblue</emphasis>: switch color to blue\r
1082 </simpara>\r
1083 </listitem>\r
1084 <listitem>\r
1085 <simpara>\r
1086 <emphasis>%Creset</emphasis>: reset color\r
1087 </simpara>\r
1088 </listitem>\r
1089 <listitem>\r
1090 <simpara>\r
1091 <emphasis>%C(&#8230;)</emphasis>: color specification, as described in color.branch.* config option\r
1092 </simpara>\r
1093 </listitem>\r
1094 <listitem>\r
1095 <simpara>\r
1096 <emphasis>%m</emphasis>: left, right or boundary mark\r
1097 </simpara>\r
1098 </listitem>\r
1099 <listitem>\r
1100 <simpara>\r
1101 <emphasis>%n</emphasis>: newline\r
1102 </simpara>\r
1103 </listitem>\r
1104 <listitem>\r
1105 <simpara>\r
1106 <emphasis>%x00</emphasis>: print a byte from a hex code\r
1107 </simpara>\r
1108 </listitem>\r
1109 </itemizedlist>\r
1110 </listitem>\r
1111 <listitem>\r
1112 <simpara>\r
1113 <emphasis>tformat:</emphasis>\r
1114 </simpara>\r
1115 <simpara>The <emphasis>tformat:</emphasis> format works exactly like <emphasis>format:</emphasis>, except that it\r
1116 provides "terminator" semantics instead of "separator" semantics. In\r
1117 other words, each commit has the message terminator character (usually a\r
1118 newline) appended, rather than a separator placed between entries.\r
1119 This means that the final entry of a single-line format will be properly\r
1120 terminated with a new line, just as the "oneline" format does.\r
1121 For example:</simpara>\r
1122 <literallayout>$ git log -2 --pretty=format:%h 4da45bef \\r
1123   | perl -pe '$_ .= " -- NO NEWLINE\n" unless /\n/'\r
1124 4da45be\r
1125 7134973 -- NO NEWLINE\r
1126 \r
1127 $ git log -2 --pretty=tformat:%h 4da45bef \\r
1128   | perl -pe '$_ .= " -- NO NEWLINE\n" unless /\n/'\r
1129 4da45be\r
1130 7134973</literallayout>\r
1131 </listitem>\r
1132 </itemizedlist>\r
1133 </simplesect>\r
1134 <simplesect id="_limiting_output">\r
1135 <title>Limiting Output</title>\r
1136 <simpara>If you&#8217;re only interested in differences in a subset of files, for\r
1137 example some architecture-specific files, you might do:</simpara>\r
1138 <literallayout class="monospaced">git diff-tree -r &lt;tree-ish&gt; &lt;tree-ish&gt; arch/ia64 include/asm-ia64</literallayout>\r
1139 <simpara>and it will only show you what changed in those two directories.</simpara>\r
1140 <simpara>Or if you are searching for what changed in just <literal>kernel/sched.c</literal>, just do</simpara>\r
1141 <literallayout class="monospaced">git diff-tree -r &lt;tree-ish&gt; &lt;tree-ish&gt; kernel/sched.c</literallayout>\r
1142 <simpara>and it will ignore all differences to other files.</simpara>\r
1143 <simpara>The pattern is always the prefix, and is matched exactly.  There are no\r
1144 wildcards.  Even stricter, it has to match a complete path component.\r
1145 I.e. "foo" does not pick up <literal>foobar.h</literal>.  "foo" does match <literal>foo/bar.h</literal>\r
1146 so it can be used to name subdirectories.</simpara>\r
1147 <simpara>An example of normal usage is:</simpara>\r
1148 <literallayout class="monospaced">torvalds@ppc970:~/git&gt; git diff-tree 5319e4......\r
1149 *100664-&gt;100664 blob    ac348b.......-&gt;a01513.......      git-fsck-objects.c</literallayout>\r
1150 <simpara>which tells you that the last commit changed just one file (it&#8217;s from\r
1151 this one:</simpara>\r
1152 <literallayout>commit 3c6f7ca19ad4043e9e72fa94106f352897e651a8\r
1153 tree 5319e4d609cdd282069cc4dce33c1db559539b03\r
1154 parent b4e628ea30d5ab3606119d2ea5caeab141d38df7\r
1155 author Linus Torvalds &lt;torvalds@ppc970.osdl.org&gt; Sat Apr 9 12:02:30 2005\r
1156 committer Linus Torvalds &lt;torvalds@ppc970.osdl.org&gt; Sat Apr 9 12:02:30 2005\r
1157 \r
1158 Make "git-fsck-objects" print out all the root commits it finds.\r
1159 \r
1160 Once I do the reference tracking, I'll also make it print out all the\r
1161 HEAD commits it finds, which is even more interesting.</literallayout>\r
1162 <simpara>in case you care).</simpara>\r
1163 </simplesect>\r
1164 <simplesect id="_output_format">\r
1165 <title>Output format</title>\r
1166 <simpara>The output format from "git-diff-index", "git-diff-tree",\r
1167 "git-diff-files" and "git diff --raw" are very similar.</simpara>\r
1168 <simpara>These commands all compare two sets of things; what is\r
1169 compared differs:</simpara>\r
1170 <variablelist>\r
1171 <varlistentry>\r
1172 <term>\r
1173 git-diff-index &lt;tree-ish&gt;\r
1174 </term>\r
1175 <listitem>\r
1176 <simpara>\r
1177         compares the &lt;tree-ish&gt; and the files on the filesystem.\r
1178 </simpara>\r
1179 </listitem>\r
1180 </varlistentry>\r
1181 <varlistentry>\r
1182 <term>\r
1183 git-diff-index --cached &lt;tree-ish&gt;\r
1184 </term>\r
1185 <listitem>\r
1186 <simpara>\r
1187         compares the &lt;tree-ish&gt; and the index.\r
1188 </simpara>\r
1189 </listitem>\r
1190 </varlistentry>\r
1191 <varlistentry>\r
1192 <term>\r
1193 git-diff-tree [-r] &lt;tree-ish-1&gt; &lt;tree-ish-2&gt; [&lt;pattern&gt;&#8230;]\r
1194 </term>\r
1195 <listitem>\r
1196 <simpara>\r
1197         compares the trees named by the two arguments.\r
1198 </simpara>\r
1199 </listitem>\r
1200 </varlistentry>\r
1201 <varlistentry>\r
1202 <term>\r
1203 git-diff-files [&lt;pattern&gt;&#8230;]\r
1204 </term>\r
1205 <listitem>\r
1206 <simpara>\r
1207         compares the index and the files on the filesystem.\r
1208 </simpara>\r
1209 </listitem>\r
1210 </varlistentry>\r
1211 </variablelist>\r
1212 <simpara>An output line is formatted this way:</simpara>\r
1213 <literallayout>in-place edit  :100644 100644 bcd1234... 0123456... M file0\r
1214 copy-edit      :100644 100644 abcd123... 1234567... C68 file1 file2\r
1215 rename-edit    :100644 100644 abcd123... 1234567... R86 file1 file3\r
1216 create         :000000 100644 0000000... 1234567... A file4\r
1217 delete         :100644 000000 1234567... 0000000... D file5\r
1218 unmerged       :000000 000000 0000000... 0000000... U file6</literallayout>\r
1219 <simpara>That is, from the left to the right:</simpara>\r
1220 <orderedlist numeration="arabic">\r
1221 <listitem>\r
1222 <simpara>\r
1223 a colon.\r
1224 </simpara>\r
1225 </listitem>\r
1226 <listitem>\r
1227 <simpara>\r
1228 mode for "src"; 000000 if creation or unmerged.\r
1229 </simpara>\r
1230 </listitem>\r
1231 <listitem>\r
1232 <simpara>\r
1233 a space.\r
1234 </simpara>\r
1235 </listitem>\r
1236 <listitem>\r
1237 <simpara>\r
1238 mode for "dst"; 000000 if deletion or unmerged.\r
1239 </simpara>\r
1240 </listitem>\r
1241 <listitem>\r
1242 <simpara>\r
1243 a space.\r
1244 </simpara>\r
1245 </listitem>\r
1246 <listitem>\r
1247 <simpara>\r
1248 sha1 for "src"; 0{40} if creation or unmerged.\r
1249 </simpara>\r
1250 </listitem>\r
1251 <listitem>\r
1252 <simpara>\r
1253 a space.\r
1254 </simpara>\r
1255 </listitem>\r
1256 <listitem>\r
1257 <simpara>\r
1258 sha1 for "dst"; 0{40} if creation, unmerged or "look at work tree".\r
1259 </simpara>\r
1260 </listitem>\r
1261 <listitem>\r
1262 <simpara>\r
1263 a space.\r
1264 </simpara>\r
1265 </listitem>\r
1266 <listitem>\r
1267 <simpara>\r
1268 status, followed by optional "score" number.\r
1269 </simpara>\r
1270 </listitem>\r
1271 <listitem>\r
1272 <simpara>\r
1273 a tab or a NUL when <emphasis>-z</emphasis> option is used.\r
1274 </simpara>\r
1275 </listitem>\r
1276 <listitem>\r
1277 <simpara>\r
1278 path for "src"\r
1279 </simpara>\r
1280 </listitem>\r
1281 <listitem>\r
1282 <simpara>\r
1283 a tab or a NUL when <emphasis>-z</emphasis> option is used; only exists for C or R.\r
1284 </simpara>\r
1285 </listitem>\r
1286 <listitem>\r
1287 <simpara>\r
1288 path for "dst"; only exists for C or R.\r
1289 </simpara>\r
1290 </listitem>\r
1291 <listitem>\r
1292 <simpara>\r
1293 an LF or a NUL when <emphasis>-z</emphasis> option is used, to terminate the record.\r
1294 </simpara>\r
1295 </listitem>\r
1296 </orderedlist>\r
1297 <simpara>Possible status letters are:</simpara>\r
1298 <itemizedlist>\r
1299 <listitem>\r
1300 <simpara>\r
1301 A: addition of a file\r
1302 </simpara>\r
1303 </listitem>\r
1304 <listitem>\r
1305 <simpara>\r
1306 C: copy of a file into a new one\r
1307 </simpara>\r
1308 </listitem>\r
1309 <listitem>\r
1310 <simpara>\r
1311 D: deletion of a file\r
1312 </simpara>\r
1313 </listitem>\r
1314 <listitem>\r
1315 <simpara>\r
1316 M: modification of the contents or mode of a file\r
1317 </simpara>\r
1318 </listitem>\r
1319 <listitem>\r
1320 <simpara>\r
1321 R: renaming of a file\r
1322 </simpara>\r
1323 </listitem>\r
1324 <listitem>\r
1325 <simpara>\r
1326 T: change in the type of the file\r
1327 </simpara>\r
1328 </listitem>\r
1329 <listitem>\r
1330 <simpara>\r
1331 U: file is unmerged (you must complete the merge before it can\r
1332 be committed)\r
1333 </simpara>\r
1334 </listitem>\r
1335 <listitem>\r
1336 <simpara>\r
1337 X: "unknown" change type (most probably a bug, please report it)\r
1338 </simpara>\r
1339 </listitem>\r
1340 </itemizedlist>\r
1341 <simpara>Status letters C and R are always followed by a score (denoting the\r
1342 percentage of similarity between the source and target of the move or\r
1343 copy), and are the only ones to be so.</simpara>\r
1344 <simpara>&lt;sha1&gt; is shown as all 0&#8217;s if a file is new on the filesystem\r
1345 and it is out of sync with the index.</simpara>\r
1346 <simpara>Example:</simpara>\r
1347 <literallayout>:100644 100644 5be4a4...... 000000...... M file.c</literallayout>\r
1348 <simpara>When <literal>-z</literal> option is not used, TAB, LF, and backslash characters\r
1349 in pathnames are represented as <literal>\t</literal>, <literal>\n</literal>, and <literal>\\</literal>,\r
1350 respectively.</simpara>\r
1351 </simplesect>\r
1352 <simplesect id="_diff_format_for_merges">\r
1353 <title>diff format for merges</title>\r
1354 <simpara>"git-diff-tree", "git-diff-files" and "git-diff --raw"\r
1355 can take <emphasis>-c</emphasis> or <emphasis>--cc</emphasis> option\r
1356 to generate diff output also for merge commits.  The output differs\r
1357 from the format described above in the following way:</simpara>\r
1358 <orderedlist numeration="arabic">\r
1359 <listitem>\r
1360 <simpara>\r
1361 there is a colon for each parent\r
1362 </simpara>\r
1363 </listitem>\r
1364 <listitem>\r
1365 <simpara>\r
1366 there are more "src" modes and "src" sha1\r
1367 </simpara>\r
1368 </listitem>\r
1369 <listitem>\r
1370 <simpara>\r
1371 status is concatenated status characters for each parent\r
1372 </simpara>\r
1373 </listitem>\r
1374 <listitem>\r
1375 <simpara>\r
1376 no optional "score" number\r
1377 </simpara>\r
1378 </listitem>\r
1379 <listitem>\r
1380 <simpara>\r
1381 single path, only for "dst"\r
1382 </simpara>\r
1383 </listitem>\r
1384 </orderedlist>\r
1385 <simpara>Example:</simpara>\r
1386 <literallayout>::100644 100644 100644 fabadb8... cc95eb0... 4866510... MM      describe.c</literallayout>\r
1387 <simpara>Note that <emphasis>combined diff</emphasis> lists only files which were modified from\r
1388 all parents.</simpara>\r
1389 </simplesect>\r
1390 <simplesect id="_generating_patches_with_p">\r
1391 <title>Generating patches with -p</title>\r
1392 <simpara>When "git-diff-index", "git-diff-tree", or "git-diff-files" are run\r
1393 with a <emphasis>-p</emphasis> option, "git diff" without the <emphasis>--raw</emphasis> option, or\r
1394 "git log" with the "-p" option, they\r
1395 do not produce the output described above; instead they produce a\r
1396 patch file.  You can customize the creation of such patches via the\r
1397 GIT_EXTERNAL_DIFF and the GIT_DIFF_OPTS environment variables.</simpara>\r
1398 <simpara>What the -p option produces is slightly different from the traditional\r
1399 diff format.</simpara>\r
1400 <orderedlist numeration="arabic">\r
1401 <listitem>\r
1402 <simpara>\r
1403 It is preceded with a "git diff" header, that looks like\r
1404      this:\r
1405 </simpara>\r
1406 <literallayout class="monospaced">diff --git a/file1 b/file2</literallayout>\r
1407 <simpara>The <literal>a/</literal> and <literal>b/</literal> filenames are the same unless rename/copy is\r
1408 involved.  Especially, even for a creation or a deletion,\r
1409 <literal>/dev/null</literal> is <emphasis>not</emphasis> used in place of <literal>a/</literal> or <literal>b/</literal> filenames.</simpara>\r
1410 <simpara>When rename/copy is involved, <literal>file1</literal> and <literal>file2</literal> show the\r
1411 name of the source file of the rename/copy and the name of\r
1412 the file that rename/copy produces, respectively.</simpara>\r
1413 </listitem>\r
1414 <listitem>\r
1415 <simpara>\r
1416 It is followed by one or more extended header lines:\r
1417 </simpara>\r
1418 <literallayout class="monospaced">old mode &lt;mode&gt;\r
1419 new mode &lt;mode&gt;\r
1420 deleted file mode &lt;mode&gt;\r
1421 new file mode &lt;mode&gt;\r
1422 copy from &lt;path&gt;\r
1423 copy to &lt;path&gt;\r
1424 rename from &lt;path&gt;\r
1425 rename to &lt;path&gt;\r
1426 similarity index &lt;number&gt;\r
1427 dissimilarity index &lt;number&gt;\r
1428 index &lt;hash&gt;..&lt;hash&gt; &lt;mode&gt;</literallayout>\r
1429 </listitem>\r
1430 <listitem>\r
1431 <simpara>\r
1432 TAB, LF, double quote and backslash characters in pathnames\r
1433     are represented as <literal>\t</literal>, <literal>\n</literal>, <literal>\"</literal> and <literal>\\</literal>, respectively.\r
1434     If there is need for such substitution then the whole\r
1435     pathname is put in double quotes.\r
1436 </simpara>\r
1437 </listitem>\r
1438 </orderedlist>\r
1439 <simpara>The similarity index is the percentage of unchanged lines, and\r
1440 the dissimilarity index is the percentage of changed lines.  It\r
1441 is a rounded down integer, followed by a percent sign.  The\r
1442 similarity index value of 100% is thus reserved for two equal\r
1443 files, while 100% dissimilarity means that no line from the old\r
1444 file made it into the new one.</simpara>\r
1445 </simplesect>\r
1446 <simplesect id="_combined_diff_format">\r
1447 <title>combined diff format</title>\r
1448 <simpara>"git-diff-tree", "git-diff-files" and "git-diff" can take <emphasis>-c</emphasis> or\r
1449 <emphasis>--cc</emphasis> option to produce <emphasis>combined diff</emphasis>.  For showing a merge commit\r
1450 with "git log -p", this is the default format.\r
1451 A <emphasis>combined diff</emphasis> format looks like this:</simpara>\r
1452 <literallayout>diff --combined describe.c\r
1453 index fabadb8,cc95eb0..4866510\r
1454 --- a/describe.c\r
1455 +++ b/describe.c\r
1456 @@@ -98,20 -98,12 +98,20 @@@\r
1457         return (a_date &gt; b_date) ? -1 : (a_date == b_date) ? 0 : 1;\r
1458   }\r
1459 \r
1460 - static void describe(char *arg)\r
1461  -static void describe(struct commit *cmit, int last_one)\r
1462 ++static void describe(char *arg, int last_one)\r
1463   {\r
1464  +      unsigned char sha1[20];\r
1465  +      struct commit *cmit;\r
1466         struct commit_list *list;\r
1467         static int initialized = 0;\r
1468         struct commit_name *n;\r
1469 \r
1470  +      if (get_sha1(arg, sha1) &lt; 0)\r
1471  +              usage(describe_usage);\r
1472  +      cmit = lookup_commit_reference(sha1);\r
1473  +      if (!cmit)\r
1474  +              usage(describe_usage);\r
1475  +\r
1476         if (!initialized) {\r
1477                 initialized = 1;\r
1478                 for_each_ref(get_name);</literallayout>\r
1479 <orderedlist numeration="arabic">\r
1480 <listitem>\r
1481 <simpara>\r
1482 It is preceded with a "git diff" header, that looks like\r
1483      this (when <emphasis>-c</emphasis> option is used):\r
1484 </simpara>\r
1485 <literallayout class="monospaced">diff --combined file</literallayout>\r
1486 <simpara>or like this (when <emphasis>--cc</emphasis> option is used):</simpara>\r
1487 <literallayout class="monospaced">diff --cc file</literallayout>\r
1488 </listitem>\r
1489 <listitem>\r
1490 <simpara>\r
1491 It is followed by one or more extended header lines\r
1492      (this example shows a merge with two parents):\r
1493 </simpara>\r
1494 <literallayout class="monospaced">index &lt;hash&gt;,&lt;hash&gt;..&lt;hash&gt;\r
1495 mode &lt;mode&gt;,&lt;mode&gt;..&lt;mode&gt;\r
1496 new file mode &lt;mode&gt;\r
1497 deleted file mode &lt;mode&gt;,&lt;mode&gt;</literallayout>\r
1498 <simpara>The <literal>mode &lt;mode&gt;,&lt;mode&gt;..&lt;mode&gt;</literal> line appears only if at least one of\r
1499 the &lt;mode&gt; is different from the rest. Extended headers with\r
1500 information about detected contents movement (renames and\r
1501 copying detection) are designed to work with diff of two\r
1502 &lt;tree-ish&gt; and are not used by combined diff format.</simpara>\r
1503 </listitem>\r
1504 <listitem>\r
1505 <simpara>\r
1506 It is followed by two-line from-file/to-file header\r
1507 </simpara>\r
1508 <literallayout class="monospaced">--- a/file\r
1509 +++ b/file</literallayout>\r
1510 <simpara>Similar to two-line header for traditional <emphasis>unified</emphasis> diff\r
1511 format, <literal>/dev/null</literal> is used to signal created or deleted\r
1512 files.</simpara>\r
1513 </listitem>\r
1514 <listitem>\r
1515 <simpara>\r
1516 Chunk header format is modified to prevent people from\r
1517      accidentally feeding it to <literal>patch -p1</literal>. Combined diff format\r
1518      was created for review of merge commit changes, and was not\r
1519      meant for apply. The change is similar to the change in the\r
1520      extended <emphasis>index</emphasis> header:\r
1521 </simpara>\r
1522 <literallayout class="monospaced">@@@ &lt;from-file-range&gt; &lt;from-file-range&gt; &lt;to-file-range&gt; @@@</literallayout>\r
1523 <simpara>There are (number of parents + 1) <literal>@</literal> characters in the chunk\r
1524 header for combined diff format.</simpara>\r
1525 </listitem>\r
1526 </orderedlist>\r
1527 <simpara>Unlike the traditional <emphasis>unified</emphasis> diff format, which shows two\r
1528 files A and B with a single column that has <literal>-</literal> (minus&#8201;&#8212;&#8201;appears in A but removed in B), <literal>+</literal> (plus&#8201;&#8212;&#8201;missing in A but\r
1529 added to B), or <literal>" "</literal> (space&#8201;&#8212;&#8201;unchanged) prefix, this format\r
1530 compares two or more files file1, file2,&#8230; with one file X, and\r
1531 shows how X differs from each of fileN.  One column for each of\r
1532 fileN is prepended to the output line to note how X&#8217;s line is\r
1533 different from it.</simpara>\r
1534 <simpara>A <literal>-</literal> character in the column N means that the line appears in\r
1535 fileN but it does not appear in the result.  A <literal>+</literal> character\r
1536 in the column N means that the line appears in the result,\r
1537 and fileN does not have that line (in other words, the line was\r
1538 added, from the point of view of that parent).</simpara>\r
1539 <simpara>In the above example output, the function signature was changed\r
1540 from both files (hence two <literal>-</literal> removals from both file1 and\r
1541 file2, plus <literal>++</literal> to mean one line that was added does not appear\r
1542 in either file1 nor file2).  Also eight other lines are the same\r
1543 from file1 but do not appear in file2 (hence prefixed with <literal>&#43;</literal>).</simpara>\r
1544 <simpara>When shown by <literal>git diff-tree -c</literal>, it compares the parents of a\r
1545 merge commit with the merge result (i.e. file1..fileN are the\r
1546 parents).  When shown by <literal>git diff-files -c</literal>, it compares the\r
1547 two unresolved merge parents with the working tree file\r
1548 (i.e. file1 is stage 2 aka "our version", file2 is stage 3 aka\r
1549 "their version").</simpara>\r
1550 </simplesect>\r
1551 <simplesect id="_other_diff_formats">\r
1552 <title>other diff formats</title>\r
1553 <simpara>The <literal>--summary</literal> option describes newly added, deleted, renamed and\r
1554 copied files.  The <literal>--stat</literal> option adds diffstat(1) graph to the\r
1555 output.  These options can be combined with other options, such as\r
1556 <literal>-p</literal>, and are meant for human consumption.</simpara>\r
1557 <simpara>When showing a change that involves a rename or a copy, <literal>--stat</literal> output\r
1558 formats the pathnames compactly by combining common prefix and suffix of\r
1559 the pathnames.  For example, a change that moves <literal>arch/i386/Makefile</literal> to\r
1560 <literal>arch/x86/Makefile</literal> while modifying 4 lines will be shown like this:</simpara>\r
1561 <literallayout>arch/{i386 =&gt; x86}/Makefile    |   4 +--</literallayout>\r
1562 <simpara>The <literal>--numstat</literal> option gives the diffstat(1) information but is designed\r
1563 for easier machine consumption.  An entry in <literal>--numstat</literal> output looks\r
1564 like this:</simpara>\r
1565 <literallayout>1       2       README\r
1566 3       1       arch/{i386 =&gt; x86}/Makefile</literallayout>\r
1567 <simpara>That is, from left to right:</simpara>\r
1568 <orderedlist numeration="arabic">\r
1569 <listitem>\r
1570 <simpara>\r
1571 the number of added lines;\r
1572 </simpara>\r
1573 </listitem>\r
1574 <listitem>\r
1575 <simpara>\r
1576 a tab;\r
1577 </simpara>\r
1578 </listitem>\r
1579 <listitem>\r
1580 <simpara>\r
1581 the number of deleted lines;\r
1582 </simpara>\r
1583 </listitem>\r
1584 <listitem>\r
1585 <simpara>\r
1586 a tab;\r
1587 </simpara>\r
1588 </listitem>\r
1589 <listitem>\r
1590 <simpara>\r
1591 pathname (possibly with rename/copy information);\r
1592 </simpara>\r
1593 </listitem>\r
1594 <listitem>\r
1595 <simpara>\r
1596 a newline.\r
1597 </simpara>\r
1598 </listitem>\r
1599 </orderedlist>\r
1600 <simpara>When <literal>-z</literal> output option is in effect, the output is formatted this way:</simpara>\r
1601 <literallayout>1       2       README NUL\r
1602 3       1       NUL arch/i386/Makefile NUL arch/x86/Makefile NUL</literallayout>\r
1603 <simpara>That is:</simpara>\r
1604 <orderedlist numeration="arabic">\r
1605 <listitem>\r
1606 <simpara>\r
1607 the number of added lines;\r
1608 </simpara>\r
1609 </listitem>\r
1610 <listitem>\r
1611 <simpara>\r
1612 a tab;\r
1613 </simpara>\r
1614 </listitem>\r
1615 <listitem>\r
1616 <simpara>\r
1617 the number of deleted lines;\r
1618 </simpara>\r
1619 </listitem>\r
1620 <listitem>\r
1621 <simpara>\r
1622 a tab;\r
1623 </simpara>\r
1624 </listitem>\r
1625 <listitem>\r
1626 <simpara>\r
1627 a NUL (only exists if renamed/copied);\r
1628 </simpara>\r
1629 </listitem>\r
1630 <listitem>\r
1631 <simpara>\r
1632 pathname in preimage;\r
1633 </simpara>\r
1634 </listitem>\r
1635 <listitem>\r
1636 <simpara>\r
1637 a NUL (only exists if renamed/copied);\r
1638 </simpara>\r
1639 </listitem>\r
1640 <listitem>\r
1641 <simpara>\r
1642 pathname in postimage (only exists if renamed/copied);\r
1643 </simpara>\r
1644 </listitem>\r
1645 <listitem>\r
1646 <simpara>\r
1647 a NUL.\r
1648 </simpara>\r
1649 </listitem>\r
1650 </orderedlist>\r
1651 <simpara>The extra <literal>NUL</literal> before the preimage path in renamed case is to allow\r
1652 scripts that read the output to tell if the current record being read is\r
1653 a single-path record or a rename/copy record without reading ahead.\r
1654 After reading added and deleted lines, reading up to <literal>NUL</literal> would yield\r
1655 the pathname, but if that is <literal>NUL</literal>, the record will show two paths.</simpara>\r
1656 </simplesect>\r
1657 <simplesect id="_author">\r
1658 <title>Author</title>\r
1659 <simpara>Written by Linus Torvalds &lt;<ulink url="mailto:torvalds@osdl.org">torvalds@osdl.org</ulink>&gt;</simpara>\r
1660 </simplesect>\r
1661 <simplesect id="_documentation">\r
1662 <title>Documentation</title>\r
1663 <simpara>Documentation by David Greaves, Junio C Hamano and the git-list &lt;<ulink url="mailto:git@vger.kernel.org">git@vger.kernel.org</ulink>&gt;.</simpara>\r
1664 </simplesect>\r
1665 <simplesect id="_git">\r
1666 <title>GIT</title>\r
1667 <simpara>Part of the <xref linkend="git(1)"/> suite</simpara>\r
1668 </simplesect>\r
1669 </article>\r