Merge branch 'jk/name-hash-dirent'
* jk/name-hash-dirent: fix phantom untracked files when core.ignorecase is set
This commit is contained in:
commit
6f55f02815
1
cache.h
1
cache.h
@ -168,6 +168,7 @@ struct cache_entry {
|
||||
unsigned int ce_flags;
|
||||
unsigned char sha1[20];
|
||||
struct cache_entry *next;
|
||||
struct cache_entry *dir_next;
|
||||
char name[FLEX_ARRAY]; /* more */
|
||||
};
|
||||
|
||||
|
15
name-hash.c
15
name-hash.c
@ -57,12 +57,10 @@ static void hash_index_entry_directories(struct index_state *istate, struct cach
|
||||
if (*ptr == '/') {
|
||||
++ptr;
|
||||
hash = hash_name(ce->name, ptr - ce->name);
|
||||
if (!lookup_hash(hash, &istate->name_hash)) {
|
||||
pos = insert_hash(hash, ce, &istate->name_hash);
|
||||
if (pos) {
|
||||
ce->next = *pos;
|
||||
*pos = ce;
|
||||
}
|
||||
pos = insert_hash(hash, ce, &istate->name_hash);
|
||||
if (pos) {
|
||||
ce->dir_next = *pos;
|
||||
*pos = ce;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -166,7 +164,10 @@ struct cache_entry *index_name_exists(struct index_state *istate, const char *na
|
||||
if (same_name(ce, name, namelen, icase))
|
||||
return ce;
|
||||
}
|
||||
ce = ce->next;
|
||||
if (icase && name[namelen - 1] == '/')
|
||||
ce = ce->dir_next;
|
||||
else
|
||||
ce = ce->next;
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
Reference in New Issue
Block a user