summaryrefslogtreecommitdiff
path: root/src/shared
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2013-07-02 01:35:08 +0200
committerLennart Poettering <lennart@poettering.net>2013-07-02 01:48:55 +0200
commitede3a7967560506486e1e25d09ef4e74600851ff (patch)
tree8cfca3a63952ce9f83538085b4fe0e107fa49c09 /src/shared
parentcc23f9f17434aad3941dff3c20bce485b39ce47c (diff)
core: split out unit bus path unescaping into unit_name_from_dbus_path()
Diffstat (limited to 'src/shared')
-rw-r--r--src/shared/unit-name.c16
-rw-r--r--src/shared/unit-name.h1
2 files changed, 17 insertions, 0 deletions
diff --git a/src/shared/unit-name.c b/src/shared/unit-name.c
index f2c30a6e4f..7733aae0e7 100644
--- a/src/shared/unit-name.c
+++ b/src/shared/unit-name.c
@@ -467,6 +467,22 @@ char *unit_dbus_path_from_name(const char *name) {
return strappend("/org/freedesktop/systemd1/unit/", e);
}
+int unit_name_from_dbus_path(const char *path, char **name) {
+ const char *e;
+ char *n;
+
+ e = startswith(path, "/org/freedesktop/systemd1/unit/");
+ if (!e)
+ return -EINVAL;
+
+ n = bus_path_unescape(e);
+ if (!n)
+ return -ENOMEM;
+
+ *name = n;
+ return 0;
+}
+
char *unit_name_mangle(const char *name) {
char *r, *t;
const char *f;
diff --git a/src/shared/unit-name.h b/src/shared/unit-name.h
index 88f2b83443..7f4ae56433 100644
--- a/src/shared/unit-name.h
+++ b/src/shared/unit-name.h
@@ -95,6 +95,7 @@ char *unit_name_from_path_instance(const char *prefix, const char *path, const c
char *unit_name_to_path(const char *name);
char *unit_dbus_path_from_name(const char *name);
+int unit_name_from_dbus_path(const char *path, char **name);
char *unit_name_mangle(const char *name);
char *unit_name_mangle_with_suffix(const char *name, const char *suffix);