Merge branch 'ab/retire-refs-unused-funcs'
Code cleanup. * ab/retire-refs-unused-funcs: refs/ref-cache.[ch]: remove "incomplete" from create_dir_entry() refs/ref-cache.c: remove "mkdir" parameter from find_containing_dir() refs/ref-cache.[ch]: remove unused add_ref_entry() refs/ref-cache.[ch]: remove unused remove_entry_from_dir() refs.[ch]: remove unused ref_storage_backend_exists()
This commit is contained in:
commit
870de59af0
5
refs.c
5
refs.c
@ -33,11 +33,6 @@ static struct ref_storage_be *find_ref_storage_backend(const char *name)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int ref_storage_backend_exists(const char *name)
|
|
||||||
{
|
|
||||||
return find_ref_storage_backend(name) != NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* How to handle various characters in refnames:
|
* How to handle various characters in refnames:
|
||||||
* 0: An acceptable character for refs
|
* 0: An acceptable character for refs
|
||||||
|
2
refs.h
2
refs.h
@ -835,8 +835,6 @@ int reflog_expire(const char *refname,
|
|||||||
reflog_expiry_cleanup_fn cleanup_fn,
|
reflog_expiry_cleanup_fn cleanup_fn,
|
||||||
void *policy_cb_data);
|
void *policy_cb_data);
|
||||||
|
|
||||||
int ref_storage_backend_exists(const char *name);
|
|
||||||
|
|
||||||
struct ref_store *get_main_ref_store(struct repository *r);
|
struct ref_store *get_main_ref_store(struct repository *r);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -227,7 +227,7 @@ static void add_per_worktree_entries_to_dir(struct ref_dir *dir, const char *dir
|
|||||||
pos = search_ref_dir(dir, prefix, prefix_len);
|
pos = search_ref_dir(dir, prefix, prefix_len);
|
||||||
if (pos >= 0)
|
if (pos >= 0)
|
||||||
continue;
|
continue;
|
||||||
child_entry = create_dir_entry(dir->cache, prefix, prefix_len, 1);
|
child_entry = create_dir_entry(dir->cache, prefix, prefix_len);
|
||||||
add_entry_to_dir(dir, child_entry);
|
add_entry_to_dir(dir, child_entry);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -278,7 +278,7 @@ static void loose_fill_ref_dir(struct ref_store *ref_store,
|
|||||||
strbuf_addch(&refname, '/');
|
strbuf_addch(&refname, '/');
|
||||||
add_entry_to_dir(dir,
|
add_entry_to_dir(dir,
|
||||||
create_dir_entry(dir->cache, refname.buf,
|
create_dir_entry(dir->cache, refname.buf,
|
||||||
refname.len, 1));
|
refname.len));
|
||||||
} else {
|
} else {
|
||||||
if (!refs_resolve_ref_unsafe(&refs->base,
|
if (!refs_resolve_ref_unsafe(&refs->base,
|
||||||
refname.buf,
|
refname.buf,
|
||||||
@ -336,7 +336,7 @@ static struct ref_cache *get_loose_ref_cache(struct files_ref_store *refs)
|
|||||||
* lazily):
|
* lazily):
|
||||||
*/
|
*/
|
||||||
add_entry_to_dir(get_ref_dir(refs->loose->root),
|
add_entry_to_dir(get_ref_dir(refs->loose->root),
|
||||||
create_dir_entry(refs->loose, "refs/", 5, 1));
|
create_dir_entry(refs->loose, "refs/", 5));
|
||||||
}
|
}
|
||||||
return refs->loose;
|
return refs->loose;
|
||||||
}
|
}
|
||||||
|
@ -49,7 +49,7 @@ struct ref_cache *create_ref_cache(struct ref_store *refs,
|
|||||||
|
|
||||||
ret->ref_store = refs;
|
ret->ref_store = refs;
|
||||||
ret->fill_ref_dir = fill_ref_dir;
|
ret->fill_ref_dir = fill_ref_dir;
|
||||||
ret->root = create_dir_entry(ret, "", 0, 1);
|
ret->root = create_dir_entry(ret, "", 0);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,14 +86,13 @@ static void clear_ref_dir(struct ref_dir *dir)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct ref_entry *create_dir_entry(struct ref_cache *cache,
|
struct ref_entry *create_dir_entry(struct ref_cache *cache,
|
||||||
const char *dirname, size_t len,
|
const char *dirname, size_t len)
|
||||||
int incomplete)
|
|
||||||
{
|
{
|
||||||
struct ref_entry *direntry;
|
struct ref_entry *direntry;
|
||||||
|
|
||||||
FLEX_ALLOC_MEM(direntry, name, dirname, len);
|
FLEX_ALLOC_MEM(direntry, name, dirname, len);
|
||||||
direntry->u.subdir.cache = cache;
|
direntry->u.subdir.cache = cache;
|
||||||
direntry->flag = REF_DIR | (incomplete ? REF_INCOMPLETE : 0);
|
direntry->flag = REF_DIR | REF_INCOMPLETE;
|
||||||
return direntry;
|
return direntry;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,30 +143,19 @@ int search_ref_dir(struct ref_dir *dir, const char *refname, size_t len)
|
|||||||
/*
|
/*
|
||||||
* Search for a directory entry directly within dir (without
|
* Search for a directory entry directly within dir (without
|
||||||
* recursing). Sort dir if necessary. subdirname must be a directory
|
* recursing). Sort dir if necessary. subdirname must be a directory
|
||||||
* name (i.e., end in '/'). If mkdir is set, then create the
|
* name (i.e., end in '/'). Returns NULL if the desired
|
||||||
* directory if it is missing; otherwise, return NULL if the desired
|
|
||||||
* directory cannot be found. dir must already be complete.
|
* directory cannot be found. dir must already be complete.
|
||||||
*/
|
*/
|
||||||
static struct ref_dir *search_for_subdir(struct ref_dir *dir,
|
static struct ref_dir *search_for_subdir(struct ref_dir *dir,
|
||||||
const char *subdirname, size_t len,
|
const char *subdirname, size_t len)
|
||||||
int mkdir)
|
|
||||||
{
|
{
|
||||||
int entry_index = search_ref_dir(dir, subdirname, len);
|
int entry_index = search_ref_dir(dir, subdirname, len);
|
||||||
struct ref_entry *entry;
|
struct ref_entry *entry;
|
||||||
if (entry_index == -1) {
|
|
||||||
if (!mkdir)
|
if (entry_index == -1)
|
||||||
return NULL;
|
return NULL;
|
||||||
/*
|
|
||||||
* Since dir is complete, the absence of a subdir
|
entry = dir->entries[entry_index];
|
||||||
* means that the subdir really doesn't exist;
|
|
||||||
* therefore, create an empty record for it but mark
|
|
||||||
* the record complete.
|
|
||||||
*/
|
|
||||||
entry = create_dir_entry(dir->cache, subdirname, len, 0);
|
|
||||||
add_entry_to_dir(dir, entry);
|
|
||||||
} else {
|
|
||||||
entry = dir->entries[entry_index];
|
|
||||||
}
|
|
||||||
return get_ref_dir(entry);
|
return get_ref_dir(entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -176,18 +164,17 @@ static struct ref_dir *search_for_subdir(struct ref_dir *dir,
|
|||||||
* tree that should hold refname. If refname is a directory name
|
* tree that should hold refname. If refname is a directory name
|
||||||
* (i.e., it ends in '/'), then return that ref_dir itself. dir must
|
* (i.e., it ends in '/'), then return that ref_dir itself. dir must
|
||||||
* represent the top-level directory and must already be complete.
|
* represent the top-level directory and must already be complete.
|
||||||
* Sort ref_dirs and recurse into subdirectories as necessary. If
|
* Sort ref_dirs and recurse into subdirectories as necessary. Will
|
||||||
* mkdir is set, then create any missing directories; otherwise,
|
|
||||||
* return NULL if the desired directory cannot be found.
|
* return NULL if the desired directory cannot be found.
|
||||||
*/
|
*/
|
||||||
static struct ref_dir *find_containing_dir(struct ref_dir *dir,
|
static struct ref_dir *find_containing_dir(struct ref_dir *dir,
|
||||||
const char *refname, int mkdir)
|
const char *refname)
|
||||||
{
|
{
|
||||||
const char *slash;
|
const char *slash;
|
||||||
for (slash = strchr(refname, '/'); slash; slash = strchr(slash + 1, '/')) {
|
for (slash = strchr(refname, '/'); slash; slash = strchr(slash + 1, '/')) {
|
||||||
size_t dirnamelen = slash - refname + 1;
|
size_t dirnamelen = slash - refname + 1;
|
||||||
struct ref_dir *subdir;
|
struct ref_dir *subdir;
|
||||||
subdir = search_for_subdir(dir, refname, dirnamelen, mkdir);
|
subdir = search_for_subdir(dir, refname, dirnamelen);
|
||||||
if (!subdir) {
|
if (!subdir) {
|
||||||
dir = NULL;
|
dir = NULL;
|
||||||
break;
|
break;
|
||||||
@ -202,7 +189,7 @@ struct ref_entry *find_ref_entry(struct ref_dir *dir, const char *refname)
|
|||||||
{
|
{
|
||||||
int entry_index;
|
int entry_index;
|
||||||
struct ref_entry *entry;
|
struct ref_entry *entry;
|
||||||
dir = find_containing_dir(dir, refname, 0);
|
dir = find_containing_dir(dir, refname);
|
||||||
if (!dir)
|
if (!dir)
|
||||||
return NULL;
|
return NULL;
|
||||||
entry_index = search_ref_dir(dir, refname, strlen(refname));
|
entry_index = search_ref_dir(dir, refname, strlen(refname));
|
||||||
@ -212,50 +199,6 @@ struct ref_entry *find_ref_entry(struct ref_dir *dir, const char *refname)
|
|||||||
return (entry->flag & REF_DIR) ? NULL : entry;
|
return (entry->flag & REF_DIR) ? NULL : entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
int remove_entry_from_dir(struct ref_dir *dir, const char *refname)
|
|
||||||
{
|
|
||||||
int refname_len = strlen(refname);
|
|
||||||
int entry_index;
|
|
||||||
struct ref_entry *entry;
|
|
||||||
int is_dir = refname[refname_len - 1] == '/';
|
|
||||||
if (is_dir) {
|
|
||||||
/*
|
|
||||||
* refname represents a reference directory. Remove
|
|
||||||
* the trailing slash; otherwise we will get the
|
|
||||||
* directory *representing* refname rather than the
|
|
||||||
* one *containing* it.
|
|
||||||
*/
|
|
||||||
char *dirname = xmemdupz(refname, refname_len - 1);
|
|
||||||
dir = find_containing_dir(dir, dirname, 0);
|
|
||||||
free(dirname);
|
|
||||||
} else {
|
|
||||||
dir = find_containing_dir(dir, refname, 0);
|
|
||||||
}
|
|
||||||
if (!dir)
|
|
||||||
return -1;
|
|
||||||
entry_index = search_ref_dir(dir, refname, refname_len);
|
|
||||||
if (entry_index == -1)
|
|
||||||
return -1;
|
|
||||||
entry = dir->entries[entry_index];
|
|
||||||
|
|
||||||
MOVE_ARRAY(&dir->entries[entry_index],
|
|
||||||
&dir->entries[entry_index + 1], dir->nr - entry_index - 1);
|
|
||||||
dir->nr--;
|
|
||||||
if (dir->sorted > entry_index)
|
|
||||||
dir->sorted--;
|
|
||||||
free_ref_entry(entry);
|
|
||||||
return dir->nr;
|
|
||||||
}
|
|
||||||
|
|
||||||
int add_ref_entry(struct ref_dir *dir, struct ref_entry *ref)
|
|
||||||
{
|
|
||||||
dir = find_containing_dir(dir, ref->name, 1);
|
|
||||||
if (!dir)
|
|
||||||
return -1;
|
|
||||||
add_entry_to_dir(dir, ref);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Emit a warning and return true iff ref1 and ref2 have the same name
|
* Emit a warning and return true iff ref1 and ref2 have the same name
|
||||||
* and the same oid. Die if they have the same name but different
|
* and the same oid. Die if they have the same name but different
|
||||||
@ -522,7 +465,7 @@ struct ref_iterator *cache_ref_iterator_begin(struct ref_cache *cache,
|
|||||||
|
|
||||||
dir = get_ref_dir(cache->root);
|
dir = get_ref_dir(cache->root);
|
||||||
if (prefix && *prefix)
|
if (prefix && *prefix)
|
||||||
dir = find_containing_dir(dir, prefix, 0);
|
dir = find_containing_dir(dir, prefix);
|
||||||
if (!dir)
|
if (!dir)
|
||||||
/* There's nothing to iterate over. */
|
/* There's nothing to iterate over. */
|
||||||
return empty_ref_iterator_begin();
|
return empty_ref_iterator_begin();
|
||||||
|
@ -169,8 +169,7 @@ struct ref_dir *get_ref_dir(struct ref_entry *entry);
|
|||||||
* "refs/heads/") or "" for the top-level directory.
|
* "refs/heads/") or "" for the top-level directory.
|
||||||
*/
|
*/
|
||||||
struct ref_entry *create_dir_entry(struct ref_cache *cache,
|
struct ref_entry *create_dir_entry(struct ref_cache *cache,
|
||||||
const char *dirname, size_t len,
|
const char *dirname, size_t len);
|
||||||
int incomplete);
|
|
||||||
|
|
||||||
struct ref_entry *create_ref_entry(const char *refname,
|
struct ref_entry *create_ref_entry(const char *refname,
|
||||||
const struct object_id *oid, int flag);
|
const struct object_id *oid, int flag);
|
||||||
@ -199,29 +198,6 @@ void free_ref_cache(struct ref_cache *cache);
|
|||||||
*/
|
*/
|
||||||
void add_entry_to_dir(struct ref_dir *dir, struct ref_entry *entry);
|
void add_entry_to_dir(struct ref_dir *dir, struct ref_entry *entry);
|
||||||
|
|
||||||
/*
|
|
||||||
* Remove the entry with the given name from dir, recursing into
|
|
||||||
* subdirectories as necessary. If refname is the name of a directory
|
|
||||||
* (i.e., ends with '/'), then remove the directory and its contents.
|
|
||||||
* If the removal was successful, return the number of entries
|
|
||||||
* remaining in the directory entry that contained the deleted entry.
|
|
||||||
* If the name was not found, return -1. Please note that this
|
|
||||||
* function only deletes the entry from the cache; it does not delete
|
|
||||||
* it from the filesystem or ensure that other cache entries (which
|
|
||||||
* might be symbolic references to the removed entry) are updated.
|
|
||||||
* Nor does it remove any containing dir entries that might be made
|
|
||||||
* empty by the removal. dir must represent the top-level directory
|
|
||||||
* and must already be complete.
|
|
||||||
*/
|
|
||||||
int remove_entry_from_dir(struct ref_dir *dir, const char *refname);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Add a ref_entry to the ref_dir (unsorted), recursing into
|
|
||||||
* subdirectories as necessary. dir must represent the top-level
|
|
||||||
* directory. Return 0 on success.
|
|
||||||
*/
|
|
||||||
int add_ref_entry(struct ref_dir *dir, struct ref_entry *ref);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Find the value entry with the given name in dir, sorting ref_dirs
|
* Find the value entry with the given name in dir, sorting ref_dirs
|
||||||
* and recursing into subdirectories as necessary. If the name is not
|
* and recursing into subdirectories as necessary. If the name is not
|
||||||
|
Loading…
Reference in New Issue
Block a user