|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
From eac249866b560587f6d08555e1625215e295bef0 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
Date: Fri, 28 Nov 2014 11:28:10 -0500
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
Subject: [PATCH] systemctl: append default suffix only if none present
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
Simplify unit_name_mangle() and unit_name_mangle_with_suffix() to
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
always behave the same, and only append a suffix if there is no
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
type suffix. If a user says 'isolate blah.device' it is better to
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
return an error that the type cannot be isolated, than to try to
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
isolate blah.device.target.
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
(cherry picked from commit 5e03c6e3b517286bbd65b48d88f60e5b83721894)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
---
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
src/shared/unit-name.c | 38 +++++++++-----------------------------
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
src/shared/unit-name.h | 4 +++-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
src/systemctl/systemctl.c | 5 +----
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
3 files changed, 13 insertions(+), 34 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
diff --git a/src/shared/unit-name.c b/src/shared/unit-name.c
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
index 6c6d7f4f83..21b66913c9 100644
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
--- a/src/shared/unit-name.c
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+++ b/src/shared/unit-name.c
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
@@ -502,13 +502,18 @@ int unit_name_from_dbus_path(const char *path, char **name) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
}
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
/**
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- * Try to turn a string that might not be a unit name into a
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- * sensible unit name.
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ * Convert a string to a unit name. /dev/blah is converted to dev-blah.device,
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ * /blah/blah is converted to blah-blah.mount, anything else is left alone,
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ * except that @suffix is appended if a valid unit suffix is not present.
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ *
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ * If @allow_globs, globs characters are preserved. Otherwise they are escaped.
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
*/
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-char *unit_name_mangle(const char *name, enum unit_name_mangle allow_globs) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+char *unit_name_mangle_with_suffix(const char *name, enum unit_name_mangle allow_globs, const char *suffix) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
char *r, *t;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
assert(name);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ assert(suffix);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ assert(suffix[0] == '.');
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
if (is_device_path(name))
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
return unit_name_from_path(name, ".device");
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
@@ -516,38 +521,13 @@ char *unit_name_mangle(const char *name, enum unit_name_mangle allow_globs) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
if (path_is_absolute(name))
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
return unit_name_from_path(name, ".mount");
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- r = new(char, strlen(name) * 4 + strlen(".service") + 1);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- if (!r)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- return NULL;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- t = do_escape_mangle(name, allow_globs, r);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- if (unit_name_to_type(name) < 0)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- strcpy(t, ".service");
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- else
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- *t = 0;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- return r;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-}
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-/**
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- * Similar to unit_name_mangle(), but is called when we know
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- * that this is about a specific unit type.
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- */
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-char *unit_name_mangle_with_suffix(const char *name, enum unit_name_mangle allow_globs, const char *suffix) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- char *r, *t;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- assert(name);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- assert(suffix);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- assert(suffix[0] == '.');
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
r = new(char, strlen(name) * 4 + strlen(suffix) + 1);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
if (!r)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
return NULL;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
t = do_escape_mangle(name, allow_globs, r);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- if (!endswith(name, suffix))
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ if (unit_name_to_type(name) < 0)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
strcpy(t, suffix);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
else
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
*t = 0;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
diff --git a/src/shared/unit-name.h b/src/shared/unit-name.h
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
index daeb56a860..6f139cc4c4 100644
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
--- a/src/shared/unit-name.h
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+++ b/src/shared/unit-name.h
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
@@ -156,8 +156,10 @@ enum unit_name_mangle {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
MANGLE_GLOB,
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
};
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
-char *unit_name_mangle(const char *name, enum unit_name_mangle allow_globs);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
char *unit_name_mangle_with_suffix(const char *name, enum unit_name_mangle allow_globs, const char *suffix);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+static inline char *unit_name_mangle(const char *name, enum unit_name_mangle allow_globs) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ return unit_name_mangle_with_suffix(name, allow_globs, ".service");
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
int build_subslice(const char *slice, const char*name, char **subslice);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
diff --git a/src/systemctl/systemctl.c b/src/systemctl/systemctl.c
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
index 409693e8f7..70b92db017 100644
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
--- a/src/systemctl/systemctl.c
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+++ b/src/systemctl/systemctl.c
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
@@ -2700,10 +2700,7 @@ static int expand_names(sd_bus *bus, char **names, const char* suffix, char ***r
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
STRV_FOREACH(name, names) {
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
char *t;
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- if (suffix)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- t = unit_name_mangle_with_suffix(*name, MANGLE_GLOB, suffix);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- else
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
- t = unit_name_mangle(*name, MANGLE_GLOB);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
+ t = unit_name_mangle_with_suffix(*name, MANGLE_GLOB, suffix);
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
if (!t)
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
return log_oom();
|
|
Zbigniew Jędrzejewski-Szmek |
9ecd5b |
|