lint: add more details to message about redeclared tag
This commit is contained in:
parent
810c465bf3
commit
39bf493754
|
@ -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);
|
||||
|
|
|
@ -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]
|
||||
|
|
|
@ -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;
|
||||
};
|
||||
/*
|
||||
|
|
|
@ -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]
|
||||
|
|
|
@ -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 @@ newtag(sym_t *tag, scl_t scl, bool decl, bool semi)
|
|||
}
|
||||
} 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;
|
||||
|
|
|
@ -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 @@ const char *const msgs[] = {
|
|||
"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 */
|
||||
|
|
Loading…
Reference in New Issue