config: add read_very_early_config()
Created an even lighter version of read_early_config() that only looks at system and global config settings. It omits repo-local, worktree-local, and command-line settings. 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
a7bc01eb25
commit
800a7f99a8
23
config.c
23
config.c
@ -1688,14 +1688,15 @@ static int do_git_config_sequence(const struct config_options *opts,
|
||||
ret += git_config_from_file(fn, user_config, data);
|
||||
|
||||
current_parsing_scope = CONFIG_SCOPE_REPO;
|
||||
if (repo_config && !access_or_die(repo_config, R_OK, 0))
|
||||
if (!opts->ignore_repo && repo_config &&
|
||||
!access_or_die(repo_config, R_OK, 0))
|
||||
ret += git_config_from_file(fn, repo_config, data);
|
||||
|
||||
/*
|
||||
* Note: this should have a new scope, CONFIG_SCOPE_WORKTREE.
|
||||
* But let's not complicate things before it's actually needed.
|
||||
*/
|
||||
if (repository_format_worktree_config) {
|
||||
if (!opts->ignore_worktree && repository_format_worktree_config) {
|
||||
char *path = git_pathdup("config.worktree");
|
||||
if (!access_or_die(path, R_OK, 0))
|
||||
ret += git_config_from_file(fn, path, data);
|
||||
@ -1703,7 +1704,7 @@ static int do_git_config_sequence(const struct config_options *opts,
|
||||
}
|
||||
|
||||
current_parsing_scope = CONFIG_SCOPE_CMDLINE;
|
||||
if (git_config_from_parameters(fn, data) < 0)
|
||||
if (!opts->ignore_cmdline && git_config_from_parameters(fn, data) < 0)
|
||||
die(_("unable to parse command-line config"));
|
||||
|
||||
current_parsing_scope = CONFIG_SCOPE_UNKNOWN;
|
||||
@ -1794,6 +1795,22 @@ void read_early_config(config_fn_t cb, void *data)
|
||||
strbuf_release(&gitdir);
|
||||
}
|
||||
|
||||
/*
|
||||
* Read config but only enumerate system and global settings.
|
||||
* Omit any repo-local, worktree-local, or command-line settings.
|
||||
*/
|
||||
void read_very_early_config(config_fn_t cb, void *data)
|
||||
{
|
||||
struct config_options opts = { 0 };
|
||||
|
||||
opts.respect_includes = 1;
|
||||
opts.ignore_repo = 1;
|
||||
opts.ignore_worktree = 1;
|
||||
opts.ignore_cmdline = 1;
|
||||
|
||||
config_with_options(cb, data, NULL, &opts);
|
||||
}
|
||||
|
||||
static struct config_set_element *configset_find_element(struct config_set *cs, const char *key)
|
||||
{
|
||||
struct config_set_element k;
|
||||
|
Reference in New Issue
Block a user