]> xenbits.xensource.com Git - libvirt.git/commitdiff
commandhelper: Use automatic memory management in printEnvironment
authorTim Wiederhake <twiederh@redhat.com>
Mon, 1 Feb 2021 11:28:01 +0000 (12:28 +0100)
committerPeter Krempa <pkrempa@redhat.com>
Tue, 2 Feb 2021 14:00:54 +0000 (15:00 +0100)
Signed-off-by: Tim Wiederhake <twiederh@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
tests/commandhelper.c

index 19dfc0915144a4f4d0d4754e87abb3677fd80d4b..854f3c09bfb2db96bdb67e740cccbe8c2b9415c1 100644 (file)
@@ -54,6 +54,12 @@ static void cleanupArguments(struct Arguments **ptr)
     free(args);
 }
 
+static void cleanupGeneric(void *ptr)
+{
+    void **ptrptr = ptr;
+    free (*ptrptr);
+}
+
 static struct Arguments *parseArguments(int argc, char** argv)
 {
     cleanup(struct Arguments *, cleanupArguments) args = NULL;
@@ -124,16 +130,15 @@ static int envsort(const void *a, const void *b)
 
 static int printEnvironment(FILE *log)
 {
-    char **newenv;
+    cleanup(char **, cleanupGeneric) newenv = NULL;
     size_t length;
     size_t i;
-    int ret = -1;
 
     for (length = 0; environ[length]; length++) {
     }
 
     if (!(newenv = malloc(sizeof(*newenv) * length)))
-        goto cleanup;
+        return -1;
 
     for (i = 0; i < length; i++) {
         newenv[i] = environ[i];
@@ -148,12 +153,7 @@ static int printEnvironment(FILE *log)
             fprintf(log, "ENV:%s\n", newenv[i]);
     }
 
-    ret = 0;
-
- cleanup:
-    if (newenv)
-        free(newenv);
-    return ret;
+    return 0;
 }
 
 static int printFds(FILE *log)