Source-Changes-HG archive

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

[src/trunk]: src/usr.bin/xlint/lint1 lint: add more details to message about ...



details:   https://anonhg.NetBSD.org/src/rev/f8e5a494af09
branches:  trunk
changeset: 985278:f8e5a494af09
user:      rillig <rillig%NetBSD.org@localhost>
date:      Mon Aug 16 06:49:56 2021 +0000

description:
lint: add more details to message about redeclared tag

diffstat:

 tests/usr.bin/xlint/lint1/msg_046.c   |  18 +++++++++---------
 tests/usr.bin/xlint/lint1/msg_046.exp |  14 +++++++-------
 tests/usr.bin/xlint/lint1/msg_260.c   |  22 +++++++++++++---------
 tests/usr.bin/xlint/lint1/msg_260.exp |  12 ++++++------
 usr.bin/xlint/lint1/decl.c            |  14 ++++++++------
 usr.bin/xlint/lint1/err.c             |   6 +++---
 6 files changed, 46 insertions(+), 40 deletions(-)

diffs (196 lines):

diff -r a3d246c8f0e5 -r f8e5a494af09 tests/usr.bin/xlint/lint1/msg_046.c
--- a/tests/usr.bin/xlint/lint1/msg_046.c       Mon Aug 16 06:30:43 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_046.c       Mon Aug 16 06:49:56 2021 +0000
@@ -1,36 +1,36 @@
-/*     $NetBSD: msg_046.c,v 1.3 2021/08/16 06:30:43 rillig Exp $       */
+/*     $NetBSD: msg_046.c,v 1.4 2021/08/16 06:49:57 rillig Exp $       */
 # 3 "msg_046.c"
 
-// Test for message: (%s) tag redeclared [46]
+// Test for message: %s tag '%s' redeclared as %s [46]
 
 /* expect+1: warning: struct tag1 never defined [233] */
 struct tag1;
-/* expect+2: error: (struct) tag redeclared [46] */
+/* expect+2: error: struct tag 'tag1' redeclared as union [46] */
 /* expect+1: warning: union tag1 never defined [234] */
 union tag1;
 
 /* expect+1: warning: union tag2 never defined [234] */
 union tag2;
-/* expect+2: error: (union) tag redeclared [46] */
+/* expect+2: error: union tag 'tag2' redeclared as enum [46] */
 /* expect+1: warning: enum tag2 never defined [235] */
 enum tag2;
 
 /* expect+1: warning: enum tag3 never defined [235] */
 enum tag3;
-/* expect+2: error: (enum) tag redeclared [46] */
+/* expect+2: error: enum tag 'tag3' redeclared as struct [46] */
 /* expect+1: warning: struct tag3 never defined [233] */
 struct tag3;
 
-/* expect+2: error: (union) tag redeclared [46] */
+/* expect+2: error: union tag 'tag1' redeclared as struct [46] */
 /* expect+1: warning: struct tag1 never defined [233] */
 struct tag1 *use_tag1(void);
-/* expect+2: error: (enum) tag redeclared [46] */
+/* expect+2: error: enum tag 'tag2' redeclared as union [46] */
 /* expect+1: warning: union tag2 never defined [234] */
 union tag2 *use_tag2(void);
-/* expect+2: error: (struct) tag redeclared [46] */
+/* expect+2: error: struct tag 'tag3' redeclared as enum [46] */
 /* expect+1: warning: enum tag3 never defined [235] */
 enum tag3 *use_tag3(void);
 
-/* expect+2: error: (struct) tag redeclared [46] */
+/* expect+2: error: struct tag 'tag1' redeclared as union [46] */
 /* expect+1: warning: union tag1 never defined [234] */
 union tag1 *mismatch_tag1(void);
diff -r a3d246c8f0e5 -r f8e5a494af09 tests/usr.bin/xlint/lint1/msg_046.exp
--- a/tests/usr.bin/xlint/lint1/msg_046.exp     Mon Aug 16 06:30:43 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_046.exp     Mon Aug 16 06:49:56 2021 +0000
@@ -1,10 +1,10 @@
-msg_046.c(10): error: (struct) tag redeclared [46]
-msg_046.c(16): error: (union) tag redeclared [46]
-msg_046.c(22): error: (enum) tag redeclared [46]
-msg_046.c(26): error: (union) tag redeclared [46]
-msg_046.c(29): error: (enum) tag redeclared [46]
-msg_046.c(32): error: (struct) tag redeclared [46]
-msg_046.c(36): error: (struct) tag redeclared [46]
+msg_046.c(10): error: struct tag 'tag1' redeclared as union [46]
+msg_046.c(16): error: union tag 'tag2' redeclared as enum [46]
+msg_046.c(22): error: enum tag 'tag3' redeclared as struct [46]
+msg_046.c(26): error: union tag 'tag1' redeclared as struct [46]
+msg_046.c(29): error: enum tag 'tag2' redeclared as union [46]
+msg_046.c(32): error: struct tag 'tag3' redeclared as enum [46]
+msg_046.c(36): error: struct tag 'tag1' redeclared as union [46]
 msg_046.c(7): warning: struct tag1 never defined [233]
 msg_046.c(10): warning: union tag1 never defined [234]
 msg_046.c(13): warning: union tag2 never defined [234]
diff -r a3d246c8f0e5 -r f8e5a494af09 tests/usr.bin/xlint/lint1/msg_260.c
--- a/tests/usr.bin/xlint/lint1/msg_260.c       Mon Aug 16 06:30:43 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_260.c       Mon Aug 16 06:49:56 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: msg_260.c,v 1.3 2021/04/18 07:31:47 rillig Exp $       */
+/*     $NetBSD: msg_260.c,v 1.4 2021/08/16 06:49:57 rillig Exp $       */
 # 3 "msg_260.c"
 
 // Test for message: previous declaration of %s [260]
