fsmonitor-settings: bare repos are incompatible with FSMonitor
Bare repos do not have a worktree, so there is nothing for the daemon watch. Signed-off-by: Jeff Hostetler <jeffhost@microsoft.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
49b398a970
commit
62a62a2830
@ -9,23 +9,42 @@
|
||||
*/
|
||||
struct fsmonitor_settings {
|
||||
enum fsmonitor_mode mode;
|
||||
enum fsmonitor_reason reason;
|
||||
char *hook_path;
|
||||
};
|
||||
|
||||
static void lookup_fsmonitor_settings(struct repository *r)
|
||||
static enum fsmonitor_reason check_for_incompatible(struct repository *r)
|
||||
{
|
||||
if (!r->worktree) {
|
||||
/*
|
||||
* Bare repositories don't have a working directory and
|
||||
* therefore have nothing to watch.
|
||||
*/
|
||||
return FSMONITOR_REASON_BARE;
|
||||
}
|
||||
|
||||
return FSMONITOR_REASON_OK;
|
||||
}
|
||||
|
||||
static struct fsmonitor_settings *alloc_settings(void)
|
||||
{
|
||||
struct fsmonitor_settings *s;
|
||||
|
||||
CALLOC_ARRAY(s, 1);
|
||||
s->mode = FSMONITOR_MODE_DISABLED;
|
||||
s->reason = FSMONITOR_REASON_UNTESTED;
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
static void lookup_fsmonitor_settings(struct repository *r)
|
||||
{
|
||||
const char *const_str;
|
||||
int bool_value;
|
||||
|
||||
if (r->settings.fsmonitor)
|
||||
return;
|
||||
|
||||
CALLOC_ARRAY(s, 1);
|
||||
s->mode = FSMONITOR_MODE_DISABLED;
|
||||
|
||||
r->settings.fsmonitor = s;
|
||||
|
||||
/*
|
||||
* Overload the existing "core.fsmonitor" config setting (which
|
||||
* has historically been either unset or a hook pathname) to
|
||||
@ -38,6 +57,8 @@ static void lookup_fsmonitor_settings(struct repository *r)
|
||||
case 0: /* config value was set to <bool> */
|
||||
if (bool_value)
|
||||
fsm_settings__set_ipc(r);
|
||||
else
|
||||
fsm_settings__set_disabled(r);
|
||||
return;
|
||||
|
||||
case 1: /* config value was unset */
|
||||
@ -53,18 +74,18 @@ static void lookup_fsmonitor_settings(struct repository *r)
|
||||
return;
|
||||
}
|
||||
|
||||
if (!const_str || !*const_str)
|
||||
return;
|
||||
|
||||
fsm_settings__set_hook(r, const_str);
|
||||
if (const_str && *const_str)
|
||||
fsm_settings__set_hook(r, const_str);
|
||||
else
|
||||
fsm_settings__set_disabled(r);
|
||||
}
|
||||
|
||||
enum fsmonitor_mode fsm_settings__get_mode(struct repository *r)
|
||||
{
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
|
||||
lookup_fsmonitor_settings(r);
|
||||
if (!r->settings.fsmonitor)
|
||||
lookup_fsmonitor_settings(r);
|
||||
|
||||
return r->settings.fsmonitor->mode;
|
||||
}
|
||||
@ -73,31 +94,55 @@ const char *fsm_settings__get_hook_path(struct repository *r)
|
||||
{
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
|
||||
lookup_fsmonitor_settings(r);
|
||||
if (!r->settings.fsmonitor)
|
||||
lookup_fsmonitor_settings(r);
|
||||
|
||||
return r->settings.fsmonitor->hook_path;
|
||||
}
|
||||
|
||||
void fsm_settings__set_ipc(struct repository *r)
|
||||
{
|
||||
enum fsmonitor_reason reason = check_for_incompatible(r);
|
||||
|
||||
if (reason != FSMONITOR_REASON_OK) {
|
||||
fsm_settings__set_incompatible(r, reason);
|
||||
return;
|
||||
}
|
||||
|
||||
/*
|
||||
* Caller requested IPC explicitly, so avoid (possibly
|
||||
* recursive) config lookup.
|
||||
*/
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
|
||||
lookup_fsmonitor_settings(r);
|
||||
if (!r->settings.fsmonitor)
|
||||
r->settings.fsmonitor = alloc_settings();
|
||||
|
||||
r->settings.fsmonitor->mode = FSMONITOR_MODE_IPC;
|
||||
r->settings.fsmonitor->reason = reason;
|
||||
FREE_AND_NULL(r->settings.fsmonitor->hook_path);
|
||||
}
|
||||
|
||||
void fsm_settings__set_hook(struct repository *r, const char *path)
|
||||
{
|
||||
enum fsmonitor_reason reason = check_for_incompatible(r);
|
||||
|
||||
if (reason != FSMONITOR_REASON_OK) {
|
||||
fsm_settings__set_incompatible(r, reason);
|
||||
return;
|
||||
}
|
||||
|
||||
/*
|
||||
* Caller requested hook explicitly, so avoid (possibly
|
||||
* recursive) config lookup.
|
||||
*/
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
|
||||
lookup_fsmonitor_settings(r);
|
||||
if (!r->settings.fsmonitor)
|
||||
r->settings.fsmonitor = alloc_settings();
|
||||
|
||||
r->settings.fsmonitor->mode = FSMONITOR_MODE_HOOK;
|
||||
r->settings.fsmonitor->reason = reason;
|
||||
FREE_AND_NULL(r->settings.fsmonitor->hook_path);
|
||||
r->settings.fsmonitor->hook_path = strdup(path);
|
||||
}
|
||||
@ -106,9 +151,57 @@ void fsm_settings__set_disabled(struct repository *r)
|
||||
{
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
|
||||
lookup_fsmonitor_settings(r);
|
||||
if (!r->settings.fsmonitor)
|
||||
r->settings.fsmonitor = alloc_settings();
|
||||
|
||||
r->settings.fsmonitor->mode = FSMONITOR_MODE_DISABLED;
|
||||
r->settings.fsmonitor->reason = FSMONITOR_REASON_OK;
|
||||
FREE_AND_NULL(r->settings.fsmonitor->hook_path);
|
||||
}
|
||||
|
||||
void fsm_settings__set_incompatible(struct repository *r,
|
||||
enum fsmonitor_reason reason)
|
||||
{
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
if (!r->settings.fsmonitor)
|
||||
r->settings.fsmonitor = alloc_settings();
|
||||
|
||||
r->settings.fsmonitor->mode = FSMONITOR_MODE_INCOMPATIBLE;
|
||||
r->settings.fsmonitor->reason = reason;
|
||||
FREE_AND_NULL(r->settings.fsmonitor->hook_path);
|
||||
}
|
||||
|
||||
enum fsmonitor_reason fsm_settings__get_reason(struct repository *r)
|
||||
{
|
||||
if (!r)
|
||||
r = the_repository;
|
||||
if (!r->settings.fsmonitor)
|
||||
lookup_fsmonitor_settings(r);
|
||||
|
||||
return r->settings.fsmonitor->reason;
|
||||
}
|
||||
|
||||
char *fsm_settings__get_incompatible_msg(const struct repository *r,
|
||||
enum fsmonitor_reason reason)
|
||||
{
|
||||
struct strbuf msg = STRBUF_INIT;
|
||||
|
||||
switch (reason) {
|
||||
case FSMONITOR_REASON_UNTESTED:
|
||||
case FSMONITOR_REASON_OK:
|
||||
goto done;
|
||||
|
||||
case FSMONITOR_REASON_BARE:
|
||||
strbuf_addf(&msg,
|
||||
_("bare repository '%s' is incompatible with fsmonitor"),
|
||||
xgetcwd());
|
||||
goto done;
|
||||
}
|
||||
|
||||
BUG("Unhandled case in fsm_settings__get_incompatible_msg: '%d'",
|
||||
reason);
|
||||
|
||||
done:
|
||||
return strbuf_detach(&msg, NULL);
|
||||
}
|
||||
|
Reference in New Issue
Block a user