diff options
Diffstat (limited to 'builtin-update-index.c')
| -rw-r--r-- | builtin-update-index.c | 24 | 
1 files changed, 10 insertions, 14 deletions
diff --git a/builtin-update-index.c b/builtin-update-index.c index 92beaaf4b3..f1b6c8e88e 100644 --- a/builtin-update-index.c +++ b/builtin-update-index.c @@ -24,8 +24,8 @@ static int info_only;  static int force_remove;  static int verbose;  static int mark_valid_only; -#define MARK_VALID 1 -#define UNMARK_VALID 2 +#define MARK_FLAG 1 +#define UNMARK_FLAG 2  static void report(const char *fmt, ...)  { @@ -40,19 +40,15 @@ static void report(const char *fmt, ...)  	va_end(vp);  } -static int mark_valid(const char *path) +static int mark_ce_flags(const char *path, int flag, int mark)  {  	int namelen = strlen(path);  	int pos = cache_name_pos(path, namelen);  	if (0 <= pos) { -		switch (mark_valid_only) { -		case MARK_VALID: -			active_cache[pos]->ce_flags |= CE_VALID; -			break; -		case UNMARK_VALID: -			active_cache[pos]->ce_flags &= ~CE_VALID; -			break; -		} +		if (mark) +			active_cache[pos]->ce_flags |= flag; +		else +			active_cache[pos]->ce_flags &= ~flag;  		cache_tree_invalidate_path(active_cache_tree, path);  		active_cache_changed = 1;  		return 0; @@ -276,7 +272,7 @@ static void update_one(const char *path, const char *prefix, int prefix_length)  		goto free_return;  	}  	if (mark_valid_only) { -		if (mark_valid(p)) +		if (mark_ce_flags(p, CE_VALID, mark_valid_only == MARK_FLAG))  			die("Unable to mark file %s", path);  		goto free_return;  	} @@ -647,11 +643,11 @@ int cmd_update_index(int argc, const char **argv, const char *prefix)  				continue;  			}  			if (!strcmp(path, "--assume-unchanged")) { -				mark_valid_only = MARK_VALID; +				mark_valid_only = MARK_FLAG;  				continue;  			}  			if (!strcmp(path, "--no-assume-unchanged")) { -				mark_valid_only = UNMARK_VALID; +				mark_valid_only = UNMARK_FLAG;  				continue;  			}  			if (!strcmp(path, "--info-only")) {  | 
