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

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.

  1. 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);
}
  1. Call git_checkattr() with the prepared array of struct git_attr_check:

        const char *path;

        setup_check();
        git_checkattr(path, ARRAY_SIZE(check), check);
  1. 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)