MINOR: standard: make indent_msg() support empty messages
indent_msg() is called with dynamically generated messages, so these
may be empty (NULL) when an empty list is being dumped. Support this
and return a NULL too.
diff --git a/src/standard.c b/src/standard.c
index 49810fc..287931a 100644
--- a/src/standard.c
+++ b/src/standard.c
@@ -1840,7 +1840,8 @@
/* Used to add <level> spaces before each line of <out>, unless there is only one line.
* The input argument is automatically freed and reassigned. The result will have to be
- * freed by the caller.
+ * freed by the caller. It also supports being passed a NULL which results in the same
+ * output.
* Example of use :
* parse(cmd, &err); (callee: memprintf(&err, ...))
* fprintf(stderr, "Parser said: %s\n", indent_error(&err));
@@ -1854,6 +1855,9 @@
int lastlf = 0;
int len;
+ if (!out || !*out)
+ return NULL;
+
in = *out - 1;
while ((in = strchr(in + 1, '\n')) != NULL) {
lastlf = in - *out;