diff options
| author | Lennart Poettering <lennart@poettering.net> | 2014-11-28 16:51:45 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2014-11-28 20:29:43 +0100 | 
| commit | 5b820358cf2a5cb6d67cc0b1faaaca3b0171f1ac (patch) | |
| tree | 91e4d6c1bbe2586c725b4de8d4308c5d6e0256a9 /src | |
| parent | 5c3026927de9dfa60ad6ae8326fef5d7824e723e (diff) | |
sd-bus: add new sd_bus_get_address() for querying the current bus address
Also, update "busctl" to show this in its output.
Diffstat (limited to 'src')
| -rw-r--r-- | src/libsystemd/sd-bus/busctl.c | 8 | ||||
| -rw-r--r-- | src/libsystemd/sd-bus/sd-bus.c | 22 | ||||
| -rw-r--r-- | src/systemd/sd-bus.h | 3 | 
3 files changed, 26 insertions, 7 deletions
| diff --git a/src/libsystemd/sd-bus/busctl.c b/src/libsystemd/sd-bus/busctl.c index f75a9dcbd3..1ba4e8adac 100644 --- a/src/libsystemd/sd-bus/busctl.c +++ b/src/libsystemd/sd-bus/busctl.c @@ -1176,12 +1176,16 @@ static int status(sd_bus *bus, char *argv[]) {                                          pid,                                          _SD_BUS_CREDS_ALL);          } else { -                const char *scope; +                const char *scope, *address;                  sd_id128_t bus_id; +                r = sd_bus_get_address(bus, &address); +                if (r >= 0) +                        printf("BusAddress=%s%s%s\n", ansi_highlight(), address, ansi_highlight_off()); +                  r = sd_bus_get_scope(bus, &scope);                  if (r >= 0) -                        printf("Scope=%s%s%s\n", ansi_highlight(), scope, ansi_highlight_off()); +                        printf("BusScope=%s%s%s\n", ansi_highlight(), scope, ansi_highlight_off());                  r = sd_bus_get_bus_id(bus, &bus_id);                  if (r >= 0) diff --git a/src/libsystemd/sd-bus/sd-bus.c b/src/libsystemd/sd-bus/sd-bus.c index 5947cd72c9..6b35036c06 100644 --- a/src/libsystemd/sd-bus/sd-bus.c +++ b/src/libsystemd/sd-bus/sd-bus.c @@ -3396,24 +3396,38 @@ _public_ int sd_bus_get_scope(sd_bus *bus, const char **scope) {                  if (streq(n, "0-system")) {                          *scope = "system"; -                        return 1; +                        return 0;                  }                  dash = strchr(n, '-');                  if (streq(dash, "-user")) {                          *scope = "user"; -                        return 1; +                        return 0;                  }          }          if (bus->is_user) {                  *scope = "user"; -                return 1; +                return 0;          }          if (bus->is_system) {                  *scope = "system"; -                return 1; +                return 0; +        } + +        return -ENODATA; +} + +_public_ int sd_bus_get_address(sd_bus *bus, const char **address) { + +        assert_return(bus, -EINVAL); +        assert_return(address, -EINVAL); +        assert_return(!bus_pid_changed(bus), -ECHILD); + +        if (bus->address) { +                *address = bus->address; +                return 0;          }          return -ENODATA; diff --git a/src/systemd/sd-bus.h b/src/systemd/sd-bus.h index 78a81a9436..daa34842d7 100644 --- a/src/systemd/sd-bus.h +++ b/src/systemd/sd-bus.h @@ -120,7 +120,7 @@ int sd_bus_set_address(sd_bus *bus, const char *address);  int sd_bus_set_fd(sd_bus *bus, int input_fd, int output_fd);  int sd_bus_set_exec(sd_bus *bus, const char *path, char *const argv[]);  int sd_bus_set_bus_client(sd_bus *bus, int b); -int sd_bus_set_server(sd_bus *bus, int b, sd_id128_t owner_id); +int sd_bus_set_server(sd_bus *bus, int b, sd_id128_t bus_id);  int sd_bus_set_anonymous(sd_bus *bus, int b);  int sd_bus_set_trusted(sd_bus *bus, int b);  int sd_bus_set_description(sd_bus *bus, const char *description); @@ -138,6 +138,7 @@ sd_bus *sd_bus_unref(sd_bus *bus);  int sd_bus_is_open(sd_bus *bus);  int sd_bus_can_send(sd_bus *bus, char type); +int sd_bus_get_address(sd_bus *bus, const char **address);  int sd_bus_get_bus_id(sd_bus *bus, sd_id128_t *id);  int sd_bus_get_owner_creds(sd_bus *bus, uint64_t creds_mask, sd_bus_creds **ret);  int sd_bus_get_scope(sd_bus *bus, const char **scope); | 
