chiark / gitweb /
bus: generate a nice error when attempting to add a NULL string
authorLennart Poettering <lennart@poettering.net>
Thu, 21 Mar 2013 23:24:21 +0000 (00:24 +0100)
committerLennart Poettering <lennart@poettering.net>
Thu, 21 Mar 2013 23:24:21 +0000 (00:24 +0100)
src/libsystemd-bus/bus-message.c
src/libsystemd-bus/sd-bus.h
src/libsystemd-bus/test-bus-marshal.c

index c0a0242fd612dfd7b2ce2e082f0ebaa069abb20e..524f17eb9f952707ebdbc91da3c98121a4c14e1c 100644 (file)
@@ -768,11 +768,27 @@ int message_append_basic(sd_bus_message *m, char type, const void *p, const void
 
         case SD_BUS_TYPE_STRING:
         case SD_BUS_TYPE_OBJECT_PATH:
+
+                if (!p) {
+                        if (e)
+                                c->signature[c->index] = 0;
+
+                        return -EINVAL;
+                }
+
                 align = 4;
                 sz = 4 + strlen(p) + 1;
                 break;
 
         case SD_BUS_TYPE_SIGNATURE:
+
+                if (!p) {
+                        if (e)
+                                c->signature[c->index] = 0;
+
+                        return -EINVAL;
+                }
+
                 align = 1;
                 sz = 1 + strlen(p) + 1;
                 break;
index d5101c20d75a33ea68cfb969e8f0e3edd6d17325..3ea4acc76f8ba12d72576169535efde8217d5638 100644 (file)
@@ -33,7 +33,6 @@
  * - add page donation logic
  * - api for appending/reading fixed arrays
  * - always verify container depth
- * - handle NULL strings nicer when appending
  * - merge busctl into systemctl or so?
  * - add object handlers
  * - verify object paths
index 15c472cca099af0b23f708ad470baafc34514578..d12c847f352140eadde4b0ccf87b330acb65d8be 100644 (file)
@@ -50,6 +50,9 @@ int main(int argc, char *argv[]) {
         r = sd_bus_message_append(m, "s", "a string");
         assert_se(r >= 0);
 
+        r = sd_bus_message_append(m, "s", NULL);
+        assert_se(r < 0);
+
         r = sd_bus_message_append(m, "as", 2, "string #1", "string #2");
         assert_se(r >= 0);