| gitattributes API |
| ================= |
| |
| gitattributes mechanism gives a uniform way to associate various |
| attributes to set of paths. |
| |
| |
| Data Structure |
| -------------- |
| |
| `struct git_attr`:: |
| |
| An attribute is an opaque object that is identified by its name. |
| Pass the name to `git_attr()` function to obtain the object of |
| this type. The internal representation of this structure is |
| of no interest to the calling programs. The name of the |
| attribute can be retrieved by calling `git_attr_name()`. |
| |
| `struct git_attr_check`:: |
| |
| This structure represents a set of attributes to check in a call |
| to `git_checkattr()` function, and receives the results. |
| |
| |
| Attribute Values |
| ---------------- |
| |
| An attribute for a path can be in one of four states: Set, Unset, |
| Unspecified or set to a string, and `.value` member of `struct |
| git_attr_check` records it. There are three macros to check these: |
| |
| `ATTR_TRUE()`:: |
| |
| Returns true if the attribute is Set for the path. |
| |
| `ATTR_FALSE()`:: |
| |
| Returns true if the attribute is Unset for the path. |
| |
| `ATTR_UNSET()`:: |
| |
| Returns true if the attribute is Unspecified for the path. |
| |
| If none of the above returns true, `.value` member points at a string |
| value of the attribute for the path. |
| |
| |
| Querying Specific Attributes |
| ---------------------------- |
| |
| * Prepare an array of `struct git_attr_check` to define the list of |
| attributes you would want to check. To populate this array, you would |
| need to define necessary attributes by calling `git_attr()` function. |
| |
| * Call `git_checkattr()` to check the attributes for the path. |
| |
| * Inspect `git_attr_check` structure to see how each of the attribute in |
| the array is defined for the path. |
| |
| |
| Example |
| ------- |
| |
| To see how attributes "crlf" and "indent" are set for different paths. |
| |
| . Prepare an array of `struct git_attr_check` with two elements (because |
| we are checking two attributes). Initialize their `attr` member with |
| pointers to `struct git_attr` obtained by calling `git_attr()`: |
| |
| ------------ |
| static struct git_attr_check check[2]; |
| static void setup_check(void) |
| { |
| if (check[0].attr) |
| return; /* already done */ |
| check[0].attr = git_attr("crlf"); |
| check[1].attr = git_attr("ident"); |
| } |
| ------------ |
| |
| . Call `git_checkattr()` with the prepared array of `struct git_attr_check`: |
| |
| ------------ |
| const char *path; |
| |
| setup_check(); |
| git_checkattr(path, ARRAY_SIZE(check), check); |
| ------------ |
| |
| . Act on `.value` member of the result, left in `check[]`: |
| |
| ------------ |
| const char *value = check[0].value; |
| |
| if (ATTR_TRUE(value)) { |
| The attribute is Set, by listing only the name of the |
| attribute in the gitattributes file for the path. |
| } else if (ATTR_FALSE(value)) { |
| The attribute is Unset, by listing the name of the |
| attribute prefixed with a dash - for the path. |
| } else if (ATTR_UNSET(value)) { |
| The attribute is not set nor unset for the path. |
| } else if (!strcmp(value, "input")) { |
| If none of ATTR_TRUE(), ATTR_FALSE(), or ATTR_UNSET() is |
| true, the value is a string set in the gitattributes |
| file for the path by saying "attr=value". |
| } else if (... other check using value as string ...) { |
| ... |
| } |
| ------------ |
| |
| |
| Querying All Attributes |
| ----------------------- |
| |
| To get the values of all attributes associated with a file: |
| |
| * Call `git_all_attrs()`, which returns an array of `git_attr_check` |
| structures. |
| |
| * Iterate over the `git_attr_check` array to examine the attribute |
| names and values. The name of the attribute described by a |
| `git_attr_check` object can be retrieved via |
| `git_attr_name(check[i].attr)`. (Please note that no items will be |
| returned for unset attributes, so `ATTR_UNSET()` will return false |
| for all returned `git_array_check` objects.) |
| |
| * Free the `git_array_check` array. |