X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=attr.h;h=eb8ca0d7c067417a8ff2802179e50bddcdff3367;hb=dac1de7de5f13d5bd2b69c8580ae213f166f16c5;hp=450f49d648a013ffddc6321b7fd79b3fc1b66f7a;hpb=c444c16589f95ac22d8e3ffe603cd7f0613512ce;p=git.git diff --git a/attr.h b/attr.h index 450f49d64..eb8ca0d7c 100644 --- a/attr.h +++ b/attr.h @@ -20,7 +20,7 @@ extern const char git_attr__false[]; #define ATTR_UNSET(v) ((v) == NULL) /* - * Send one or more git_attr_check to git_checkattr(), and + * Send one or more git_attr_check to git_check_attr(), and * each 'value' member tells what its value is. * Unset one is returned as NULL. */ @@ -29,12 +29,28 @@ struct git_attr_check { const char *value; }; -int git_checkattr(const char *path, int, struct git_attr_check *); +/* + * Return the name of the attribute represented by the argument. The + * return value is a pointer to a null-delimited string that is part + * of the internal data structure; it should not be modified or freed. + */ +char *git_attr_name(struct git_attr *); + +int git_check_attr(const char *path, int, struct git_attr_check *); + +/* + * Retrieve all attributes that apply to the specified path. *num + * will be set the the number of attributes on the path; **check will + * be set to point at a newly-allocated array of git_attr_check + * objects describing the attributes and their values. *check must be + * free()ed by the caller. + */ +int git_all_attrs(const char *path, int *num, struct git_attr_check **check); enum git_attr_direction { GIT_ATTR_CHECKIN, GIT_ATTR_CHECKOUT, - GIT_ATTR_INDEX, + GIT_ATTR_INDEX }; void git_attr_set_direction(enum git_attr_direction, struct index_state *);