112 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
| 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)
 |