Source-Changes-HG archive

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

[src/trunk]: src/usr.bin/printf Tighten syntax a little (no more %*4.*2d nons...



details:   https://anonhg.NetBSD.org/src/rev/090962e8368b
branches:  trunk
changeset: 993270:090962e8368b
user:      kre <kre%NetBSD.org@localhost>
date:      Mon Sep 03 04:10:20 2018 +0000

description:
Tighten syntax a little (no more %*4.*2d nonsense).
Include the format collected so far in "missing format char" err message.
Minor KNF and whitespace.

diffstat:

 usr.bin/printf/printf.c |  34 +++++++++++++++++++++++-----------
 1 files changed, 23 insertions(+), 11 deletions(-)

diffs (97 lines):

diff -r 439e34c95c49 -r 090962e8368b usr.bin/printf/printf.c
--- a/usr.bin/printf/printf.c   Mon Sep 03 02:33:30 2018 +0000
+++ b/usr.bin/printf/printf.c   Mon Sep 03 04:10:20 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: printf.c,v 1.43 2018/08/31 17:27:35 kre Exp $  */
+/*     $NetBSD: printf.c,v 1.44 2018/09/03 04:10:20 kre Exp $  */
 
 /*
  * Copyright (c) 1989, 1993
@@ -41,7 +41,7 @@
 #if 0
 static char sccsid[] = "@(#)printf.c   8.2 (Berkeley) 3/22/95";
 #else
-__RCSID("$NetBSD: printf.c,v 1.43 2018/08/31 17:27:35 kre Exp $");
+__RCSID("$NetBSD: printf.c,v 1.44 2018/09/03 04:10:20 kre Exp $");
 #endif
 #endif /* not lint */
 
@@ -121,7 +121,9 @@
 #ifdef main
 int main(int, char *[]);
 #endif
-int main(int argc, char *argv[])
+
+int
+main(int argc, char *argv[])
 {
        char *fmt, *start;
        int fieldwidth, precision;
@@ -189,34 +191,39 @@
                        if (*fmt == '*') {
                                fmt++;
                                fieldwidth = getwidth();
-                       } else
+                       } else {
                                fieldwidth = -1;
 
-                       /* skip to possible '.', get following precision */
-                       fmt += strspn(fmt, SKIP2);
+                               /* skip to possible '.' for precision */
+                               fmt += strspn(fmt, SKIP2);
+                       }
+
                        if (*fmt == '.') {
+                                /* get following precision */
                                fmt++;
                                if (*fmt == '*') {
                                        fmt++;
                                        precision = getwidth();
-                               } else
+                               } else {
                                        precision = -1;
+                                       fmt += strspn(fmt, SKIP2);
+                               }
                        } else
                                precision = -1;
 
-                       fmt += strspn(fmt, SKIP2);
-
                        ch = *fmt;
                        if (!ch) {
-                               warnx("missing format character");
+                               warnx("%s: missing format character", start);
                                return 1;
                        }
+
                        /*
                         * null terminate format string to we can use it
                         * as an argument to printf.
                         */
                        nextch = fmt[1];
                        fmt[1] = 0;
+
                        switch (ch) {
 
                        case 'B': {
@@ -323,6 +330,11 @@
                                        goto out;
                                break;
                        }
+                       case '%':
+                               /* Don't ask, but this is useful ... */
+                               if (fieldwidth == 'N' && precision == 'B')
+                                       return 0;
+                               /* FALLTHROUGH */
                        default:
                                warnx("%s: invalid directive", start);
                                return 1;
@@ -617,7 +629,7 @@
        char *s, *ep;
 
        s = *gargv;
-       if (!*gargv)
+       if (s == NULL)
                return 0;
        gargv++;
 



Home | Main Index | Thread Index | Old Index