| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 1 | gitattributes API |
| 2 | ================= |
| 3 | |
| 4 | gitattributes mechanism gives a uniform way to associate various |
| 5 | attributes to set of paths. |
| 6 | |
| 7 | |
| 8 | Data Structure |
| 9 | -------------- |
| 10 | |
| 11 | `struct git_attr`:: |
| 12 | |
| 13 | An attribute is an opaque object that is identified by its name. |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 14 | Pass the name to `git_attr()` function to obtain the object of |
| 15 | this type. The internal representation of this structure is |
| 16 | of no interest to the calling programs. The name of the |
| 17 | attribute can be retrieved by calling `git_attr_name()`. |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 18 | |
| 19 | `struct git_attr_check`:: |
| 20 | |
| 21 | This structure represents a set of attributes to check in a call |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 22 | to `git_check_attr()` function, and receives the results. |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 23 | |
| 24 | |
| 25 | Attribute Values |
| 26 | ---------------- |
| 27 | |
| 28 | An attribute for a path can be in one of four states: Set, Unset, |
| 29 | Unspecified or set to a string, and `.value` member of `struct |
| 30 | git_attr_check` records it. There are three macros to check these: |
| 31 | |
| 32 | `ATTR_TRUE()`:: |
| 33 | |
| 34 | Returns true if the attribute is Set for the path. |
| 35 | |
| 36 | `ATTR_FALSE()`:: |
| 37 | |
| 38 | Returns true if the attribute is Unset for the path. |
| 39 | |
| 40 | `ATTR_UNSET()`:: |
| 41 | |
| 42 | Returns true if the attribute is Unspecified for the path. |
| 43 | |
| 44 | If none of the above returns true, `.value` member points at a string |
| 45 | value of the attribute for the path. |
| 46 | |
| 47 | |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 48 | Querying Specific Attributes |
| 49 | ---------------------------- |
| 50 | |
| 51 | * Prepare an array of `struct git_attr_check` to define the list of |
| 52 | attributes you would want to check. To populate this array, you would |
| 53 | need to define necessary attributes by calling `git_attr()` function. |
| 54 | |
| 55 | * Call `git_check_attr()` to check the attributes for the path. |
| 56 | |
| 57 | * Inspect `git_attr_check` structure to see how each of the attribute in |
| 58 | the array is defined for the path. |
| 59 | |
| 60 | |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 61 | Example |
| 62 | ------- |
| 63 | |
| 64 | To see how attributes "crlf" and "indent" are set for different paths. |
| 65 | |
| 66 | . Prepare an array of `struct git_attr_check` with two elements (because |
| 67 | we are checking two attributes). Initialize their `attr` member with |
| 68 | pointers to `struct git_attr` obtained by calling `git_attr()`: |
| 69 | |
| 70 | ------------ |
| 71 | static struct git_attr_check check[2]; |
| 72 | static void setup_check(void) |
| 73 | { |
| 74 | if (check[0].attr) |
| 75 | return; /* already done */ |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 76 | check[0].attr = git_attr("crlf"); |
| 77 | check[1].attr = git_attr("ident"); |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 78 | } |
| 79 | ------------ |
| 80 | |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 81 | . Call `git_check_attr()` with the prepared array of `struct git_attr_check`: |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 82 | |
| 83 | ------------ |
| 84 | const char *path; |
| 85 | |
| 86 | setup_check(); |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 87 | git_check_attr(path, ARRAY_SIZE(check), check); |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 88 | ------------ |
| 89 | |
| 90 | . Act on `.value` member of the result, left in `check[]`: |
| 91 | |
| 92 | ------------ |
| 93 | const char *value = check[0].value; |
| 94 | |
| 95 | if (ATTR_TRUE(value)) { |
| 96 | The attribute is Set, by listing only the name of the |
| 97 | attribute in the gitattributes file for the path. |
| 98 | } else if (ATTR_FALSE(value)) { |
| 99 | The attribute is Unset, by listing the name of the |
| 100 | attribute prefixed with a dash - for the path. |
| 101 | } else if (ATTR_UNSET(value)) { |
| Junio C Hamano | d75148a | 2014-04-08 19:48:38 | [diff] [blame] | 102 | The attribute is neither set nor unset for the path. |
| Junio C Hamano | 3dac504 | 2007-12-15 08:40:54 | [diff] [blame] | 103 | } else if (!strcmp(value, "input")) { |
| 104 | If none of ATTR_TRUE(), ATTR_FALSE(), or ATTR_UNSET() is |
| 105 | true, the value is a string set in the gitattributes |
| 106 | file for the path by saying "attr=value". |
| 107 | } else if (... other check using value as string ...) { |
| 108 | ... |
| 109 | } |
| 110 | ------------ |
| 111 | |
| Junio C Hamano | f727901 | 2011-08-18 06:13:13 | [diff] [blame] | 112 | |
| 113 | Querying All Attributes |
| 114 | ----------------------- |
| 115 | |
| 116 | To get the values of all attributes associated with a file: |
| 117 | |
| 118 | * Call `git_all_attrs()`, which returns an array of `git_attr_check` |
| 119 | structures. |
| 120 | |
| 121 | * Iterate over the `git_attr_check` array to examine the attribute |
| 122 | names and values. The name of the attribute described by a |
| 123 | `git_attr_check` object can be retrieved via |
| 124 | `git_attr_name(check[i].attr)`. (Please note that no items will be |
| 125 | returned for unset attributes, so `ATTR_UNSET()` will return false |
| 126 | for all returned `git_array_check` objects.) |
| 127 | |
| 128 | * Free the `git_array_check` array. |