config: handle NULL value when parsing non-bools
When the config parser sees an "implicit" bool like:
[core]
someVariable
it passes NULL to the config callback. Any callback code which expects a
string must check for NULL. This usually happens via helpers like
git_config_string(), etc, but some custom code forgets to do so and will
segfault.
These are all fairly vanilla cases where the solution is just the usual
pattern of:
if (!value)
return config_error_nonbool(var);
though note that in a few cases we have to split initializers like:
int some_var = initializer();
into:
int some_var;
if (!value)
return config_error_nonbool(var);
some_var = initializer();
There are still some broken instances after this patch, which I'll
address on their own in individual patches after this one.
Reported-by: Carlos Andrés Ramírez Cataño <antaigroupltda@gmail.com>
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
564d0252ca
commit
ba176db511
19
diff.c
19
diff.c
@ -372,7 +372,10 @@ int git_diff_ui_config(const char *var, const char *value,
|
||||
return 0;
|
||||
}
|
||||
if (!strcmp(var, "diff.colormovedws")) {
|
||||
unsigned cm = parse_color_moved_ws(value);
|
||||
unsigned cm;
|
||||
if (!value)
|
||||
return config_error_nonbool(var);
|
||||
cm = parse_color_moved_ws(value);
|
||||
if (cm & COLOR_MOVED_WS_ERROR)
|
||||
return -1;
|
||||
diff_color_moved_ws_default = cm;
|
||||
@ -426,10 +429,15 @@ int git_diff_ui_config(const char *var, const char *value,
|
||||
if (!strcmp(var, "diff.orderfile"))
|
||||
return git_config_pathname(&diff_order_file_cfg, var, value);
|
||||
|
||||
if (!strcmp(var, "diff.ignoresubmodules"))
|
||||
if (!strcmp(var, "diff.ignoresubmodules")) {
|
||||
if (!value)
|
||||
return config_error_nonbool(var);
|
||||
handle_ignore_submodules_arg(&default_diff_options, value);
|
||||
}
|
||||
|
||||
if (!strcmp(var, "diff.submodule")) {
|
||||
if (!value)
|
||||
return config_error_nonbool(var);
|
||||
if (parse_submodule_params(&default_diff_options, value))
|
||||
warning(_("Unknown value for 'diff.submodule' config variable: '%s'"),
|
||||
value);
|
||||
@ -473,7 +481,10 @@ int git_diff_basic_config(const char *var, const char *value,
|
||||
}
|
||||
|
||||
if (!strcmp(var, "diff.wserrorhighlight")) {
|
||||
int val = parse_ws_error_highlight(value);
|
||||
int val;
|
||||
if (!value)
|
||||
return config_error_nonbool(var);
|
||||
val = parse_ws_error_highlight(value);
|
||||
if (val < 0)
|
||||
return -1;
|
||||
ws_error_highlight_default = val;
|
||||
@ -490,6 +501,8 @@ int git_diff_basic_config(const char *var, const char *value,
|
||||
|
||||
if (!strcmp(var, "diff.dirstat")) {
|
||||
struct strbuf errmsg = STRBUF_INIT;
|
||||
if (!value)
|
||||
return config_error_nonbool(var);
|
||||
default_diff_options.dirstat_permille = diff_dirstat_permille_default;
|
||||
if (parse_dirstat_params(&default_diff_options, value, &errmsg))
|
||||
warning(_("Found errors in 'diff.dirstat' config variable:\n%s"),
|
||||
|
||||
Reference in New Issue
Block a user