Source-Changes-HG archive

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

[src/trunk]: src/lib/libwrap Always return from expandm() with errno unaltere...



details:   https://anonhg.NetBSD.org/src/rev/5af8de6d22a0
branches:  trunk
changeset: 995979:5af8de6d22a0
user:      kre <kre%NetBSD.org@localhost>
date:      Sun Jan 13 06:10:34 2019 +0000

description:
Always return from expandm() with errno unaltered, so on the
off chance it failed, there's still the possibility that whatever
processes the result will be able to deal with the %m that would
(presumably) be left in the format string.

And as a frill, don't call strerror() until we know we are
going to use its result (still call it only once, no matter
how many %m's are in the format string).

diffstat:

 lib/libwrap/expandm.c |  11 ++++++++---
 1 files changed, 8 insertions(+), 3 deletions(-)

diffs (51 lines):

diff -r 6e0dea4d7084 -r 5af8de6d22a0 lib/libwrap/expandm.c
--- a/lib/libwrap/expandm.c     Sun Jan 13 04:45:35 2019 +0000
+++ b/lib/libwrap/expandm.c     Sun Jan 13 06:10:34 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: expandm.c,v 1.6 2019/01/13 01:32:51 christos Exp $     */
+/*     $NetBSD: expandm.c,v 1.7 2019/01/13 06:10:34 kre Exp $  */
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -29,7 +29,7 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: expandm.c,v 1.6 2019/01/13 01:32:51 christos Exp $");
+__RCSID("$NetBSD: expandm.c,v 1.7 2019/01/13 06:10:34 kre Exp $");
 
 #include <limits.h>
 #include <stdio.h>
@@ -48,7 +48,8 @@
 const char * __attribute__((__format_arg__(1)))
 expandm(const char *fmt, const char *sf, char **rbuf)
 {
-       const char *e = strerror(errno);
+       const int err = errno;
+       const char *e = NULL;
        char *buf, *m, *nbuf;
        const char *ptr;
 
@@ -74,6 +75,8 @@
                         buf = nbuf;
                 }
 
+               if (__predict_true(e == NULL && (cnt & 1) != 0))
+                       e = strerror(err);
                if (asprintf(&nbuf, "%s%.*s%s", buf ? buf : "",
                    (int)(m - ptr), ptr, (cnt & 1) ? e : "%m") == -1)
                        goto out;
@@ -87,11 +90,13 @@
        free(buf);
        if (rbuf)
                *rbuf = nbuf;
+       errno = err;
        return nbuf;
 out:
        free(buf);
        if (rbuf)
                *rbuf = NULL;
+       errno = err;
        return fmt;
 }
 



Home | Main Index | Thread Index | Old Index