mirror of
https://github.com/mpv-player/mpv
synced 2025-01-08 16:10:29 +00:00
options: commandline: support "--no-opt" for flag options
When parsing the command line, map "--no-foo" to "--foo=no" if an option named "foo" exists and is a flag option. Non-empty parameters are not allowed with this syntax ("--no-foo=no" is invalid). This implementation is different from the existing "--nofoo" variants for most flag options. Those are implemented as completely separate options; there's an option named "fs" and a separate option named "nofs" (thus "--no-nofs" actually works after this change...). The reason for adding the new syntax is to support the much more standard "--no-" prefix and to allow eventually cleaning up the option handling (though the "nofoo" variants of existing options can't be removed soon due to backwards compatibility).
This commit is contained in:
parent
b6628f4e1e
commit
081e2d0b7b
@ -68,6 +68,29 @@ static bool split_opt(struct bstr *opt, struct bstr *param, bool *old_syntax)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int map_to_option(struct m_config *config, bool old_syntax,
|
||||||
|
const struct m_option **mp_opt,
|
||||||
|
struct bstr *optname, struct bstr *param)
|
||||||
|
{
|
||||||
|
if (!mp_opt)
|
||||||
|
mp_opt = &(const struct m_option *){0};
|
||||||
|
*mp_opt = m_config_get_option(config, *optname);
|
||||||
|
if (*mp_opt)
|
||||||
|
return 0;
|
||||||
|
if (!bstr_startswith0(*optname, "no-"))
|
||||||
|
return -1;
|
||||||
|
struct bstr s = bstr_cut(*optname, 3);
|
||||||
|
*mp_opt = m_config_get_option(config, s);
|
||||||
|
if (!*mp_opt || (*mp_opt)->type != &m_option_type_flag)
|
||||||
|
return -1;
|
||||||
|
if (param->len)
|
||||||
|
return -2;
|
||||||
|
if (old_syntax)
|
||||||
|
return -3;
|
||||||
|
*optname = s;
|
||||||
|
*param = bstr("no");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Parse command line to set up config and playtree
|
// Parse command line to set up config and playtree
|
||||||
play_tree_t *m_config_parse_mp_command_line(m_config_t *config, int argc,
|
play_tree_t *m_config_parse_mp_command_line(m_config_t *config, int argc,
|
||||||
@ -172,8 +195,18 @@ play_tree_t *m_config_parse_mp_command_line(m_config_t *config, int argc,
|
|||||||
} else {
|
} else {
|
||||||
// "normal" options
|
// "normal" options
|
||||||
const struct m_option *mp_opt;
|
const struct m_option *mp_opt;
|
||||||
mp_opt = m_config_get_option(config, opt);
|
int ok = map_to_option(config, old_syntax, &mp_opt, &opt,
|
||||||
if (!mp_opt) {
|
¶m);
|
||||||
|
if (ok < 0) {
|
||||||
|
if (ok == -3)
|
||||||
|
mp_tmsg(MSGT_CFGPARSER, MSGL_ERR,
|
||||||
|
"Option --%.*s can't be used with single-dash "
|
||||||
|
"syntax\n", BSTR_P(opt));
|
||||||
|
else if (ok == -2)
|
||||||
|
mp_tmsg(MSGT_CFGPARSER, MSGL_ERR,
|
||||||
|
"A --no-* option can't take parameters: "
|
||||||
|
"--%.*s=%.*s\n", BSTR_P(opt), BSTR_P(param));
|
||||||
|
else
|
||||||
mp_tmsg(MSGT_CFGPARSER, MSGL_ERR,
|
mp_tmsg(MSGT_CFGPARSER, MSGL_ERR,
|
||||||
"Unknown option on the command line: --%.*s\n",
|
"Unknown option on the command line: --%.*s\n",
|
||||||
BSTR_P(opt));
|
BSTR_P(opt));
|
||||||
@ -295,7 +328,7 @@ int m_config_preparse_command_line(m_config_t *config, int argc, char **argv)
|
|||||||
if (!split_opt(&opt, ¶m, &old_syntax))
|
if (!split_opt(&opt, ¶m, &old_syntax))
|
||||||
continue; // Ignore non-option arguments
|
continue; // Ignore non-option arguments
|
||||||
// Ignore invalid options
|
// Ignore invalid options
|
||||||
if (!m_config_get_option(config, opt))
|
if (map_to_option(config, old_syntax, NULL, &opt, ¶m) < 0)
|
||||||
continue;
|
continue;
|
||||||
// Set, non-pre-parse options will be ignored
|
// Set, non-pre-parse options will be ignored
|
||||||
int r = m_config_set_option(config, opt, param, old_syntax);
|
int r = m_config_set_option(config, opt, param, old_syntax);
|
||||||
|
Loading…
Reference in New Issue
Block a user