mirror of
https://github.com/systemd/systemd.git
synced 2025-01-27 18:04:05 +03:00
sysext: add --force swich for forcibly ignoring version incompatibilities
This commit is contained in:
parent
8662fcbcf1
commit
8de42cb461
@ -35,6 +35,7 @@ static char **arg_hierarchies = NULL; /* "/usr" + "/opt" by default */
|
|||||||
static char *arg_root = NULL;
|
static char *arg_root = NULL;
|
||||||
static JsonFormatFlags arg_json_format_flags = JSON_FORMAT_OFF;
|
static JsonFormatFlags arg_json_format_flags = JSON_FORMAT_OFF;
|
||||||
static PagerFlags arg_pager_flags = 0;
|
static PagerFlags arg_pager_flags = 0;
|
||||||
|
static bool arg_force = false;
|
||||||
|
|
||||||
STATIC_DESTRUCTOR_REGISTER(arg_hierarchies, strv_freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_hierarchies, strv_freep);
|
||||||
STATIC_DESTRUCTOR_REGISTER(arg_root, freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_root, freep);
|
||||||
@ -414,6 +415,11 @@ static int validate_version(
|
|||||||
assert(root);
|
assert(root);
|
||||||
assert(name);
|
assert(name);
|
||||||
|
|
||||||
|
if (arg_force) {
|
||||||
|
log_debug("Force mode enabled, skipping version validation.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* Insist that extension images do not overwrite the underlying OS release file (it's fine if
|
/* Insist that extension images do not overwrite the underlying OS release file (it's fine if
|
||||||
* they place one in /etc/os-release, i.e. where things don't matter, as they aren't
|
* they place one in /etc/os-release, i.e. where things don't matter, as they aren't
|
||||||
* merged.) */
|
* merged.) */
|
||||||
@ -887,6 +893,7 @@ static int verb_help(int argc, char **argv, void *userdata) {
|
|||||||
" --root=PATH Operate relative to root path\n"
|
" --root=PATH Operate relative to root path\n"
|
||||||
" --json=pretty|short|off\n"
|
" --json=pretty|short|off\n"
|
||||||
" Generate JSON output\n"
|
" Generate JSON output\n"
|
||||||
|
" --force Ignore version incompatibilities\n"
|
||||||
"\nSee the %2$s for details.\n"
|
"\nSee the %2$s for details.\n"
|
||||||
, program_invocation_short_name
|
, program_invocation_short_name
|
||||||
, link
|
, link
|
||||||
@ -904,6 +911,7 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
ARG_NO_PAGER,
|
ARG_NO_PAGER,
|
||||||
ARG_ROOT,
|
ARG_ROOT,
|
||||||
ARG_JSON,
|
ARG_JSON,
|
||||||
|
ARG_FORCE,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct option options[] = {
|
static const struct option options[] = {
|
||||||
@ -912,6 +920,7 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
{ "no-pager", no_argument, NULL, ARG_NO_PAGER },
|
{ "no-pager", no_argument, NULL, ARG_NO_PAGER },
|
||||||
{ "root", required_argument, NULL, ARG_ROOT },
|
{ "root", required_argument, NULL, ARG_ROOT },
|
||||||
{ "json", required_argument, NULL, ARG_JSON },
|
{ "json", required_argument, NULL, ARG_JSON },
|
||||||
|
{ "force", no_argument, NULL, ARG_FORCE },
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -947,6 +956,10 @@ static int parse_argv(int argc, char *argv[]) {
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ARG_FORCE:
|
||||||
|
arg_force = true;
|
||||||
|
break;
|
||||||
|
|
||||||
case '?':
|
case '?':
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user