|
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);
|