Zbigniew Jędrzejewski-Szmek 62fe94
From 0975b63fb31263e535a2d26ed41e66e23f468bc5 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Lennart Poettering <lennart@poettering.net>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Fri, 22 Aug 2014 12:44:17 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] dbus1-generator: properly free the FILE*
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Also, rework the code to make use of fflush_and_check().
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Issue discovered by Simon Danner.
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/dbus1-generator/dbus1-generator.c | 20 ++++++++++++--------
Zbigniew Jędrzejewski-Szmek 62fe94
 1 file changed, 12 insertions(+), 8 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/dbus1-generator/dbus1-generator.c b/src/dbus1-generator/dbus1-generator.c
Zbigniew Jędrzejewski-Szmek 62fe94
index e1ffc5515f..3c4522b589 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/dbus1-generator/dbus1-generator.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/dbus1-generator/dbus1-generator.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -40,6 +40,7 @@ static int create_dbus_files(
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         _cleanup_free_ char *b = NULL, *s = NULL, *lnk = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
         _cleanup_fclose_ FILE *f = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         assert(path);
Zbigniew Jędrzejewski-Szmek 62fe94
         assert(name);
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -100,12 +101,15 @@ static int create_dbus_files(
Zbigniew Jędrzejewski-Szmek 62fe94
                         }
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-                fflush(f);
Zbigniew Jędrzejewski-Szmek 62fe94
-                if (ferror(f)) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                        log_error("Failed to write %s: %m", a);
Zbigniew Jędrzejewski-Szmek 62fe94
-                        return -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
+                r = fflush_and_check(f);
Zbigniew Jędrzejewski-Szmek 62fe94
+                if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                        log_error("Failed to write %s: %s", a, strerror(-r));
Zbigniew Jędrzejewski-Szmek 62fe94
+                        return r;
Zbigniew Jędrzejewski-Szmek 62fe94
                 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
+                fclose(f);
Zbigniew Jędrzejewski-Szmek 62fe94
+                f = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
                 service = s;
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -134,10 +138,10 @@ static int create_dbus_files(
Zbigniew Jędrzejewski-Szmek 62fe94
                 name,
Zbigniew Jędrzejewski-Szmek 62fe94
                 service);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        fflush(f);
Zbigniew Jędrzejewski-Szmek 62fe94
-        if (ferror(f)) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                log_error("Failed to write %s: %m", b);
Zbigniew Jędrzejewski-Szmek 62fe94
-                return -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
+        r = fflush_and_check(f);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (r < 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
+                log_error("Failed to write %s: %s", b, strerror(-r));
Zbigniew Jędrzejewski-Szmek 62fe94
+                return r;
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         lnk = strjoin(arg_dest_late, "/" SPECIAL_BUSNAMES_TARGET ".wants/", name, ".busname", NULL);