diff options
author | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2017-07-01 22:49:15 +0200 |
---|---|---|
committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2017-07-03 15:30:57 +0200 |
commit | 5993d46a1a4472cc5a9a227311f913ff934395a3 (patch) | |
tree | 8803bf6b3d06a1ff5dcb42826a00fa82233c66c2 /src/shared/bus-util.c | |
parent | Revert "bus: when dumping string property values escape the chars we use as e... (diff) | |
download | systemd-5993d46a1a4472cc5a9a227311f913ff934395a3.tar.xz systemd-5993d46a1a4472cc5a9a227311f913ff934395a3.zip |
bus-util: replace non-printable values with [unprintable]
Like I said in the previous commit, such values do not seem to appear in normal
use, but it's pretty hard to prove that all paths to assign values properly
check that they contain no spaces. So just in case some slip through, replace
values with spaces (in case of single-valued properties) or spaces and newlines
(in case of array proprties) with "[unprintable]". We were already doing it
in case of properties which we didn't know how to print, so this fits in well.
The advantage is the previous code which used escaping that a) this is easier
to spot, b) does not mess up printing of properties which were properly escaped
already.
v2:
- add comments
Diffstat (limited to 'src/shared/bus-util.c')
-rw-r--r-- | src/shared/bus-util.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index 8705a7b841..207b5e66fc 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -724,8 +724,14 @@ int bus_print_property(const char *name, sd_bus_message *property, bool value, b if (r < 0) return r; - if (all || !isempty(s)) - print_property(name, "%s", s); + if (all || !isempty(s)) { + bool good; + + /* This property has a single value, so we need to take + * care not to print a new line, everything else is OK. */ + good = !strchr(s, '\n'); + print_property(name, "%s", good ? s : "[unprintable]"); + } return 1; } @@ -845,10 +851,16 @@ int bus_print_property(const char *name, sd_bus_message *property, bool value, b return r; while ((r = sd_bus_message_read_basic(property, SD_BUS_TYPE_STRING, &str)) > 0) { + bool good; + if (first && !value) printf("%s=", name); - printf("%s%s", first ? "" : " ", str); + /* This property has multiple space-seperated values, so + * neither spaces not newlines can be allowed in a value. */ + good = str[strcspn(str, " \n")] == '\0'; + + printf("%s%s", first ? "" : " ", good ? str : "[unprintable]"); first = false; } |