diff options
| author | Brandon Williams <bmwill@google.com> | 2017-01-04 10:04:06 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2017-01-08 18:04:17 -0800 | 
| commit | b4bebdce834d9186f6b1646a943612658f4fb91c (patch) | |
| tree | 3ee603aa4a05cbeca208f59224c88fd8ab5802bd /pathspec.c | |
| parent | db7e85988f71b13f83f37c30e772d0e9a90d840d (diff) | |
| download | git-b4bebdce834d9186f6b1646a943612658f4fb91c.tar.gz | |
pathspec: create parse_short_magic function
Factor out the logic responsible for parsing short magic into its own
function.
Signed-off-by: Brandon Williams <bmwill@google.com>
Reviewed-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'pathspec.c')
| -rw-r--r-- | pathspec.c | 54 | 
1 files changed, 36 insertions, 18 deletions
| diff --git a/pathspec.c b/pathspec.c index 77df55da6a..1b09018480 100644 --- a/pathspec.c +++ b/pathspec.c @@ -157,6 +157,41 @@ static int get_global_magic(int element_magic)  }  /* + * Parse the pathspec element looking for short magic + * + * saves all magic in 'magic' + * returns the position in 'elem' after all magic has been parsed + */ +static const char *parse_short_magic(unsigned *magic, const char *elem) +{ +	const char *pos; + +	for (pos = elem + 1; *pos && *pos != ':'; pos++) { +		char ch = *pos; +		int i; + +		if (!is_pathspec_magic(ch)) +			break; + +		for (i = 0; i < ARRAY_SIZE(pathspec_magic); i++) { +			if (pathspec_magic[i].mnemonic == ch) { +				*magic |= pathspec_magic[i].bit; +				break; +			} +		} + +		if (ARRAY_SIZE(pathspec_magic) <= i) +			die(_("Unimplemented pathspec magic '%c' in '%s'"), +			    ch, elem); +	} + +	if (*pos == ':') +		pos++; + +	return pos; +} + +/*   * Take an element of a pathspec and check for magic signatures.   * Append the result to the prefix. Return the magic bitmap.   * @@ -220,24 +255,7 @@ static unsigned prefix_pathspec(struct pathspec_item *item, unsigned flags,  		copyfrom++;  	} else {  		/* shorthand */ -		for (copyfrom = elt + 1; -		     *copyfrom && *copyfrom != ':'; -		     copyfrom++) { -			char ch = *copyfrom; - -			if (!is_pathspec_magic(ch)) -				break; -			for (i = 0; i < ARRAY_SIZE(pathspec_magic); i++) -				if (pathspec_magic[i].mnemonic == ch) { -					element_magic |= pathspec_magic[i].bit; -					break; -				} -			if (ARRAY_SIZE(pathspec_magic) <= i) -				die(_("Unimplemented pathspec magic '%c' in '%s'"), -				    ch, elt); -		} -		if (*copyfrom == ':') -			copyfrom++; +		copyfrom = parse_short_magic(&element_magic, elt);  	}  	magic |= element_magic; | 
