aboutgitcodebugslistschat
path: root/util.c
diff options
context:
space:
mode:
authorDavid Gibson <david@gibson.dropbear.id.au>2022-10-14 15:25:32 +1100
committerStefano Brivio <sbrivio@redhat.com>2022-10-15 02:10:36 +0200
commitea5936dd3f6293fb761e3b670a0f40233e5396fd (patch)
treeff4744bab430784cd416bc063902022018e905bf /util.c
parent096e48669b56273d44a3242d7af4840b38335961 (diff)
downloadpasst-ea5936dd3f6293fb761e3b670a0f40233e5396fd.tar
passt-ea5936dd3f6293fb761e3b670a0f40233e5396fd.tar.gz
passt-ea5936dd3f6293fb761e3b670a0f40233e5396fd.tar.bz2
passt-ea5936dd3f6293fb761e3b670a0f40233e5396fd.tar.lz
passt-ea5936dd3f6293fb761e3b670a0f40233e5396fd.tar.xz
passt-ea5936dd3f6293fb761e3b670a0f40233e5396fd.tar.zst
passt-ea5936dd3f6293fb761e3b670a0f40233e5396fd.zip
Replace FWRITE with a function
In a few places we use the FWRITE() macro to open a file, replace it's contents with a given string and close it again. There's no real reason this needs to be a macro rather than just a function though. Turn it into a function 'write_file()' and make some ancillary cleanups while we're there: - Add a return code so the caller can handle giving a useful error message - Handle the case of short write()s (unlikely, but possible) - Add O_TRUNC, to make sure we replace the existing contents entirely Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
Diffstat (limited to 'util.c')
-rw-r--r--util.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/util.c b/util.c
index 76057be..514bd44 100644
--- a/util.c
+++ b/util.c
@@ -449,3 +449,36 @@ int fls(unsigned long x)
return y;
}
+
+/**
+ * write_file() - Replace contents of file with a string
+ * @path: File to write
+ * @buf: String to write
+ *
+ * Return: 0 on success, -1 on any error
+ */
+int write_file(const char *path, const char *buf)
+{
+ int fd = open(path, O_WRONLY | O_TRUNC | O_CLOEXEC);
+ size_t len = strlen(buf);
+
+ if (fd < 0) {
+ warn("Could not open %s: %s", path, strerror(errno));
+ return -1;
+ }
+
+ while (len) {
+ ssize_t rc = write(fd, buf, len);
+
+ if (rc <= 0) {
+ warn("Couldn't write to %s: %s", path, strerror(errno));
+ break;
+ }
+
+ buf += rc;
+ len -= rc;
+ }
+
+ close(fd);
+ return len == 0 ? 0 : -1;
+}