@@ -6,22 +6,26 @@
 /* lint1-extra-flags: -r */
 
 # 100 "header.h" 1
-struct s {             /* expect: 260 */
+/* expect+1: previous declaration of s [260] */
+struct s {
     int member;
 };
-# 13 "msg_260.c" 2
+# 14 "msg_260.c" 2
 
 # 200 "header.h" 1
-union s {              /* expect: tag redeclared *//* expect: 260 */
+/* expect+2: error: struct tag 's' redeclared as union [46] */
+/* expect+1: previous declaration of s [260] */
+union s {
     int member;
 };
 /*
- * FIXME: the stack trace for the 260 is wrong, as the 260 is included from
- * line 8, not from line 14.
+ * FIXME: the stack trace for the message 260 is wrong, as the previous
+ * declaration is included from logical line msg_260.c:8, not from
+ * msg_260.c:15.
  */
-# 19 "msg_160.c" 2
-
-union s {              /* expect: tag redeclared */
+# 27 "msg_260.c" 2
+/* expect+1: error: union tag 's' redeclared as union [46] */
+union s {
     int member;
 };
 /*
diff -r a3d246c8f0e5 -r f8e5a494af09 tests/usr.bin/xlint/lint1/msg_260.exp
--- a/tests/usr.bin/xlint/lint1/msg_260.exp     Mon Aug 16 06:30:43 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_260.exp     Mon Aug 16 06:49:56 2021 +0000
@@ -1,6 +1,6 @@
-header.h(200): error: (struct) tag redeclared [46]
-       included from msg_260.c(14)
-header.h(100): previous declaration of s [260]
-       included from msg_260.c(14)
-msg_160.c(20): error: (union) tag redeclared [46]
-header.h(200): previous declaration of s [260]
+header.h(202): error: struct tag 's' redeclared as union [46]
+       included from msg_260.c(15)
+header.h(101): previous declaration of s [260]
+       included from msg_260.c(15)
+msg_260.c(28): error: union tag 's' redeclared as union [46]
+header.h(202): previous declaration of s [260]
diff -r a3d246c8f0e5 -r f8e5a494af09 usr.bin/xlint/lint1/decl.c
--- a/usr.bin/xlint/lint1/decl.c        Mon Aug 16 06:30:43 2021 +0000
+++ b/usr.bin/xlint/lint1/decl.c        Mon Aug 16 06:49:56 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: decl.c,v 1.221 2021/08/10 20:43:12 rillig Exp $ */
+/* $NetBSD: decl.c,v 1.222 2021/08/16 06:49:56 rillig Exp $ */
 
 /*
  * Copyright (c) 1996 Christopher G. Demetriou.  All Rights Reserved.
@@ -38,7 +38,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: decl.c,v 1.221 2021/08/10 20:43:12 rillig Exp $");
+__RCSID("$NetBSD: decl.c,v 1.222 2021/08/16 06:49:56 rillig Exp $");
 #endif
 
 #include <sys/param.h>
@@ -1776,14 +1776,16 @@
                }
        } else {
                if (tag->s_scl != scl) {
-                       /* (%s) tag redeclared */
-                       error(46, storage_class_name(tag->s_scl));
+                       /* %s tag '%s' redeclared as %s */
+                       error(46, storage_class_name(tag->s_scl),
+                           tag->s_name, storage_class_name(scl));
                        print_previous_declaration(-1, tag);
                        tag = pushdown(tag);
                        dcs->d_next->d_nonempty_decl = true;
                } else if (decl && !is_incomplete(tag->s_type)) {
-                       /* (%s) tag redeclared */
-                       error(46, storage_class_name(tag->s_scl));
+                       /* %s tag '%s' redeclared as %s */
+                       error(46, storage_class_name(tag->s_scl),
+                           tag->s_name, storage_class_name(scl));
                        print_previous_declaration(-1, tag);
                        tag = pushdown(tag);
                        dcs->d_next->d_nonempty_decl = true;
diff -r a3d246c8f0e5 -r f8e5a494af09 usr.bin/xlint/lint1/err.c
--- a/usr.bin/xlint/lint1/err.c Mon Aug 16 06:30:43 2021 +0000
+++ b/usr.bin/xlint/lint1/err.c Mon Aug 16 06:49:56 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: err.c,v 1.136 2021/08/14 13:00:55 rillig Exp $ */
+/*     $NetBSD: err.c,v 1.137 2021/08/16 06:49:56 rillig Exp $ */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: err.c,v 1.136 2021/08/14 13:00:55 rillig Exp $");
+__RCSID("$NetBSD: err.c,v 1.137 2021/08/16 06:49:56 rillig Exp $");
 #endif
 
 #include <sys/types.h>
@@ -100,7 +100,7 @@
        "redefinition hides earlier one: %s",                         /* 43 */
        "declaration introduces new type in ANSI C: %s %s",           /* 44 */
        "base type is really '%s %s'",                                /* 45 */
-       "(%s) tag redeclared",                                        /* 46 */
+       "%s tag '%s' redeclared as %s",                               /* 46 */
        "zero sized %s is a C9X feature",                             /* 47 */
        "overflow in enumeration values: %s",                         /* 48 */
        "anonymous struct/union members is a C9X feature",            /* 49 */



Home | Main Index | Thread Index | Old Index