mirror of
https://github.com/git/git
synced 2024-11-05 18:59:29 +00:00
caf433bbdf
We never look at the "ipc" argument we receive. It was added in
8f44976882
(fsmonitor: avoid socket location check if using hook,
2022-10-04) to support the darwin fsmonitor code. The win32 code has to
match the same interface, but we should use an annotation to silence
-Wunused-parameter.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
37 lines
1.1 KiB
C
37 lines
1.1 KiB
C
#include "git-compat-util.h"
|
|
#include "config.h"
|
|
#include "repository.h"
|
|
#include "fsmonitor-ll.h"
|
|
#include "fsmonitor-settings.h"
|
|
#include "fsmonitor-path-utils.h"
|
|
|
|
/*
|
|
* VFS for Git is incompatible with FSMonitor.
|
|
*
|
|
* Granted, core Git does not know anything about VFS for Git and we
|
|
* shouldn't make assumptions about a downstream feature, but users
|
|
* can install both versions. And this can lead to incorrect results
|
|
* from core Git commands. So, without bringing in any of the VFS for
|
|
* Git code, do a simple config test for a published config setting.
|
|
* (We do not look at the various *_TEST_* environment variables.)
|
|
*/
|
|
static enum fsmonitor_reason check_vfs4git(struct repository *r)
|
|
{
|
|
const char *const_str;
|
|
|
|
if (!repo_config_get_value(r, "core.virtualfilesystem", &const_str))
|
|
return FSMONITOR_REASON_VFS4GIT;
|
|
|
|
return FSMONITOR_REASON_OK;
|
|
}
|
|
|
|
enum fsmonitor_reason fsm_os__incompatible(struct repository *r, int ipc UNUSED)
|
|
{
|
|
enum fsmonitor_reason reason;
|
|
|
|
reason = check_vfs4git(r);
|
|
if (reason != FSMONITOR_REASON_OK)
|
|
return reason;
|
|
|
|
return FSMONITOR_REASON_OK;
|
|
}
|