summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2021-01-19 19:59:53 +0100
committerLennart Poettering <lennart@poettering.net>2021-01-20 17:50:23 +0100
commit8de42cb4615c4420f9d8e320b2e03f79d68d9dd5 (patch)
tree9ab71f785588a656f7a4ac4996fa9fbc1794f44f
parent8662fcbcf1f31725998bd1ebe706ac813b053962 (diff)
downloadsystemd-8de42cb4615c4420f9d8e320b2e03f79d68d9dd5.tar.gz
sysext: add --force swich for forcibly ignoring version incompatibilities
-rw-r--r--src/sysext/sysext.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/sysext/sysext.c b/src/sysext/sysext.c
index 98f0e53a60..590dfc9c20 100644
--- a/src/sysext/sysext.c
+++ b/src/sysext/sysext.c
@@ -35,6 +35,7 @@ static char **arg_hierarchies = NULL; /* "/usr" + "/opt" by default */
static char *arg_root = NULL;
static JsonFormatFlags arg_json_format_flags = JSON_FORMAT_OFF;
static PagerFlags arg_pager_flags = 0;
+static bool arg_force = false;
STATIC_DESTRUCTOR_REGISTER(arg_hierarchies, strv_freep);
STATIC_DESTRUCTOR_REGISTER(arg_root, freep);
@@ -414,6 +415,11 @@ static int validate_version(
assert(root);
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
* they place one in /etc/os-release, i.e. where things don't matter, as they aren't
* merged.) */
@@ -887,6 +893,7 @@ static int verb_help(int argc, char **argv, void *userdata) {
" --root=PATH Operate relative to root path\n"
" --json=pretty|short|off\n"
" Generate JSON output\n"
+ " --force Ignore version incompatibilities\n"
"\nSee the %2$s for details.\n"
, program_invocation_short_name
, link
@@ -904,6 +911,7 @@ static int parse_argv(int argc, char *argv[]) {
ARG_NO_PAGER,
ARG_ROOT,
ARG_JSON,
+ ARG_FORCE,
};
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 },
{ "root", required_argument, NULL, ARG_ROOT },
{ "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;
+ case ARG_FORCE:
+ arg_force = true;
+ break;
+
case '?':
return -EINVAL;