diff options
author | Lennart Poettering <lennart@poettering.net> | 2013-07-02 01:35:08 +0200 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2013-07-02 01:48:55 +0200 |
commit | ede3a7967560506486e1e25d09ef4e74600851ff (patch) | |
tree | 8cfca3a63952ce9f83538085b4fe0e107fa49c09 /src/shared | |
parent | cc23f9f17434aad3941dff3c20bce485b39ce47c (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.c | 16 | ||||
-rw-r--r-- | src/shared/unit-name.h | 1 |
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); |