Commit b747eb14 by Edward Thomson

Give index_isrch the same semantics as index_srch

In case insensitive index mode, we would stop at a prefixed entry,
treating the provided search key length as a substring, not the
length of the string to match.
parent bae8bea0
...@@ -134,14 +134,25 @@ static int index_isrch(const void *key, const void *array_member) ...@@ -134,14 +134,25 @@ static int index_isrch(const void *key, const void *array_member)
{ {
const struct entry_srch_key *srch_key = key; const struct entry_srch_key *srch_key = key;
const git_index_entry *entry = array_member; const git_index_entry *entry = array_member;
int ret; int cmp, len1, len2, len;
ret = strcasecmp(srch_key->path, entry->path); len1 = srch_key->path_len;
len2 = strlen(entry->path);
len = len1 < len2 ? len1 : len2;
if (ret == 0 && srch_key->stage != GIT_INDEX_STAGE_ANY) cmp = strncasecmp(srch_key->path, entry->path, len);
ret = srch_key->stage - GIT_IDXENTRY_STAGE(entry);
return ret; if (cmp)
return cmp;
if (len1 < len2)
return -1;
if (len1 > len2)
return 1;
if (srch_key->stage != GIT_INDEX_STAGE_ANY)
return srch_key->stage - GIT_IDXENTRY_STAGE(entry);
return 0;
} }
static int index_cmp_path(const void *a, const void *b) static int index_cmp_path(const void *a, const void *b)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment