Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/audio/play Use err(3)/errx(3) properly to avoid "wri...



details:   https://anonhg.NetBSD.org/src/rev/de32cddec4b1
branches:  trunk
changeset: 998830:de32cddec4b1
user:      isaki <isaki%NetBSD.org@localhost>
date:      Sat May 04 08:27:30 2019 +0000

description:
Use err(3)/errx(3) properly to avoid "write failed: Undefined error: 0".

diffstat:

 usr.bin/audio/play/play.c |  21 ++++++++++++++-------
 1 files changed, 14 insertions(+), 7 deletions(-)

diffs (69 lines):

diff -r 618954f85a8e -r de32cddec4b1 usr.bin/audio/play/play.c
--- a/usr.bin/audio/play/play.c Sat May 04 08:26:51 2019 +0000
+++ b/usr.bin/audio/play/play.c Sat May 04 08:27:30 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: play.c,v 1.56 2018/11/16 13:55:17 mlelstv Exp $        */
+/*     $NetBSD: play.c,v 1.57 2019/05/04 08:27:30 isaki Exp $  */
 
 /*
  * Copyright (c) 1999, 2000, 2001, 2002, 2010 Matthew R. Green
@@ -28,7 +28,7 @@
 #include <sys/cdefs.h>
 
 #ifndef lint
-__RCSID("$NetBSD: play.c,v 1.56 2018/11/16 13:55:17 mlelstv Exp $");
+__RCSID("$NetBSD: play.c,v 1.57 2019/05/04 08:27:30 isaki Exp $");
 #endif
 
 
@@ -224,6 +224,7 @@
        off_t datasize = 0;
        ssize_t hdrlen;
        int fd;
+       int nw;
 
        if (file[0] == '-' && file[1] == 0) {
                play_fd("standard input", STDIN_FILENO);
@@ -283,13 +284,19 @@
        }
 
        while ((uint64_t)datasize > bufsize) {
-               if ((size_t)write(audiofd, addr, bufsize) != bufsize)
+               nw = write(audiofd, addr, bufsize);
+               if (nw == -1)
                        err(1, "write failed");
+               if ((size_t)nw != bufsize)
+                       errx(1, "write failed");
                addr = (char *)addr + bufsize;
                datasize -= bufsize;
        }
-       if ((off_t)write(audiofd, addr, datasize) != datasize)
+       nw = write(audiofd, addr, datasize);
+       if (nw == -1)
                err(1, "final write failed");
+       if ((off_t)nw != datasize)
+               errx(1, "final write failed");
 
        if (ioctl(audiofd, AUDIO_DRAIN) < 0 && !qflag)
                warn("audio drain ioctl failed");
@@ -341,8 +348,10 @@
                if (datasize != 0 && dataout + nr > datasize)
                        nr = datasize - dataout;
                nw = write(audiofd, buffer, nr);
+               if (nw == -1)
+                       err(1, "audio device write failed");
                if (nw != nr)
-                       goto write_error;
+                       errx(1, "audio device write failed");
                dataout += nw;
                nr = read(fd, buffer, bufsize);
                if (nr == -1)
@@ -356,8 +365,6 @@
        return;
 read_error:
        err(1, "read of standard input failed");
-write_error:
-       err(1, "audio device write failed");
 }
 
 /*



Home | Main Index | Thread Index | Old Index