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: casting to a struct is not allowed...



details:   https://anonhg.NetBSD.org/src/rev/5511cf2ec44c
branches:  trunk
changeset: 984998:5511cf2ec44c
user:      rillig <rillig%NetBSD.org@localhost>
date:      Tue Aug 03 18:38:02 2021 +0000

description:
lint: casting to a struct is not allowed in C99, only with GCC

diffstat:

 tests/usr.bin/xlint/lint1/expr_cast.c   |  18 +++++++++---------
 tests/usr.bin/xlint/lint1/expr_cast.exp |   3 ++-
 tests/usr.bin/xlint/lint1/msg_214.c     |  11 ++++++++---
 tests/usr.bin/xlint/lint1/msg_214.exp   |   2 +-
 usr.bin/xlint/lint1/decl.c              |   6 +++---
 usr.bin/xlint/lint1/tree.c              |   7 ++++---
 6 files changed, 27 insertions(+), 20 deletions(-)

diffs (128 lines):

diff -r c2966816aa75 -r 5511cf2ec44c tests/usr.bin/xlint/lint1/expr_cast.c
--- a/tests/usr.bin/xlint/lint1/expr_cast.c     Tue Aug 03 18:03:54 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/expr_cast.c     Tue Aug 03 18:38:02 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: expr_cast.c,v 1.1 2021/08/03 18:03:54 rillig Exp $     */
+/*     $NetBSD: expr_cast.c,v 1.2 2021/08/03 18:38:02 rillig Exp $     */
 # 3 "expr_cast.c"
 
 /*
@@ -6,8 +6,14 @@
  *
  * K&R C does not mention any restrictions on the target type.
  * C90 requires both the source type and the target type to be scalar.
+ *
+ * GCC allows casting to a struct type but there is no documentation about
+ * it at https://gcc.gnu.org/onlinedocs/gcc/C-Extensions.html.  See
+ * c-typeck.c, function build_c_cast, RECORD_OR_UNION_TYPE_P.
  */
 
+/* lint1-flags: -Sw */
+
 struct S {
        int member;
 };
@@ -20,14 +26,8 @@
        } local = {
                0.0
        };
-       /* expect-3: warning: 'local' set but not used in function 'cast' [191] */
-       /*
-        * ^^ XXX: The variable _is_ used, but only in a semantically wrong
-        * expression.  Lint should rather warn about the invalid cast in the
-        * 'return' statement, but since all C compilers since C90 are
-        * required to detect this already, there is no point in duplicating
-        * that work.
-        */
 
+       /* expect+2: error: invalid cast from 'struct S' to 'struct S' [147] */
+       /* expect+1: warning: function cast expects to return value [214] */
        return (struct S)local;
 }
diff -r c2966816aa75 -r 5511cf2ec44c tests/usr.bin/xlint/lint1/expr_cast.exp
--- a/tests/usr.bin/xlint/lint1/expr_cast.exp   Tue Aug 03 18:03:54 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/expr_cast.exp   Tue Aug 03 18:38:02 2021 +0000
@@ -1,1 +1,2 @@
-expr_cast.c(20): warning: 'local' set but not used in function 'cast' [191]
+expr_cast.c(32): error: invalid cast from 'struct S' to 'struct S' [147]
+expr_cast.c(32): warning: function cast expects to return value [214]
diff -r c2966816aa75 -r 5511cf2ec44c tests/usr.bin/xlint/lint1/msg_214.c
--- a/tests/usr.bin/xlint/lint1/msg_214.c       Tue Aug 03 18:03:54 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_214.c       Tue Aug 03 18:38:02 2021 +0000
@@ -1,7 +1,12 @@
-/*     $NetBSD: msg_214.c,v 1.2 2021/02/21 09:07:58 rillig Exp $       */
+/*     $NetBSD: msg_214.c,v 1.3 2021/08/03 18:38:02 rillig Exp $       */
 # 3 "msg_214.c"
 
 // Test for message: function %s expects to return value [214]
 
-TODO: "Add example code that triggers the above message." /* expect: 249 */
-TODO: "Add example code that almost triggers the above message."
+int
+int_function(void)
+{
+       /* TODO: add quotes around '%s' */
+       /* expect+1: warning: function int_function expects to return value [214] */
+       return;
+}
diff -r c2966816aa75 -r 5511cf2ec44c tests/usr.bin/xlint/lint1/msg_214.exp
--- a/tests/usr.bin/xlint/lint1/msg_214.exp     Tue Aug 03 18:03:54 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_214.exp     Tue Aug 03 18:38:02 2021 +0000
@@ -1,1 +1,1 @@
-msg_214.c(6): error: syntax error ':' [249]
+msg_214.c(11): warning: function int_function expects to return value [214]
diff -r c2966816aa75 -r 5511cf2ec44c usr.bin/xlint/lint1/decl.c
--- a/usr.bin/xlint/lint1/decl.c        Tue Aug 03 18:03:54 2021 +0000
+++ b/usr.bin/xlint/lint1/decl.c        Tue Aug 03 18:38:02 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: decl.c,v 1.217 2021/08/01 18:37:29 rillig Exp $ */
+/* $NetBSD: decl.c,v 1.218 2021/08/03 18:38:02 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.217 2021/08/01 18:37:29 rillig Exp $");
+__RCSID("$NetBSD: decl.c,v 1.218 2021/08/03 18:38:02 rillig Exp $");
 #endif
 
 #include <sys/param.h>
@@ -2230,7 +2230,7 @@
                                return false;
                }
 
-               /* dont check prototypes for traditional */
+               /* don't check prototypes for traditional */
                if (t == FUNC && !tflag) {
                        if (tp1->t_proto && tp2->t_proto) {
                                if (!eqargs(tp1, tp2, dowarn))
diff -r c2966816aa75 -r 5511cf2ec44c usr.bin/xlint/lint1/tree.c
--- a/usr.bin/xlint/lint1/tree.c        Tue Aug 03 18:03:54 2021 +0000
+++ b/usr.bin/xlint/lint1/tree.c        Tue Aug 03 18:38:02 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: tree.c,v 1.327 2021/08/03 17:44:59 rillig Exp $        */
+/*     $NetBSD: tree.c,v 1.328 2021/08/03 18:38:02 rillig Exp $        */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: tree.c,v 1.327 2021/08/03 17:44:59 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.328 2021/08/03 18:38:02 rillig Exp $");
 #endif
 
 #include <float.h>
@@ -3414,7 +3414,8 @@
                error(329, type_name(tn->tn_type), type_name(tp));
                return NULL;
        } else if (nt == STRUCT || nt == ARRAY || nt == FUNC) {
-               if (!Sflag || nt == ARRAY || nt == FUNC)
+               /* Casting to a struct is an undocumented GCC extension. */
+               if (!(gflag && nt == STRUCT))
                        goto invalid_cast;
        } else if (ot == STRUCT || ot == UNION) {
                goto invalid_cast;



Home | Main Index | Thread Index | Old Index