Move read_cache_unmerged() to read-cache.c
builtin-read-tree has a read_cache_unmerged() which is useful for other builtins, for example builtin-merge uses it as well. Move it to read-cache.c to avoid code duplication. Signed-off-by: Miklos Vajna <vmiklos@frugalware.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
b2eabcc253
commit
e46bbcf6e8
|
@ -29,30 +29,6 @@ static int list_tree(unsigned char *sha1)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int read_cache_unmerged(void)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
struct cache_entry **dst;
|
|
||||||
struct cache_entry *last = NULL;
|
|
||||||
|
|
||||||
read_cache();
|
|
||||||
dst = active_cache;
|
|
||||||
for (i = 0; i < active_nr; i++) {
|
|
||||||
struct cache_entry *ce = active_cache[i];
|
|
||||||
if (ce_stage(ce)) {
|
|
||||||
remove_name_hash(ce);
|
|
||||||
if (last && !strcmp(ce->name, last->name))
|
|
||||||
continue;
|
|
||||||
cache_tree_invalidate_path(active_cache_tree, ce->name);
|
|
||||||
last = ce;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
*dst++ = ce;
|
|
||||||
}
|
|
||||||
active_nr = dst - active_cache;
|
|
||||||
return !!last;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void prime_cache_tree_rec(struct cache_tree *it, struct tree *tree)
|
static void prime_cache_tree_rec(struct cache_tree *it, struct tree *tree)
|
||||||
{
|
{
|
||||||
struct tree_desc desc;
|
struct tree_desc desc;
|
||||||
|
|
2
cache.h
2
cache.h
|
@ -254,6 +254,7 @@ static inline void remove_name_hash(struct cache_entry *ce)
|
||||||
|
|
||||||
#define read_cache() read_index(&the_index)
|
#define read_cache() read_index(&the_index)
|
||||||
#define read_cache_from(path) read_index_from(&the_index, (path))
|
#define read_cache_from(path) read_index_from(&the_index, (path))
|
||||||
|
#define read_cache_unmerged() read_index_unmerged(&the_index)
|
||||||
#define write_cache(newfd, cache, entries) write_index(&the_index, (newfd))
|
#define write_cache(newfd, cache, entries) write_index(&the_index, (newfd))
|
||||||
#define discard_cache() discard_index(&the_index)
|
#define discard_cache() discard_index(&the_index)
|
||||||
#define unmerged_cache() unmerged_index(&the_index)
|
#define unmerged_cache() unmerged_index(&the_index)
|
||||||
|
@ -356,6 +357,7 @@ extern int init_db(const char *template_dir, unsigned int flags);
|
||||||
/* Initialize and use the cache information */
|
/* Initialize and use the cache information */
|
||||||
extern int read_index(struct index_state *);
|
extern int read_index(struct index_state *);
|
||||||
extern int read_index_from(struct index_state *, const char *path);
|
extern int read_index_from(struct index_state *, const char *path);
|
||||||
|
extern int read_index_unmerged(struct index_state *);
|
||||||
extern int write_index(const struct index_state *, int newfd);
|
extern int write_index(const struct index_state *, int newfd);
|
||||||
extern int discard_index(struct index_state *);
|
extern int discard_index(struct index_state *);
|
||||||
extern int unmerged_index(const struct index_state *);
|
extern int unmerged_index(const struct index_state *);
|
||||||
|
|
31
read-cache.c
31
read-cache.c
|
@ -1410,3 +1410,34 @@ int write_index(const struct index_state *istate, int newfd)
|
||||||
}
|
}
|
||||||
return ce_flush(&c, newfd);
|
return ce_flush(&c, newfd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Read the index file that is potentially unmerged into given
|
||||||
|
* index_state, dropping any unmerged entries. Returns true is
|
||||||
|
* the index is unmerged. Callers who want to refuse to work
|
||||||
|
* from an unmerged state can call this and check its return value,
|
||||||
|
* instead of calling read_cache().
|
||||||
|
*/
|
||||||
|
int read_index_unmerged(struct index_state *istate)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
struct cache_entry **dst;
|
||||||
|
struct cache_entry *last = NULL;
|
||||||
|
|
||||||
|
read_index(istate);
|
||||||
|
dst = istate->cache;
|
||||||
|
for (i = 0; i < istate->cache_nr; i++) {
|
||||||
|
struct cache_entry *ce = istate->cache[i];
|
||||||
|
if (ce_stage(ce)) {
|
||||||
|
remove_name_hash(ce);
|
||||||
|
if (last && !strcmp(ce->name, last->name))
|
||||||
|
continue;
|
||||||
|
cache_tree_invalidate_path(istate->cache_tree, ce->name);
|
||||||
|
last = ce;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
*dst++ = ce;
|
||||||
|
}
|
||||||
|
istate->cache_nr = dst - istate->cache;
|
||||||
|
return !!last;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue