зеркало из https://github.com/microsoft/git.git
ls-refs: drop config caching
The code for the v2 ls-refs command has an ensure_config_read() function that tries to read the lsrefs.unborn config only once and caches it in some static global variables. There's no real need for this caching. In any given process we'd only need the value twice (once to decide whether to advertise, and once if somebody runs the command). And since the config code already has its own cache, each access is only incurring a hash lookup and string comparison anyway. Since the values we set are going to be specific to the_repository, the globals we set are a mild anti-pattern. In practice it's not a bug (yet) since the server-side v2 code only handles a single repository anyway. But it doesn't hurt to take a small step in the right direction and model a good approach. Note that we currently set two booleans: advertise_unborn and allow_unborn. But we can get away with a single value, since "advertise" naturally implies "allow". That lets us just convert this to a function with a return value. Note that we still always read from the_repository; we'll deal with that in a follow-on patch. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
fe6258c348
Коммит
c4716086d8
34
ls-refs.c
34
ls-refs.c
|
@ -8,38 +8,32 @@
|
|||
#include "config.h"
|
||||
#include "string-list.h"
|
||||
|
||||
static int config_read;
|
||||
static int advertise_unborn;
|
||||
static int allow_unborn;
|
||||
|
||||
static void ensure_config_read(void)
|
||||
static enum {
|
||||
UNBORN_IGNORE = 0,
|
||||
UNBORN_ALLOW,
|
||||
UNBORN_ADVERTISE /* implies ALLOW */
|
||||
} unborn_config(void)
|
||||
{
|
||||
const char *str = NULL;
|
||||
|
||||
if (config_read)
|
||||
return;
|
||||
|
||||
if (repo_config_get_string_tmp(the_repository, "lsrefs.unborn", &str)) {
|
||||
/*
|
||||
* If there is no such config, advertise and allow it by
|
||||
* default.
|
||||
*/
|
||||
advertise_unborn = 1;
|
||||
allow_unborn = 1;
|
||||
return UNBORN_ADVERTISE;
|
||||
} else {
|
||||
if (!strcmp(str, "advertise")) {
|
||||
advertise_unborn = 1;
|
||||
allow_unborn = 1;
|
||||
return UNBORN_ADVERTISE;
|
||||
} else if (!strcmp(str, "allow")) {
|
||||
allow_unborn = 1;
|
||||
return UNBORN_ALLOW;
|
||||
} else if (!strcmp(str, "ignore")) {
|
||||
/* do nothing */
|
||||
return UNBORN_IGNORE;
|
||||
} else {
|
||||
die(_("invalid value for '%s': '%s'"),
|
||||
"lsrefs.unborn", str);
|
||||
}
|
||||
}
|
||||
config_read = 1;
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -159,7 +153,6 @@ int ls_refs(struct repository *r, struct packet_reader *request)
|
|||
strbuf_init(&data.buf, 0);
|
||||
string_list_init_dup(&data.hidden_refs);
|
||||
|
||||
ensure_config_read();
|
||||
git_config(ls_refs_config, &data);
|
||||
|
||||
while (packet_reader_read(request) == PACKET_READ_NORMAL) {
|
||||
|
@ -175,7 +168,7 @@ int ls_refs(struct repository *r, struct packet_reader *request)
|
|||
strvec_push(&data.prefixes, out);
|
||||
}
|
||||
else if (!strcmp("unborn", arg))
|
||||
data.unborn = allow_unborn;
|
||||
data.unborn = !!unborn_config();
|
||||
else
|
||||
die(_("unexpected line: '%s'"), arg);
|
||||
}
|
||||
|
@ -206,11 +199,8 @@ int ls_refs(struct repository *r, struct packet_reader *request)
|
|||
|
||||
int ls_refs_advertise(struct repository *r, struct strbuf *value)
|
||||
{
|
||||
if (value) {
|
||||
ensure_config_read();
|
||||
if (advertise_unborn)
|
||||
strbuf_addstr(value, "unborn");
|
||||
}
|
||||
if (value && unborn_config() == UNBORN_ADVERTISE)
|
||||
strbuf_addstr(value, "unborn");
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
|
Загрузка…
Ссылка в новой задаче