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: fix wrong warning about main falli...
details: https://anonhg.NetBSD.org/src/rev/a090f2456574
branches: trunk
changeset: 980878:a090f2456574
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Feb 21 09:17:55 2021 +0000
description:
lint: fix wrong warning about main falling off the bottom in C99 mode
This gets lint a small step closer to implementing C99.
diffstat:
tests/usr.bin/xlint/lint1/d_cvt_constant.c | 6 ++----
tests/usr.bin/xlint/lint1/d_cvt_constant.exp | 1 -
tests/usr.bin/xlint/lint1/msg_217.c | 14 +++++++++++++-
usr.bin/xlint/lint1/func.c | 26 +++++++++++++++++++-------
4 files changed, 34 insertions(+), 13 deletions(-)
diffs (102 lines):
diff -r a309ac3b5f4b -r a090f2456574 tests/usr.bin/xlint/lint1/d_cvt_constant.c
--- a/tests/usr.bin/xlint/lint1/d_cvt_constant.c Sun Feb 21 09:07:58 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/d_cvt_constant.c Sun Feb 21 09:17:55 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: d_cvt_constant.c,v 1.4 2021/02/21 09:07:58 rillig Exp $ */
+/* $NetBSD: d_cvt_constant.c,v 1.5 2021/02/21 09:17:55 rillig Exp $ */
# 3 "d_cvt_constant.c"
/* the second assignment assumes failed before */
@@ -9,6 +9,4 @@
int foo = 0;
if (foo)
x = 1;
-} /* expect: 217 */
-// FIXME: Since C99, main may fall off the bottom without returning a value.
-// Therefore there should be no warning 217.
+}
diff -r a309ac3b5f4b -r a090f2456574 tests/usr.bin/xlint/lint1/d_cvt_constant.exp
--- a/tests/usr.bin/xlint/lint1/d_cvt_constant.exp Sun Feb 21 09:07:58 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/d_cvt_constant.exp Sun Feb 21 09:17:55 2021 +0000
@@ -1,2 +1,1 @@
d_cvt_constant.c(8): warning: x set but not used in function main [191]
-d_cvt_constant.c(12): warning: function main falls off bottom without returning value [217]
diff -r a309ac3b5f4b -r a090f2456574 tests/usr.bin/xlint/lint1/msg_217.c
--- a/tests/usr.bin/xlint/lint1/msg_217.c Sun Feb 21 09:07:58 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_217.c Sun Feb 21 09:17:55 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: msg_217.c,v 1.3 2021/01/31 13:33:10 rillig Exp $ */
+/* $NetBSD: msg_217.c,v 1.4 2021/02/21 09:17:55 rillig Exp $ */
# 3 "msg_217.c"
// Test for message: function %s falls off bottom without returning value [217]
@@ -30,3 +30,15 @@
return i;
} while (/*CONSTCOND*/0); /*FIXME*//* expect: 193 */
} /*FIXME*//* expect: 217 */
+
+/*
+ * C99 5.1.2.2.3 "Program termination" p1 defines that as a special exception,
+ * the function 'main' does not have to return a value, reaching the bottom
+ * is equivalent to returning 0.
+ *
+ * Before func.c 1.72 from 2021-02-21, lint had wrongly warned about this.
+ */
+int
+main(void)
+{
+}
diff -r a309ac3b5f4b -r a090f2456574 usr.bin/xlint/lint1/func.c
--- a/usr.bin/xlint/lint1/func.c Sun Feb 21 09:07:58 2021 +0000
+++ b/usr.bin/xlint/lint1/func.c Sun Feb 21 09:17:55 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: func.c,v 1.71 2021/02/19 22:27:49 rillig Exp $ */
+/* $NetBSD: func.c,v 1.72 2021/02/21 09:17:55 rillig Exp $ */
/*
* Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
#include <sys/cdefs.h>
#if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: func.c,v 1.71 2021/02/19 22:27:49 rillig Exp $");
+__RCSID("$NetBSD: func.c,v 1.72 2021/02/21 09:17:55 rillig Exp $");
#endif
#include <stdlib.h>
@@ -337,6 +337,22 @@
reached = true;
}
+static void
+check_missing_return_value(void)
+{
+ if (funcsym->s_type->t_subt->t_tspec == VOID)
+ return;
+ if (funcsym->s_return_type_implicit_int)
+ return;
+
+ /* C99 5.1.2.2.3 "Program termination" p1 */
+ if (Sflag && strcmp(funcsym->s_name, "main") == 0)
+ return;
+
+ /* function %s falls off bottom without returning value */
+ warning(217, funcsym->s_name);
+}
+
/*
* Called at the end of a function definition.
*/
@@ -348,11 +364,7 @@
if (reached) {
cstmt->c_had_return_noval = true;
- if (funcsym->s_type->t_subt->t_tspec != VOID &&
- !funcsym->s_return_type_implicit_int) {
- /* func. %s falls off bottom without returning value */
- warning(217, funcsym->s_name);
- }
+ check_missing_return_value();
}
/*
Home |
Main Index |
Thread Index |
Old Index