Module Name: src Committed By: rillig Date: Sat Apr 2 20:12:46 UTC 2022
Modified Files: src/tests/usr.bin/xlint/lint1: msg_022.c msg_022.exp src/usr.bin/xlint/lint1: decl.c err.c func.c Log Message: lint: try harder to recover after syntax errors lint: assertion "false" failed in declarator_name at decl.c:1596 near msg_022.c:22 To generate a diff of this commit: cvs rdiff -u -r1.2 -r1.3 src/tests/usr.bin/xlint/lint1/msg_022.c \ src/tests/usr.bin/xlint/lint1/msg_022.exp cvs rdiff -u -r1.263 -r1.264 src/usr.bin/xlint/lint1/decl.c cvs rdiff -u -r1.155 -r1.156 src/usr.bin/xlint/lint1/err.c cvs rdiff -u -r1.129 -r1.130 src/usr.bin/xlint/lint1/func.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/tests/usr.bin/xlint/lint1/msg_022.c diff -u src/tests/usr.bin/xlint/lint1/msg_022.c:1.2 src/tests/usr.bin/xlint/lint1/msg_022.c:1.3 --- src/tests/usr.bin/xlint/lint1/msg_022.c:1.2 Sun Feb 21 09:07:58 2021 +++ src/tests/usr.bin/xlint/lint1/msg_022.c Sat Apr 2 20:12:46 2022 @@ -1,7 +1,30 @@ -/* $NetBSD: msg_022.c,v 1.2 2021/02/21 09:07:58 rillig Exp $ */ +/* $NetBSD: msg_022.c,v 1.3 2022/04/02 20:12:46 rillig Exp $ */ # 3 "msg_022.c" // Test for message: incomplete or misplaced function definition [22] -TODO: "Add example code that triggers the above message." /* expect: 249 */ +/* + * Before decl.c 1.264 and func.c 1.130 from 2022-04-02, lint ran into + * assertion failures after trying to recover from the below syntax error. + */ +/* expect+1: error: syntax error 'f' [249] */ +unsigned long asdf = sizeof(int f() {}); + +/* Give the parser a chance to recover. */ +/* expect+1: warning: empty declaration [0] */ +; + +/* + * Before decl.c 1.264 and func.c 1.130 from 2022-04-02, lint ran into + * assertion failures after trying to recover from the below syntax error. + */ +/* expect+1: error: syntax error 'param1' [249] */ +unsigned long sz = sizeof(int(param1, param2)); + +/* Give the parser a chance to recover. */ +/* expect+1: warning: empty declaration [0] */ +; + +/* expect+1: error: syntax error ':' [249] */ +TODO: "Add example code that triggers the above message." TODO: "Add example code that almost triggers the above message." Index: src/tests/usr.bin/xlint/lint1/msg_022.exp diff -u src/tests/usr.bin/xlint/lint1/msg_022.exp:1.2 src/tests/usr.bin/xlint/lint1/msg_022.exp:1.3 --- src/tests/usr.bin/xlint/lint1/msg_022.exp:1.2 Sun Mar 21 20:44:59 2021 +++ src/tests/usr.bin/xlint/lint1/msg_022.exp Sat Apr 2 20:12:46 2022 @@ -1 +1,5 @@ -msg_022.c(6): error: syntax error ':' [249] +msg_022.c(11): error: syntax error 'f' [249] +msg_022.c(15): warning: empty declaration [0] +msg_022.c(22): error: syntax error 'param1' [249] +msg_022.c(26): warning: empty declaration [0] +msg_022.c(29): error: syntax error ':' [249] Index: src/usr.bin/xlint/lint1/decl.c diff -u src/usr.bin/xlint/lint1/decl.c:1.263 src/usr.bin/xlint/lint1/decl.c:1.264 --- src/usr.bin/xlint/lint1/decl.c:1.263 Sat Apr 2 18:15:43 2022 +++ src/usr.bin/xlint/lint1/decl.c Sat Apr 2 20:12:45 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: decl.c,v 1.263 2022/04/02 18:15:43 rillig Exp $ */ +/* $NetBSD: decl.c,v 1.264 2022/04/02 20:12:45 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.263 2022/04/02 18:15:43 rillig Exp $"); +__RCSID("$NetBSD: decl.c,v 1.264 2022/04/02 20:12:45 rillig Exp $"); #endif #include <sys/param.h> @@ -1613,6 +1613,9 @@ declarator_name(sym_t *sym) sym->s_def = DECL; } break; + case ABSTRACT: /* try to continue after syntax errors */ + sc = NOSCL; + break; default: lint_assert(/*CONSTCOND*/false); } Index: src/usr.bin/xlint/lint1/err.c diff -u src/usr.bin/xlint/lint1/err.c:1.155 src/usr.bin/xlint/lint1/err.c:1.156 --- src/usr.bin/xlint/lint1/err.c:1.155 Fri Apr 1 23:16:31 2022 +++ src/usr.bin/xlint/lint1/err.c Sat Apr 2 20:12:46 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: err.c,v 1.155 2022/04/01 23:16:31 rillig Exp $ */ +/* $NetBSD: err.c,v 1.156 2022/04/02 20:12:46 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.155 2022/04/01 23:16:31 rillig Exp $"); +__RCSID("$NetBSD: err.c,v 1.156 2022/04/02 20:12:46 rillig Exp $"); #endif #include <sys/types.h> @@ -596,6 +596,7 @@ assert_failed(const char *file, int line "lint: assertion \"%s\" failed in %s at %s:%d near %s:%d\n", cond, func, file, line, fn, curr_pos.p_line); print_stack_trace(); + (void)fflush(stdout); abort(); } Index: src/usr.bin/xlint/lint1/func.c diff -u src/usr.bin/xlint/lint1/func.c:1.129 src/usr.bin/xlint/lint1/func.c:1.130 --- src/usr.bin/xlint/lint1/func.c:1.129 Sat Apr 2 14:28:30 2022 +++ src/usr.bin/xlint/lint1/func.c Sat Apr 2 20:12:46 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: func.c,v 1.129 2022/04/02 14:28:30 rillig Exp $ */ +/* $NetBSD: func.c,v 1.130 2022/04/02 20:12:46 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.129 2022/04/02 14:28:30 rillig Exp $"); +__RCSID("$NetBSD: func.c,v 1.130 2022/04/02 20:12:46 rillig Exp $"); #endif #include <stdlib.h> @@ -1161,6 +1161,8 @@ global_clean_up_decl(bool silent) * fine. See test gcc_attribute.c, function_with_unknown_attribute. */ in_gcc_attribute = false; + while (dcs->d_enclosing != NULL) + end_declaration_level(); } /*