X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fdbus-service.c;h=c888570c4b9f9653c14d169d58e24ebc714425ae;hb=5b1869eaa22e365ab6595924fe96549b279b5ebc;hp=8b157b5f3cfac7e6215f8e6cac6f3dd90010c290;hpb=b9ec9359369f224bfb13db616f97401a6a177bd8;p=elogind.git diff --git a/src/core/dbus-service.c b/src/core/dbus-service.c index 8b157b5f3..c888570c4 100644 --- a/src/core/dbus-service.c +++ b/src/core/dbus-service.c @@ -81,7 +81,7 @@ BUS_UNIT_INTERFACES_LIST \ "org.freedesktop.systemd1.Service\0" -const char bus_service_interface[] _introspect_("Service") = BUS_SERVICE_INTERFACE; +const char bus_service_interface[] = BUS_SERVICE_INTERFACE; const char bus_service_invalidating_properties[] = "ExecStartPre\0" @@ -180,7 +180,22 @@ static int bus_service_set_transient_property( assert(s); assert(i); - if (streq(name, "ExecStart")) { + if (streq(name, "RemainAfterExit")) { + if (dbus_message_iter_get_arg_type(i) != DBUS_TYPE_BOOLEAN) + return -EINVAL; + + if (mode != UNIT_CHECK) { + dbus_bool_t b; + + dbus_message_iter_get_basic(i, &b); + + s->remain_after_exit = b; + unit_write_drop_in_private_format(UNIT(s), mode, name, "RemainAfterExit=%s\n", yes_no(b)); + } + + return 1; + + } else if (streq(name, "ExecStart")) { DBusMessageIter sub; unsigned n = 0; @@ -258,21 +273,16 @@ static int bus_service_set_transient_property( fputs("ExecStart=\n", f); LIST_FOREACH(command, c, s->exec_command[SERVICE_EXEC_START]) { - char **a; - fputs("ExecStart=", f); - - if (c->ignore) - fputc('-', f); + _cleanup_free_ char *a; - fputc('@', f); - fputs(c->path, f); - - STRV_FOREACH(a, c->argv) { - fputc(' ', f); - fputs(*a, f); - } + a = strv_join_quoted(c->argv); + if (!a) + return -ENOMEM; - fputc('\n', f); + fprintf(f, "ExecStart=%s@%s %s\n", + c->ignore ? "-" : "", + c->path, + a); } fflush(f); @@ -309,6 +319,10 @@ int bus_service_set_property( r = bus_service_set_transient_property(s, name, i, mode, error); if (r != 0) return r; + + r = bus_kill_context_set_transient_property(u, &s->kill_context, name, i, mode, error); + if (r != 0) + return r; } return 0;