X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fpath.c;h=27c45447297882b3c44d522567fc1d7bfb915a90;hp=30d946d788a66cb58bbd4b971c10f456fa78c0f4;hb=085b94eec37695a395c5edd5bb1e320ba12d2d1a;hpb=a40eb73224e237f758d38847ae216c019425ebac diff --git a/src/path.c b/src/path.c index 30d946d78..27c454472 100644 --- a/src/path.c +++ b/src/path.c @@ -30,6 +30,7 @@ #include "path.h" #include "dbus-path.h" #include "special.h" +#include "bus-errors.h" static const UnitActiveState state_translation_table[_PATH_STATE_MAX] = { [PATH_DEAD] = UNIT_INACTIVE, @@ -298,17 +299,22 @@ static void path_enter_dead(Path *p, bool success) { static void path_enter_running(Path *p) { int r; + DBusError error; + assert(p); + dbus_error_init(&error); - if ((r = manager_add_job(p->meta.manager, JOB_START, p->unit, JOB_REPLACE, true, NULL)) < 0) + if ((r = manager_add_job(p->meta.manager, JOB_START, p->unit, JOB_REPLACE, true, &error, NULL)) < 0) goto fail; path_set_state(p, PATH_RUNNING); return; fail: - log_warning("%s failed to queue unit startup job: %s", p->meta.id, strerror(-r)); + log_warning("%s failed to queue unit startup job: %s", p->meta.id, bus_error(&error, r)); path_enter_dead(p, false); + + dbus_error_free(&error); }