In preceding commits the rest of the vreportf() users outside of usage.c have been migrated to die_message(), leaving only the git_die_config() function added in 5a80e97c827 (config: add `git_die_config()` to the config-set API, 2014-08-07). Let's have its callers call error() themselves if they want to emit a message, which is exactly what git_die_config() was doing for them before emitting its own die() message. This means that we can make the vreportf() in usage.c "static", and only expose functions such as usage(), die(), warning() etc. Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@xxxxxxxxx> --- builtin/fast-import.c | 7 ++++--- builtin/notes.c | 6 ++++-- config.c | 22 +++++++++------------- config.h | 10 ++++++---- git-compat-util.h | 1 - imap-send.c | 3 ++- usage.c | 2 +- 7 files changed, 26 insertions(+), 25 deletions(-) diff --git a/builtin/fast-import.c b/builtin/fast-import.c index 2b2e28bad79..4e2432bb491 100644 --- a/builtin/fast-import.c +++ b/builtin/fast-import.c @@ -3456,9 +3456,10 @@ static void git_pack_config(void) } if (!git_config_get_int("pack.indexversion", &indexversion_value)) { pack_idx_opts.version = indexversion_value; - if (pack_idx_opts.version > 2) - git_die_config("pack.indexversion", - "bad pack.indexversion=%"PRIu32, pack_idx_opts.version); + if (pack_idx_opts.version > 2) { + error("bad pack.indexversion=%"PRIu32, pack_idx_opts.version); + git_die_config("pack.indexversion"); + } } if (!git_config_get_ulong("pack.packsizelimit", &packsizelimit_value)) max_packsize = packsizelimit_value; diff --git a/builtin/notes.c b/builtin/notes.c index 2812d1eac40..60c5dab4122 100644 --- a/builtin/notes.c +++ b/builtin/notes.c @@ -763,8 +763,10 @@ static int git_config_get_notes_strategy(const char *key, if (git_config_get_string(key, &value)) return 1; - if (parse_notes_merge_strategy(value, strategy)) - git_die_config(key, _("unknown notes merge strategy %s"), value); + if (parse_notes_merge_strategy(value, strategy)) { + error(_("unknown notes merge strategy %s"), value); + git_die_config(key); + } free(value); return 0; diff --git a/config.c b/config.c index c5873f3a706..30f7971e0cc 100644 --- a/config.c +++ b/config.c @@ -2323,7 +2323,7 @@ int repo_config_get_string(struct repository *repo, git_config_check_init(repo); ret = git_configset_get_string(repo->config, key, dest); if (ret < 0) - git_die_config(key, NULL); + git_die_config(key); return ret; } @@ -2334,7 +2334,7 @@ int repo_config_get_string_tmp(struct repository *repo, git_config_check_init(repo); ret = git_configset_get_string_tmp(repo->config, key, dest); if (ret < 0) - git_die_config(key, NULL); + git_die_config(key); return ret; } @@ -2380,7 +2380,7 @@ int repo_config_get_pathname(struct repository *repo, git_config_check_init(repo); ret = git_configset_get_pathname(repo->config, key, dest); if (ret < 0) - git_die_config(key, NULL); + git_die_config(key); return ret; } @@ -2452,8 +2452,10 @@ int git_config_get_expiry(const char *key, const char **output) return ret; if (strcmp(*output, "now")) { timestamp_t now = approxidate("now"); - if (approxidate(*output) >= now) - git_die_config(key, _("Invalid %s: '%s'"), key, *output); + if (approxidate(*output) >= now) { + error(_("Invalid %s: '%s'"), key, *output); + git_die_config(key); + } } return ret; } @@ -2550,18 +2552,12 @@ void git_die_config_linenr(const char *key, const char *filename, int linenr) key, filename, linenr); } -NORETURN __attribute__((format(printf, 2, 3))) -void git_die_config(const char *key, const char *err, ...) +NORETURN +void git_die_config(const char *key) { const struct string_list *values; struct key_value_info *kv_info; - if (err) { - va_list params; - va_start(params, err); - vreportf("error: ", err, params); - va_end(params); - } values = git_config_get_value_multi(key); kv_info = values->items[values->nr - 1].util; git_die_config_linenr(key, kv_info->filename, kv_info->linenr); diff --git a/config.h b/config.h index f119de01309..fae585d2005 100644 --- a/config.h +++ b/config.h @@ -626,11 +626,13 @@ struct key_value_info { }; /** - * First prints the error message specified by the caller in `err` and then - * dies printing the line number and the file name of the highest priority - * value for the configuration variable `key`. + * Dies printing the line number and the file name of the highest + * priority value for the configuration variable `key`. + * + * Consider calling error() first with a more specific formatted + * message of your own. */ -NORETURN void git_die_config(const char *key, const char *err, ...) __attribute__((format(printf, 2, 3))); +NORETURN void git_die_config(const char *key); /** * Helper function which formats the die error message according to the diff --git a/git-compat-util.h b/git-compat-util.h index d56f416af8a..2f44aa86a8b 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -466,7 +466,6 @@ static inline int git_has_dir_sep(const char *path) struct strbuf; /* General helper functions */ -void vreportf(const char *prefix, const char *err, va_list params); NORETURN void usage(const char *err); NORETURN void usagef(const char *err, ...) __attribute__((format (printf, 1, 2))); NORETURN void die(const char *err, ...) __attribute__((format (printf, 1, 2))); diff --git a/imap-send.c b/imap-send.c index e6090a0346a..0fdfe5159eb 100644 --- a/imap-send.c +++ b/imap-send.c @@ -1350,7 +1350,8 @@ static int git_imap_config(const char *var, const char *val, void *cb) server.port = git_config_int(var, val); else if (!strcmp("imap.host", var)) { if (!val) { - git_die_config("imap.host", "Missing value for 'imap.host'"); + error("Missing value for 'imap.host'"); + git_die_config("imap.host"); } else { if (starts_with(val, "imap:")) val += 5; diff --git a/usage.c b/usage.c index a39d7aa330b..43231c8eac0 100644 --- a/usage.c +++ b/usage.c @@ -6,7 +6,7 @@ #include "git-compat-util.h" #include "cache.h" -void vreportf(const char *prefix, const char *err, va_list params) +static void vreportf(const char *prefix, const char *err, va_list params) { char msg[4096]; char *p, *pend = msg + sizeof(msg); -- 2.34.0.rc2.809.g11e21d44b24