unpack-trees: avoid array out-of-bounds error

The loop in warn_conflicted_path() that checks for the count of
entries with the same path uses "i+count" for the array
entry. However, the loop only verifies that the value of count is
below the array size. Fix this by adding i to the condition.

I hit this condition during a test of the in-tree sparse-checkout
feature, so it is exercised by the end of the series.

Signed-off-by: Derrick Stolee <dstolee@microsoft.com>
[jc: readability fix]
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Derrick Stolee 2020-05-07 13:17:33 +00:00 committed by Junio C Hamano
parent 5644ca28cd
commit 0eeb3be4c4

View File

@ -562,11 +562,11 @@ static int warn_conflicted_path(struct index_state *istate,
add_rejected_path(o, WARNING_SPARSE_UNMERGED_FILE, conflicting_path); add_rejected_path(o, WARNING_SPARSE_UNMERGED_FILE, conflicting_path);
/* Find out how many higher stage entries at same path */ /* Find out how many higher stage entries are at same path */
while (++count < istate->cache_nr && while ((++count) + i < istate->cache_nr &&
!strcmp(conflicting_path, !strcmp(conflicting_path, istate->cache[count + i]->name))
istate->cache[i+count]->name)) ; /* do nothing */
/* do nothing */;
return count; return count;
} }