trace2: plumb config kvi
There is a code path starting from trace2_def_param_fl() that eventually calls current_config_scope(), and thus it needs to have "kvi" plumbed through it. Additional plumbing is also needed to get "kvi" to trace2_def_param_fl(), which gets called by two code paths: - Through tr2_cfg_cb(), which is a config callback, so it trivially receives "kvi" via the "struct config_context ctx" parameter. - Through tr2_list_env_vars_fl(), which is a high level function that lists environment variables for tracing. This has been secretly behaving like git_config_from_parameters() (in that it parses config from environment variables/the CLI), but does not set config source information. Teach tr2_list_env_vars_fl() to be well-behaved by using kvi_from_param(), which is used elsewhere for CLI/environment variable-based config. As a result, current_config_scope() has no more callers, so remove it. Signed-off-by: Glen Choo <chooglen@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
26b669324b
commit
dc90208497
46
config.c
46
config.c
|
@ -85,16 +85,6 @@ struct config_reader {
|
||||||
*/
|
*/
|
||||||
struct config_source *source;
|
struct config_source *source;
|
||||||
struct key_value_info *config_kvi;
|
struct key_value_info *config_kvi;
|
||||||
/*
|
|
||||||
* The "scope" of the current config source being parsed (repo, global,
|
|
||||||
* etc). Like "source", this is only set when parsing a config source.
|
|
||||||
* It's not part of "source" because it transcends a single file (i.e.,
|
|
||||||
* a file included from .git/config is still in "repo" scope).
|
|
||||||
*
|
|
||||||
* When iterating through a configset, the equivalent value is
|
|
||||||
* "config_kvi.scope" (see above).
|
|
||||||
*/
|
|
||||||
enum config_scope parsing_scope;
|
|
||||||
};
|
};
|
||||||
/*
|
/*
|
||||||
* Where possible, prefer to accept "struct config_reader" as an arg than to use
|
* Where possible, prefer to accept "struct config_reader" as an arg than to use
|
||||||
|
@ -125,19 +115,9 @@ static inline struct config_source *config_reader_pop_source(struct config_reade
|
||||||
static inline void config_reader_set_kvi(struct config_reader *reader,
|
static inline void config_reader_set_kvi(struct config_reader *reader,
|
||||||
struct key_value_info *kvi)
|
struct key_value_info *kvi)
|
||||||
{
|
{
|
||||||
if (kvi && (reader->source || reader->parsing_scope))
|
|
||||||
BUG("kvi should not be set while parsing a config source");
|
|
||||||
reader->config_kvi = kvi;
|
reader->config_kvi = kvi;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void config_reader_set_scope(struct config_reader *reader,
|
|
||||||
enum config_scope scope)
|
|
||||||
{
|
|
||||||
if (scope && reader->config_kvi)
|
|
||||||
BUG("scope should only be set when iterating through a config source");
|
|
||||||
reader->parsing_scope = scope;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int pack_compression_seen;
|
static int pack_compression_seen;
|
||||||
static int zlib_compression_seen;
|
static int zlib_compression_seen;
|
||||||
|
|
||||||
|
@ -412,19 +392,13 @@ static void populate_remote_urls(struct config_include_data *inc)
|
||||||
{
|
{
|
||||||
struct config_options opts;
|
struct config_options opts;
|
||||||
|
|
||||||
enum config_scope store_scope = inc->config_reader->parsing_scope;
|
|
||||||
|
|
||||||
opts = *inc->opts;
|
opts = *inc->opts;
|
||||||
opts.unconditional_remote_url = 1;
|
opts.unconditional_remote_url = 1;
|
||||||
|
|
||||||
config_reader_set_scope(inc->config_reader, 0);
|
|
||||||
|
|
||||||
inc->remote_urls = xmalloc(sizeof(*inc->remote_urls));
|
inc->remote_urls = xmalloc(sizeof(*inc->remote_urls));
|
||||||
string_list_init_dup(inc->remote_urls);
|
string_list_init_dup(inc->remote_urls);
|
||||||
config_with_options(add_remote_url, inc->remote_urls,
|
config_with_options(add_remote_url, inc->remote_urls,
|
||||||
inc->config_source, inc->repo, &opts);
|
inc->config_source, inc->repo, &opts);
|
||||||
|
|
||||||
config_reader_set_scope(inc->config_reader, store_scope);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int forbid_remote_url(const char *var, const char *value UNUSED,
|
static int forbid_remote_url(const char *var, const char *value UNUSED,
|
||||||
|
@ -2255,7 +2229,6 @@ static int do_git_config_sequence(struct config_reader *reader,
|
||||||
char *user_config = NULL;
|
char *user_config = NULL;
|
||||||
char *repo_config;
|
char *repo_config;
|
||||||
char *worktree_config;
|
char *worktree_config;
|
||||||
enum config_scope prev_parsing_scope = reader->parsing_scope;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Ensure that either:
|
* Ensure that either:
|
||||||
|
@ -2273,7 +2246,6 @@ static int do_git_config_sequence(struct config_reader *reader,
|
||||||
worktree_config = NULL;
|
worktree_config = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
config_reader_set_scope(reader, CONFIG_SCOPE_SYSTEM);
|
|
||||||
if (git_config_system() && system_config &&
|
if (git_config_system() && system_config &&
|
||||||
!access_or_die(system_config, R_OK,
|
!access_or_die(system_config, R_OK,
|
||||||
opts->system_gently ? ACCESS_EACCES_OK : 0))
|
opts->system_gently ? ACCESS_EACCES_OK : 0))
|
||||||
|
@ -2281,7 +2253,6 @@ static int do_git_config_sequence(struct config_reader *reader,
|
||||||
data, CONFIG_SCOPE_SYSTEM,
|
data, CONFIG_SCOPE_SYSTEM,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
config_reader_set_scope(reader, CONFIG_SCOPE_GLOBAL);
|
|
||||||
git_global_config(&user_config, &xdg_config);
|
git_global_config(&user_config, &xdg_config);
|
||||||
|
|
||||||
if (xdg_config && !access_or_die(xdg_config, R_OK, ACCESS_EACCES_OK))
|
if (xdg_config && !access_or_die(xdg_config, R_OK, ACCESS_EACCES_OK))
|
||||||
|
@ -2292,13 +2263,11 @@ static int do_git_config_sequence(struct config_reader *reader,
|
||||||
ret += git_config_from_file_with_options(fn, user_config, data,
|
ret += git_config_from_file_with_options(fn, user_config, data,
|
||||||
CONFIG_SCOPE_GLOBAL, NULL);
|
CONFIG_SCOPE_GLOBAL, NULL);
|
||||||
|
|
||||||
config_reader_set_scope(reader, CONFIG_SCOPE_LOCAL);
|
|
||||||
if (!opts->ignore_repo && repo_config &&
|
if (!opts->ignore_repo && repo_config &&
|
||||||
!access_or_die(repo_config, R_OK, 0))
|
!access_or_die(repo_config, R_OK, 0))
|
||||||
ret += git_config_from_file_with_options(fn, repo_config, data,
|
ret += git_config_from_file_with_options(fn, repo_config, data,
|
||||||
CONFIG_SCOPE_LOCAL, NULL);
|
CONFIG_SCOPE_LOCAL, NULL);
|
||||||
|
|
||||||
config_reader_set_scope(reader, CONFIG_SCOPE_WORKTREE);
|
|
||||||
if (!opts->ignore_worktree && worktree_config &&
|
if (!opts->ignore_worktree && worktree_config &&
|
||||||
repo && repo->repository_format_worktree_config &&
|
repo && repo->repository_format_worktree_config &&
|
||||||
!access_or_die(worktree_config, R_OK, 0)) {
|
!access_or_die(worktree_config, R_OK, 0)) {
|
||||||
|
@ -2307,11 +2276,9 @@ static int do_git_config_sequence(struct config_reader *reader,
|
||||||
NULL);
|
NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
config_reader_set_scope(reader, CONFIG_SCOPE_COMMAND);
|
|
||||||
if (!opts->ignore_cmdline && 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"));
|
die(_("unable to parse command-line config"));
|
||||||
|
|
||||||
config_reader_set_scope(reader, prev_parsing_scope);
|
|
||||||
free(system_config);
|
free(system_config);
|
||||||
free(xdg_config);
|
free(xdg_config);
|
||||||
free(user_config);
|
free(user_config);
|
||||||
|
@ -2326,7 +2293,6 @@ int config_with_options(config_fn_t fn, void *data,
|
||||||
const struct config_options *opts)
|
const struct config_options *opts)
|
||||||
{
|
{
|
||||||
struct config_include_data inc = CONFIG_INCLUDE_INIT;
|
struct config_include_data inc = CONFIG_INCLUDE_INIT;
|
||||||
enum config_scope prev_scope = the_reader.parsing_scope;
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (opts->respect_includes) {
|
if (opts->respect_includes) {
|
||||||
|
@ -2340,9 +2306,6 @@ int config_with_options(config_fn_t fn, void *data,
|
||||||
data = &inc;
|
data = &inc;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config_source)
|
|
||||||
config_reader_set_scope(&the_reader, config_source->scope);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If we have a specific filename, use it. Otherwise, follow the
|
* If we have a specific filename, use it. Otherwise, follow the
|
||||||
* regular lookup sequence.
|
* regular lookup sequence.
|
||||||
|
@ -2364,7 +2327,6 @@ int config_with_options(config_fn_t fn, void *data,
|
||||||
string_list_clear(inc.remote_urls, 0);
|
string_list_clear(inc.remote_urls, 0);
|
||||||
FREE_AND_NULL(inc.remote_urls);
|
FREE_AND_NULL(inc.remote_urls);
|
||||||
}
|
}
|
||||||
config_reader_set_scope(&the_reader, prev_scope);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4088,14 +4050,6 @@ static int reader_config_name(struct config_reader *reader, const char **out)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum config_scope current_config_scope(void)
|
|
||||||
{
|
|
||||||
if (the_reader.config_kvi)
|
|
||||||
return the_reader.config_kvi->scope;
|
|
||||||
else
|
|
||||||
return the_reader.parsing_scope;
|
|
||||||
}
|
|
||||||
|
|
||||||
int lookup_config(const char **mapping, int nr_mapping, const char *var)
|
int lookup_config(const char **mapping, int nr_mapping, const char *var)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
1
config.h
1
config.h
|
@ -386,7 +386,6 @@ void git_global_config(char **user, char **xdg);
|
||||||
|
|
||||||
int git_config_parse_parameter(const char *, config_fn_t fn, void *data);
|
int git_config_parse_parameter(const char *, config_fn_t fn, void *data);
|
||||||
|
|
||||||
enum config_scope current_config_scope(void);
|
|
||||||
const char *config_origin_type_name(enum config_origin_type type);
|
const char *config_origin_type_name(enum config_origin_type type);
|
||||||
void kvi_from_param(struct key_value_info *out);
|
void kvi_from_param(struct key_value_info *out);
|
||||||
|
|
||||||
|
|
4
trace2.c
4
trace2.c
|
@ -634,7 +634,7 @@ void trace2_thread_exit_fl(const char *file, int line)
|
||||||
}
|
}
|
||||||
|
|
||||||
void trace2_def_param_fl(const char *file, int line, const char *param,
|
void trace2_def_param_fl(const char *file, int line, const char *param,
|
||||||
const char *value)
|
const char *value, const struct key_value_info *kvi)
|
||||||
{
|
{
|
||||||
struct tr2_tgt *tgt_j;
|
struct tr2_tgt *tgt_j;
|
||||||
int j;
|
int j;
|
||||||
|
@ -644,7 +644,7 @@ void trace2_def_param_fl(const char *file, int line, const char *param,
|
||||||
|
|
||||||
for_each_wanted_builtin (j, tgt_j)
|
for_each_wanted_builtin (j, tgt_j)
|
||||||
if (tgt_j->pfn_param_fl)
|
if (tgt_j->pfn_param_fl)
|
||||||
tgt_j->pfn_param_fl(file, line, param, value);
|
tgt_j->pfn_param_fl(file, line, param, value, kvi);
|
||||||
}
|
}
|
||||||
|
|
||||||
void trace2_def_repo_fl(const char *file, int line, struct repository *repo)
|
void trace2_def_repo_fl(const char *file, int line, struct repository *repo)
|
||||||
|
|
3
trace2.h
3
trace2.h
|
@ -325,6 +325,7 @@ void trace2_thread_exit_fl(const char *file, int line);
|
||||||
|
|
||||||
#define trace2_thread_exit() trace2_thread_exit_fl(__FILE__, __LINE__)
|
#define trace2_thread_exit() trace2_thread_exit_fl(__FILE__, __LINE__)
|
||||||
|
|
||||||
|
struct key_value_info;
|
||||||
/*
|
/*
|
||||||
* Emits a "def_param" message containing a key/value pair.
|
* Emits a "def_param" message containing a key/value pair.
|
||||||
*
|
*
|
||||||
|
@ -334,7 +335,7 @@ void trace2_thread_exit_fl(const char *file, int line);
|
||||||
* `core.abbrev`, `status.showUntrackedFiles`, or `--no-ahead-behind`.
|
* `core.abbrev`, `status.showUntrackedFiles`, or `--no-ahead-behind`.
|
||||||
*/
|
*/
|
||||||
void trace2_def_param_fl(const char *file, int line, const char *param,
|
void trace2_def_param_fl(const char *file, int line, const char *param,
|
||||||
const char *value);
|
const char *value, const struct key_value_info *kvi);
|
||||||
|
|
||||||
#define trace2_def_param(param, value) \
|
#define trace2_def_param(param, value) \
|
||||||
trace2_def_param_fl(__FILE__, __LINE__, (param), (value))
|
trace2_def_param_fl(__FILE__, __LINE__, (param), (value))
|
||||||
|
|
|
@ -100,7 +100,7 @@ struct tr2_cfg_data {
|
||||||
* See if the given config key matches any of our patterns of interest.
|
* See if the given config key matches any of our patterns of interest.
|
||||||
*/
|
*/
|
||||||
static int tr2_cfg_cb(const char *key, const char *value,
|
static int tr2_cfg_cb(const char *key, const char *value,
|
||||||
const struct config_context *ctx UNUSED, void *d)
|
const struct config_context *ctx, void *d)
|
||||||
{
|
{
|
||||||
struct strbuf **s;
|
struct strbuf **s;
|
||||||
struct tr2_cfg_data *data = (struct tr2_cfg_data *)d;
|
struct tr2_cfg_data *data = (struct tr2_cfg_data *)d;
|
||||||
|
@ -109,7 +109,8 @@ static int tr2_cfg_cb(const char *key, const char *value,
|
||||||
struct strbuf *buf = *s;
|
struct strbuf *buf = *s;
|
||||||
int wm = wildmatch(buf->buf, key, WM_CASEFOLD);
|
int wm = wildmatch(buf->buf, key, WM_CASEFOLD);
|
||||||
if (wm == WM_MATCH) {
|
if (wm == WM_MATCH) {
|
||||||
trace2_def_param_fl(data->file, data->line, key, value);
|
trace2_def_param_fl(data->file, data->line, key, value,
|
||||||
|
ctx->kvi);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -127,8 +128,10 @@ void tr2_cfg_list_config_fl(const char *file, int line)
|
||||||
|
|
||||||
void tr2_list_env_vars_fl(const char *file, int line)
|
void tr2_list_env_vars_fl(const char *file, int line)
|
||||||
{
|
{
|
||||||
|
struct key_value_info kvi = KVI_INIT;
|
||||||
struct strbuf **s;
|
struct strbuf **s;
|
||||||
|
|
||||||
|
kvi_from_param(&kvi);
|
||||||
if (tr2_load_env_vars() <= 0)
|
if (tr2_load_env_vars() <= 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -136,7 +139,7 @@ void tr2_list_env_vars_fl(const char *file, int line)
|
||||||
struct strbuf *buf = *s;
|
struct strbuf *buf = *s;
|
||||||
const char *val = getenv(buf->buf);
|
const char *val = getenv(buf->buf);
|
||||||
if (val && *val)
|
if (val && *val)
|
||||||
trace2_def_param_fl(file, line, buf->buf, val);
|
trace2_def_param_fl(file, line, buf->buf, val, &kvi);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -69,8 +69,10 @@ typedef void(tr2_tgt_evt_exec_result_fl_t)(const char *file, int line,
|
||||||
uint64_t us_elapsed_absolute,
|
uint64_t us_elapsed_absolute,
|
||||||
int exec_id, int code);
|
int exec_id, int code);
|
||||||
|
|
||||||
|
struct key_value_info;
|
||||||
typedef void(tr2_tgt_evt_param_fl_t)(const char *file, int line,
|
typedef void(tr2_tgt_evt_param_fl_t)(const char *file, int line,
|
||||||
const char *param, const char *value);
|
const char *param, const char *value,
|
||||||
|
const struct key_value_info *kvi);
|
||||||
|
|
||||||
typedef void(tr2_tgt_evt_repo_fl_t)(const char *file, int line,
|
typedef void(tr2_tgt_evt_repo_fl_t)(const char *file, int line,
|
||||||
const struct repository *repo);
|
const struct repository *repo);
|
||||||
|
|
|
@ -477,11 +477,11 @@ static void fn_exec_result_fl(const char *file, int line,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void fn_param_fl(const char *file, int line, const char *param,
|
static void fn_param_fl(const char *file, int line, const char *param,
|
||||||
const char *value)
|
const char *value, const struct key_value_info *kvi)
|
||||||
{
|
{
|
||||||
const char *event_name = "def_param";
|
const char *event_name = "def_param";
|
||||||
struct json_writer jw = JSON_WRITER_INIT;
|
struct json_writer jw = JSON_WRITER_INIT;
|
||||||
enum config_scope scope = current_config_scope();
|
enum config_scope scope = kvi->scope;
|
||||||
const char *scope_name = config_scope_name(scope);
|
const char *scope_name = config_scope_name(scope);
|
||||||
|
|
||||||
jw_object_begin(&jw, 0);
|
jw_object_begin(&jw, 0);
|
||||||
|
|
|
@ -297,10 +297,10 @@ static void fn_exec_result_fl(const char *file, int line,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void fn_param_fl(const char *file, int line, const char *param,
|
static void fn_param_fl(const char *file, int line, const char *param,
|
||||||
const char *value)
|
const char *value, const struct key_value_info *kvi)
|
||||||
{
|
{
|
||||||
struct strbuf buf_payload = STRBUF_INIT;
|
struct strbuf buf_payload = STRBUF_INIT;
|
||||||
enum config_scope scope = current_config_scope();
|
enum config_scope scope = kvi->scope;
|
||||||
const char *scope_name = config_scope_name(scope);
|
const char *scope_name = config_scope_name(scope);
|
||||||
|
|
||||||
strbuf_addf(&buf_payload, "def_param scope:%s %s=%s", scope_name, param,
|
strbuf_addf(&buf_payload, "def_param scope:%s %s=%s", scope_name, param,
|
||||||
|
|
|
@ -439,12 +439,12 @@ static void fn_exec_result_fl(const char *file, int line,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void fn_param_fl(const char *file, int line, const char *param,
|
static void fn_param_fl(const char *file, int line, const char *param,
|
||||||
const char *value)
|
const char *value, const struct key_value_info *kvi)
|
||||||
{
|
{
|
||||||
const char *event_name = "def_param";
|
const char *event_name = "def_param";
|
||||||
struct strbuf buf_payload = STRBUF_INIT;
|
struct strbuf buf_payload = STRBUF_INIT;
|
||||||
struct strbuf scope_payload = STRBUF_INIT;
|
struct strbuf scope_payload = STRBUF_INIT;
|
||||||
enum config_scope scope = current_config_scope();
|
enum config_scope scope = kvi->scope;
|
||||||
const char *scope_name = config_scope_name(scope);
|
const char *scope_name = config_scope_name(scope);
|
||||||
|
|
||||||
strbuf_addf(&buf_payload, "%s:%s", param, value);
|
strbuf_addf(&buf_payload, "%s:%s", param, value);
|
||||||
|
|
Loading…
Reference in New Issue