Source-Changes-HG archive

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

[src/trunk]: src/common/lib/libutil Formalize that the printf formats should ...



details:   https://anonhg.NetBSD.org/src/rev/15f1eb8c9a77
branches:  trunk
changeset: 967367:15f1eb8c9a77
user:      christos <christos%NetBSD.org@localhost>
date:      Fri Dec 06 19:36:21 2019 +0000

description:
Formalize that the printf formats should be uintmax_t so we can
uniformly use 'j' in the user-provided formatting strings instead
of depending on _LP64 to use 'll' or 'l' (and the PRI macros). The
alternative is to parse the printf format manually to determine
which modifier to apply which would make this transparent to the
user (they could still always use '%u' or '%x'), but that's too
painful.

diffstat:

 common/lib/libutil/snprintb.c |  18 +++++++++---------
 1 files changed, 9 insertions(+), 9 deletions(-)

diffs (71 lines):

diff -r 58fdc448ea18 -r 15f1eb8c9a77 common/lib/libutil/snprintb.c
--- a/common/lib/libutil/snprintb.c     Fri Dec 06 19:31:52 2019 +0000
+++ b/common/lib/libutil/snprintb.c     Fri Dec 06 19:36:21 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: snprintb.c,v 1.21 2019/06/17 17:03:58 christos Exp $   */
+/*     $NetBSD: snprintb.c,v 1.22 2019/12/06 19:36:22 christos Exp $   */
 
 /*-
  * Copyright (c) 2002 The NetBSD Foundation, Inc.
@@ -41,7 +41,7 @@
 
 #  include <sys/cdefs.h>
 #  if defined(LIBC_SCCS) && !defined(lint)
-__RCSID("$NetBSD: snprintb.c,v 1.21 2019/06/17 17:03:58 christos Exp $");
+__RCSID("$NetBSD: snprintb.c,v 1.22 2019/12/06 19:36:22 christos Exp $");
 #  endif
 
 #  include <sys/types.h>
@@ -51,7 +51,7 @@
 #  include <errno.h>
 # else /* ! _KERNEL */
 #  include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: snprintb.c,v 1.21 2019/06/17 17:03:58 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: snprintb.c,v 1.22 2019/12/06 19:36:22 christos Exp $");
 #  include <sys/param.h>
 #  include <sys/inttypes.h>
 #  include <sys/systm.h>
@@ -81,13 +81,13 @@
        ch = *bitfmt++;
        switch (ch != '\177' ? ch : *bitfmt++) {
        case 8:
-               sbase = "0%" PRIo64;
+               sbase = "%#jo";
                break;
        case 10:
-               sbase = "%" PRId64;
+               sbase = "%ju";
                break;
        case 16:
-               sbase = "0x%" PRIx64;
+               sbase = "%#jx";
                break;
        default:
                goto internal;
@@ -97,7 +97,7 @@
        if (l_max > 0)
                buflen--;
 
-       t_len = snprintf(bp, buflen, sbase, val);
+       t_len = snprintf(bp, buflen, sbase, (uintmax_t)val);
        if (t_len < 0)
                goto internal;
 
@@ -128,7 +128,7 @@
                  }                                                     \
                  STORE('>'); STORE('\0');                              \
                  if ((size_t)t_len < buflen)                           \
-                       snprintf(bp, buflen - t_len, sbase, val);       \
+                       snprintf(bp, buflen - t_len, sbase, (uintmax_t)val);\
                  t_len += v_len; l_len = v_len; bp += v_len;           \
                } while ( /* CONSTCOND */ 0)
 
@@ -168,7 +168,7 @@
                }
 #define FMTSTR(sb, f)                                                  \
        do {                                                            \
-               f_len = snprintf(bp, buflen - t_len, sb, f);            \
+               f_len = snprintf(bp, buflen - t_len, sb, (uintmax_t)f); \
                if (f_len < 0)                                          \
                        goto internal;                                  \
                t_len += f_len;                                         \



Home | Main Index | Thread Index | Old Index