grep: do not skip unmerged entries when grepping in the working tree.
We used to skip unmerged entries, which made sense for grepping in the cached copies, but not for grepping in the working tree. Noticed by Johannes Sixt. Signed-off-by: Junio C Hamano <junkio@cox.net>maint
							parent
							
								
									aabd76930f
								
							
						
					
					
						commit
						36f2587ffb
					
				|  | @ -268,7 +268,7 @@ static int external_grep(struct grep_opt *opt, const char **paths, int cached) | |||
| 	for (i = 0; i < active_nr; i++) { | ||||
| 		struct cache_entry *ce = active_cache[i]; | ||||
| 		char *name; | ||||
| 		if (ce_stage(ce) || !S_ISREG(ntohl(ce->ce_mode))) | ||||
| 		if (!S_ISREG(ntohl(ce->ce_mode))) | ||||
| 			continue; | ||||
| 		if (!pathspec_matches(paths, ce->name)) | ||||
| 			continue; | ||||
|  | @ -280,12 +280,19 @@ static int external_grep(struct grep_opt *opt, const char **paths, int cached) | |||
| 			memcpy(name + 2, ce->name, len + 1); | ||||
| 		} | ||||
| 		argv[argc++] = name; | ||||
| 		if (argc < MAXARGS) | ||||
| 		if (argc < MAXARGS && !ce_stage(ce)) | ||||
| 			continue; | ||||
| 		status = exec_grep(argc, argv); | ||||
| 		if (0 < status) | ||||
| 			hit = 1; | ||||
| 		argc = nr; | ||||
| 		if (ce_stage(ce)) { | ||||
| 			do { | ||||
| 				i++; | ||||
| 			} while (i < active_nr && | ||||
| 				 !strcmp(ce->name, active_cache[i]->name)); | ||||
| 			i--; /* compensate for loop control */ | ||||
| 		} | ||||
| 	} | ||||
| 	if (argc > nr) { | ||||
| 		status = exec_grep(argc, argv); | ||||
|  | @ -316,14 +323,24 @@ static int grep_cache(struct grep_opt *opt, const char **paths, int cached) | |||
|  | ||||
| 	for (nr = 0; nr < active_nr; nr++) { | ||||
| 		struct cache_entry *ce = active_cache[nr]; | ||||
| 		if (ce_stage(ce) || !S_ISREG(ntohl(ce->ce_mode))) | ||||
| 		if (!S_ISREG(ntohl(ce->ce_mode))) | ||||
| 			continue; | ||||
| 		if (!pathspec_matches(paths, ce->name)) | ||||
| 			continue; | ||||
| 		if (cached) | ||||
| 		if (cached) { | ||||
| 			if (ce_stage(ce)) | ||||
| 				continue; | ||||
| 			hit |= grep_sha1(opt, ce->sha1, ce->name, 0); | ||||
| 		} | ||||
| 		else | ||||
| 			hit |= grep_file(opt, ce->name); | ||||
| 		if (ce_stage(ce)) { | ||||
| 			do { | ||||
| 				nr++; | ||||
| 			} while (nr < active_nr && | ||||
| 				 !strcmp(ce->name, active_cache[nr]->name)); | ||||
| 			nr--; /* compensate for loop control */ | ||||
| 		} | ||||
| 	} | ||||
| 	free_grep_patterns(opt); | ||||
| 	return hit; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Junio C Hamano
						Junio C Hamano