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 and its length 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. `struct git_attr_check`:: This structure represents a set of attributes to check in a call to `git_checkattr()` function, and receives the results. Calling Sequence ---------------- * 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. 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. 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", 4); check[1].attr = git_attr("ident", 5); } ------------ . 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 ...) { ... } ------------ (JC)