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:
Junio C Hamano 2021-10-06 13:40:13 -07:00
commit 870de59af0
5 changed files with 19 additions and 107 deletions

5
refs.c
View File

@ -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
View File

@ -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);
/** /**

View File

@ -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;
} }

View File

@ -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();

View File

@ -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