chiark / gitweb /
sd-bus: if we don't manage to properly allocate the error message for an sd_bus_error...
authorLennart Poettering <lennart@poettering.net>
Fri, 24 Oct 2014 17:24:53 +0000 (19:24 +0200)
committerLennart Poettering <lennart@poettering.net>
Fri, 24 Oct 2014 17:24:53 +0000 (19:24 +0200)
sd_bus_error_setfv() must initialize the sd_bus_error value to some
sensible value and then return a good errno code matching that. If it
cannot work at all it should set the error statically to the OOM error.
But if it can work half-way (i.e. initialize the name, but not the
message) it should do so and still return the correct errno number for
it.

This effectively reverts 8bf13eb1e02b9977ae1cd331ae5dc7305a305a09

src/libsystemd/sd-bus/bus-error.c

index 5ca974a1910c7a5647dd186499876402f3af9aee..af83c12d53971cbcca81465ced712da0abf865b0 100644 (file)
@@ -194,13 +194,10 @@ int bus_error_setfv(sd_bus_error *e, const char *name, const char *format, va_li
                 return -ENOMEM;
         }
 
-        if (format) {
-                int r;
-
-                r = vasprintf((char**) &e->message, format, ap);
-                if (r < 0)
-                        return -ENOMEM;
-        }
+        /* Of we hit OOM on formatting the pretty message, we ignore
+         * this, since we at least managed to write the error name */
+        if (format)
+                (void) vasprintf((char**) &e->message, format, ap);
 
         e->_need_free = 1;