diff options
Diffstat (limited to 'builtin')
| -rw-r--r-- | builtin/blame.c | 10 | 
1 files changed, 9 insertions, 1 deletions
| diff --git a/builtin/blame.c b/builtin/blame.c index 8fec0e1fb3..ab66cde2c2 100644 --- a/builtin/blame.c +++ b/builtin/blame.c @@ -2229,6 +2229,7 @@ static int git_blame_config(const char *var, const char *value, void *cb)  static void verify_working_tree_path(struct commit *work_tree, const char *path)  {  	struct commit_list *parents; +	int pos;  	for (parents = work_tree->parents; parents; parents = parents->next) {  		const unsigned char *commit_sha1 = parents->item->object.oid.hash; @@ -2239,7 +2240,14 @@ static void verify_working_tree_path(struct commit *work_tree, const char *path)  		    sha1_object_info(blob_sha1, NULL) == OBJ_BLOB)  			return;  	} -	die("no such path '%s' in HEAD", path); + +	pos = cache_name_pos(path, strlen(path)); +	if (pos >= 0) +		; /* path is in the index */ +	else if (!strcmp(active_cache[-1 - pos]->name, path)) +		; /* path is in the index, unmerged */ +	else +		die("no such path '%s' in HEAD", path);  }  static struct commit_list **append_parent(struct commit_list **tail, const unsigned char *sha1) | 
