[systemd-devel] [PATCH 1/2] dbus: consolidate service SysV conditionals
Lennart Poettering
lennart at poettering.net
Fri Mar 11 09:42:47 PST 2011
On Fri, 11.03.11 15:26, Andrey Borzenkov (arvidjaar at gmail.com) wrote:
> No need to define the same set of properties twice. While on it,
> add FsckPassNo to introspection.
Looks good, but could you rename BUS_SERVICE_SYSV_INTERFACE to
BUS_SERVICE_SYSV_INTERFACE_FRAGMENT or so, since it isn't complete
interface data anymore, just a fragment, since it includes no
<<interface> tag.
> ---
> src/dbus-service.c | 37 ++++++++-----------------------------
> 1 files changed, 8 insertions(+), 29 deletions(-)
>
> diff --git a/src/dbus-service.c b/src/dbus-service.c
> index 6bb6a9d..ed28e22 100644
> --- a/src/dbus-service.c
> +++ b/src/dbus-service.c
> @@ -26,34 +26,14 @@
> #include "dbus-service.h"
>
> #ifdef HAVE_SYSV_COMPAT
> -#define BUS_SERVICE_INTERFACE \
> - " <interface name=\"org.freedesktop.systemd1.Service\">\n" \
> - " <property name=\"Type\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"Restart\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"PIDFile\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"NotifyAccess\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"RestartUSec\" type=\"t\" access=\"read\"/>\n" \
> - " <property name=\"TimeoutUSec\" type=\"t\" access=\"read\"/>\n" \
> - BUS_EXEC_COMMAND_INTERFACE("ExecStartPre") \
> - BUS_EXEC_COMMAND_INTERFACE("ExecStart") \
> - BUS_EXEC_COMMAND_INTERFACE("ExecStartPost") \
> - BUS_EXEC_COMMAND_INTERFACE("ExecReload") \
> - BUS_EXEC_COMMAND_INTERFACE("ExecStop") \
> - BUS_EXEC_COMMAND_INTERFACE("ExecStopPost") \
> - BUS_EXEC_CONTEXT_INTERFACE \
> - " <property name=\"PermissionsStartOnly\" type=\"b\" access=\"read\"/>\n" \
> - " <property name=\"RootDirectoryStartOnly\" type=\"b\" access=\"read\"/>\n" \
> - " <property name=\"RemainAfterExit\" type=\"b\" access=\"read\"/>\n" \
> - BUS_EXEC_STATUS_INTERFACE("ExecMain") \
> - " <property name=\"MainPID\" type=\"u\" access=\"read\"/>\n" \
> - " <property name=\"ControlPID\" type=\"u\" access=\"read\"/>\n" \
> +#define BUS_SERVICE_SYSV_INTERFACE \
> " <property name=\"SysVStartPriority\" type=\"i\" access=\"read\"/>\n" \
> " <property name=\"SysVRunLevels\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"SysVPath\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"BusName\" type=\"s\" access=\"read\"/>\n" \
> - " <property name=\"StatusText\" type=\"s\" access=\"read\"/>\n" \
> - " </interface>\n"
> + " <property name=\"SysVPath\" type=\"s\" access=\"read\"/>\n"
> #else
> +#define BUS_SERVICE_SYSV_INTERFACE ""
> +#endif
> +
> #define BUS_SERVICE_INTERFACE \
> " <interface name=\"org.freedesktop.systemd1.Service\">\n" \
> " <property name=\"Type\" type=\"s\" access=\"read\"/>\n" \
> @@ -77,8 +57,9 @@
> " <property name=\"ControlPID\" type=\"u\" access=\"read\"/>\n" \
> " <property name=\"BusName\" type=\"s\" access=\"read\"/>\n" \
> " <property name=\"StatusText\" type=\"s\" access=\"read\"/>\n" \
> + " <property name=\"FsckPassNo\" type=\"i\" access=\"read\"/>\n" \
> + BUS_SERVICE_SYSV_INTERFACE \
> " </interface>\n"
> -#endif
>
> #define INTROSPECTION \
> DBUS_INTROSPECT_1_0_XML_DOCTYPE_DECL_NODE \
> @@ -135,14 +116,12 @@ DBusHandlerResult bus_service_message_handler(Unit *u, DBusConnection *connectio
> BUS_EXEC_STATUS_PROPERTIES("org.freedesktop.systemd1.Service", u->service.main_exec_status, "ExecMain"),
> { "org.freedesktop.systemd1.Service", "MainPID", bus_property_append_pid, "u", &u->service.main_pid },
> { "org.freedesktop.systemd1.Service", "ControlPID", bus_property_append_pid, "u", &u->service.control_pid },
> -#ifdef HAVE_SYSV_COMPAT
> - { "org.freedesktop.systemd1.Service", "SysVPath", bus_property_append_string, "s", u->service.sysv_path },
> -#endif
> { "org.freedesktop.systemd1.Service", "BusName", bus_property_append_string, "s", u->service.bus_name },
> { "org.freedesktop.systemd1.Service", "StatusText", bus_property_append_string, "s", u->service.status_text },
> #ifdef HAVE_SYSV_COMPAT
> { "org.freedesktop.systemd1.Service", "SysVRunLevels", bus_property_append_string, "s", u->service.sysv_runlevels },
> { "org.freedesktop.systemd1.Service", "SysVStartPriority", bus_property_append_int, "i", &u->service.sysv_start_priority },
> + { "org.freedesktop.systemd1.Service", "SysVPath", bus_property_append_string, "s", u->service.sysv_path },
> #endif
> { "org.freedesktop.systemd1.Service", "FsckPassNo", bus_property_append_int, "i", &u->service.fsck_passno },
> { NULL, NULL, NULL, NULL, NULL }
Lennart
--
Lennart Poettering - Red Hat, Inc.
More information about the systemd-devel
mailing list