Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 1 | git-check-attr(1) |
| 2 | ================= |
| 3 | |
| 4 | NAME |
| 5 | ---- |
Junio C Hamano | 9bd39c4 | 2008-11-13 01:54:44 | [diff] [blame] | 6 | git-check-attr - Display gitattributes information |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 7 | |
| 8 | |
| 9 | SYNOPSIS |
| 10 | -------- |
Junio C Hamano | 7d06a8a | 2008-10-20 05:42:33 | [diff] [blame] | 11 | [verse] |
Junio C Hamano | c9cb517 | 2018-06-01 07:13:44 | [diff] [blame] | 12 | 'git check-attr' [-a | --all | <attr>...] [--] <pathname>... |
| 13 | 'git check-attr' --stdin [-z] [-a | --all | <attr>...] |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 14 | |
| 15 | DESCRIPTION |
| 16 | ----------- |
Junio C Hamano | 1de7572 | 2009-03-26 08:39:38 | [diff] [blame] | 17 | For every pathname, this command will list if each attribute is 'unspecified', |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 18 | 'set', or 'unset' as a gitattribute on that pathname. |
| 19 | |
| 20 | OPTIONS |
| 21 | ------- |
Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 22 | -a, --all:: |
| 23 | List all attributes that are associated with the specified |
| 24 | paths. If this option is used, then 'unspecified' attributes |
| 25 | will not be included in the output. |
| 26 | |
Junio C Hamano | 8fb66e5 | 2011-10-05 20:59:51 | [diff] [blame] | 27 | --cached:: |
| 28 | Consider `.gitattributes` in the index only, ignoring the working tree. |
| 29 | |
Junio C Hamano | 7d06a8a | 2008-10-20 05:42:33 | [diff] [blame] | 30 | --stdin:: |
Junio C Hamano | daf0aae | 2015-10-26 23:14:30 | [diff] [blame] | 31 | Read pathnames from the standard input, one per line, |
| 32 | instead of from the command-line. |
Junio C Hamano | 7d06a8a | 2008-10-20 05:42:33 | [diff] [blame] | 33 | |
| 34 | -z:: |
Junio C Hamano | 535ed7a | 2013-09-04 20:35:57 | [diff] [blame] | 35 | The output format is modified to be machine-parseable. |
| 36 | If `--stdin` is also given, input paths are separated |
| 37 | with a NUL character instead of a linefeed character. |
Junio C Hamano | 7d06a8a | 2008-10-20 05:42:33 | [diff] [blame] | 38 | |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 39 | \--:: |
Junio C Hamano | 1de7572 | 2009-03-26 08:39:38 | [diff] [blame] | 40 | Interpret all preceding arguments as attributes and all following |
Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 41 | arguments as path names. |
| 42 | |
| 43 | If none of `--stdin`, `--all`, or `--` is used, the first argument |
| 44 | will be treated as an attribute and the rest of the arguments as |
| 45 | pathnames. |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 46 | |
Junio C Hamano | cbb3086 | 2008-10-17 10:03:42 | [diff] [blame] | 47 | OUTPUT |
| 48 | ------ |
| 49 | |
| 50 | The output is of the form: |
| 51 | <path> COLON SP <attribute> COLON SP <info> LF |
| 52 | |
Junio C Hamano | 535ed7a | 2013-09-04 20:35:57 | [diff] [blame] | 53 | unless `-z` is in effect, in which case NUL is used as delimiter: |
| 54 | <path> NUL <attribute> NUL <info> NUL |
| 55 | |
| 56 | |
Junio C Hamano | 1de7572 | 2009-03-26 08:39:38 | [diff] [blame] | 57 | <path> is the path of a file being queried, <attribute> is an attribute |
Junio C Hamano | cbb3086 | 2008-10-17 10:03:42 | [diff] [blame] | 58 | being queried and <info> can be either: |
| 59 | |
| 60 | 'unspecified';; when the attribute is not defined for the path. |
Junio C Hamano | 1de7572 | 2009-03-26 08:39:38 | [diff] [blame] | 61 | 'unset';; when the attribute is defined as false. |
| 62 | 'set';; when the attribute is defined as true. |
Junio C Hamano | cbb3086 | 2008-10-17 10:03:42 | [diff] [blame] | 63 | <value>;; when a value has been assigned to the attribute. |
| 64 | |
Junio C Hamano | c710296 | 2013-05-29 23:57:17 | [diff] [blame] | 65 | Buffering happens as documented under the `GIT_FLUSH` option in |
| 66 | linkgit:git[1]. The caller is responsible for avoiding deadlocks |
| 67 | caused by overfilling an input buffer or reading from an empty output |
| 68 | buffer. |
| 69 | |
Junio C Hamano | cbb3086 | 2008-10-17 10:03:42 | [diff] [blame] | 70 | EXAMPLES |
| 71 | -------- |
| 72 | |
| 73 | In the examples, the following '.gitattributes' file is used: |
| 74 | --------------- |
| 75 | *.java diff=java -crlf myAttr |
| 76 | NoMyAttr.java !myAttr |
| 77 | README caveat=unspecified |
| 78 | --------------- |
| 79 | |
| 80 | * Listing a single attribute: |
| 81 | --------------- |
| 82 | $ git check-attr diff org/example/MyClass.java |
| 83 | org/example/MyClass.java: diff: java |
| 84 | --------------- |
| 85 | |
| 86 | * Listing multiple attributes for a file: |
| 87 | --------------- |
| 88 | $ git check-attr crlf diff myAttr -- org/example/MyClass.java |
| 89 | org/example/MyClass.java: crlf: unset |
| 90 | org/example/MyClass.java: diff: java |
| 91 | org/example/MyClass.java: myAttr: set |
| 92 | --------------- |
| 93 | |
Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 94 | * Listing all attributes for a file: |
| 95 | --------------- |
| 96 | $ git check-attr --all -- org/example/MyClass.java |
| 97 | org/example/MyClass.java: diff: java |
| 98 | org/example/MyClass.java: myAttr: set |
| 99 | --------------- |
| 100 | |
Junio C Hamano | 1de7572 | 2009-03-26 08:39:38 | [diff] [blame] | 101 | * Listing an attribute for multiple files: |
Junio C Hamano | cbb3086 | 2008-10-17 10:03:42 | [diff] [blame] | 102 | --------------- |
| 103 | $ git check-attr myAttr -- org/example/MyClass.java org/example/NoMyAttr.java |
| 104 | org/example/MyClass.java: myAttr: set |
| 105 | org/example/NoMyAttr.java: myAttr: unspecified |
| 106 | --------------- |
| 107 | |
| 108 | * Not all values are equally unambiguous: |
| 109 | --------------- |
| 110 | $ git check-attr caveat README |
| 111 | README: caveat: unspecified |
| 112 | --------------- |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 113 | |
Junio C Hamano | f556fc2 | 2007-12-23 08:16:38 | [diff] [blame] | 114 | SEE ALSO |
| 115 | -------- |
Junio C Hamano | 35738e8 | 2008-01-07 07:55:46 | [diff] [blame] | 116 | linkgit:gitattributes[5]. |
Junio C Hamano | f556fc2 | 2007-12-23 08:16:38 | [diff] [blame] | 117 | |
Junio C Hamano | e90436a | 2007-04-22 07:22:13 | [diff] [blame] | 118 | GIT |
| 119 | --- |
Junio C Hamano | f7c042d | 2008-06-06 22:50:53 | [diff] [blame] | 120 | Part of the linkgit:git[1] suite |