]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Suppress -Wunused-result warnings about write(), again.
authorTom Lane <tgl@sss.pgh.pa.us>
Fri, 3 Jun 2016 15:29:20 +0000 (11:29 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Fri, 3 Jun 2016 15:29:20 +0000 (11:29 -0400)
Adopt the same solution as in commit aa90e148ca70a235, but this time
let's put the ugliness inside the write_stderr() macro, instead of
expecting each call site to deal with it.  Back-port that decision
into psql/common.c where I got the macro from in the first place.

Per gripe from Peter Eisentraut.

src/bin/pg_dump/parallel.c
src/bin/psql/common.c

index 03bf732f64526a083744c5e44318fff058b90e72..51a8eee369db710f2d8c56896ac1aa3073ab81e3 100644 (file)
@@ -136,8 +136,18 @@ static volatile DumpSignalInformation signal_info;
 static CRITICAL_SECTION signal_info_lock;
 #endif
 
-/* Used from signal handlers, no buffering */
-#define write_stderr(str)      write(fileno(stderr), str, strlen(str))
+/*
+ * Write a simple string to stderr --- must be safe in a signal handler.
+ * We ignore the write() result since there's not much we could do about it.
+ * Certain compilers make that harder than it ought to be.
+ */
+#define write_stderr(str) \
+       do { \
+               const char *str_ = (str); \
+               int             rc_; \
+               rc_ = write(fileno(stderr), str_, strlen(str_)); \
+               (void) rc_; \
+       } while (0)
 
 
 #ifdef WIN32
index a287eeee1951f7f1e9de885de8b7b6cd3c9904d8..39c88fce7de7b23ed5653dace0fbe782e2409dd7 100644 (file)
@@ -175,8 +175,18 @@ static PGcancel *volatile cancelConn = NULL;
 static CRITICAL_SECTION cancelConnLock;
 #endif
 
-/* Used from signal handlers, no buffering */
-#define write_stderr(str)      write(fileno(stderr), str, strlen(str))
+/*
+ * Write a simple string to stderr --- must be safe in a signal handler.
+ * We ignore the write() result since there's not much we could do about it.
+ * Certain compilers make that harder than it ought to be.
+ */
+#define write_stderr(str) \
+       do { \
+               const char *str_ = (str); \
+               int             rc_; \
+               rc_ = write(fileno(stderr), str_, strlen(str_)); \
+               (void) rc_; \
+       } while (0)
 
 
 #ifndef WIN32
@@ -185,7 +195,6 @@ static void
 handle_sigint(SIGNAL_ARGS)
 {
        int                     save_errno = errno;
-       int                     rc;
        char            errbuf[256];
 
        /* if we are waiting for input, longjmp out of it */
@@ -202,16 +211,11 @@ handle_sigint(SIGNAL_ARGS)
        if (cancelConn != NULL)
        {
                if (PQcancel(cancelConn, errbuf, sizeof(errbuf)))
-               {
-                       rc = write_stderr("Cancel request sent\n");
-                       (void) rc;                      /* ignore errors, nothing we can do here */
-               }
+                       write_stderr("Cancel request sent\n");
                else
                {
-                       rc = write_stderr("Could not send cancel request: ");
-                       (void) rc;                      /* ignore errors, nothing we can do here */
-                       rc = write_stderr(errbuf);
-                       (void) rc;                      /* ignore errors, nothing we can do here */
+                       write_stderr("Could not send cancel request: ");
+                       write_stderr(errbuf);
                }
        }