Module Name:    src
Committed By:   rillig
Date:           Sun Jul 25 17:40:04 UTC 2021

Modified Files:
        src/tests/usr.bin/xlint/lint1: parse_init_declarator.c
            parse_init_declarator.exp
        src/usr.bin/xlint/lint1: cgram.y

Log Message:
lint: fix parsing of GNU __attribute__ after __asm

GCC only accepts them in the order __asm __attribute__, not the other
way round.  So should lint.


To generate a diff of this commit:
cvs rdiff -u -r1.1 -r1.2 \
    src/tests/usr.bin/xlint/lint1/parse_init_declarator.c \
    src/tests/usr.bin/xlint/lint1/parse_init_declarator.exp
cvs rdiff -u -r1.338 -r1.339 src/usr.bin/xlint/lint1/cgram.y

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/parse_init_declarator.c
diff -u src/tests/usr.bin/xlint/lint1/parse_init_declarator.c:1.1 src/tests/usr.bin/xlint/lint1/parse_init_declarator.c:1.2
--- src/tests/usr.bin/xlint/lint1/parse_init_declarator.c:1.1	Sun Jul 25 17:27:07 2021
+++ src/tests/usr.bin/xlint/lint1/parse_init_declarator.c	Sun Jul 25 17:40:04 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: parse_init_declarator.c,v 1.1 2021/07/25 17:27:07 rillig Exp $	*/
+/*	$NetBSD: parse_init_declarator.c,v 1.2 2021/07/25 17:40:04 rillig Exp $	*/
 # 3 "parse_init_declarator.c"
 
 /*
@@ -12,8 +12,6 @@ int global_var;
 
 int *init_declarator_without_initializer
     __asm("") __attribute__((deprecated));
-/* expect-1: error: syntax error '__attribute__' [249] */
-/* FIXME */
 
 /* XXX: GCC does not accept this, neither should lint. */
 int *init_declarator_without_initializer_wrong_order
@@ -21,8 +19,6 @@ int *init_declarator_without_initializer
 
 int *init_declarator_with_initializer
     __asm("") __attribute__((deprecated)) = &global_var;
-/* expect-1: error: syntax error '__attribute__' [249] */
-/* FIXME */
 
 /* XXX: GCC does not accept this, neither should lint. */
 int *init_declarator_with_initializer_wrong_order
Index: src/tests/usr.bin/xlint/lint1/parse_init_declarator.exp
diff -u src/tests/usr.bin/xlint/lint1/parse_init_declarator.exp:1.1 src/tests/usr.bin/xlint/lint1/parse_init_declarator.exp:1.2
--- src/tests/usr.bin/xlint/lint1/parse_init_declarator.exp:1.1	Sun Jul 25 17:27:07 2021
+++ src/tests/usr.bin/xlint/lint1/parse_init_declarator.exp	Sun Jul 25 17:40:04 2021
@@ -1,3 +1 @@
-parse_init_declarator.c(14): error: syntax error '__attribute__' [249]
-parse_init_declarator.c(23): error: syntax error '__attribute__' [249]
-parse_init_declarator.c(33): error: syntax error '__attribute__' [249]
+parse_init_declarator.c(29): error: syntax error '__attribute__' [249]

Index: src/usr.bin/xlint/lint1/cgram.y
diff -u src/usr.bin/xlint/lint1/cgram.y:1.338 src/usr.bin/xlint/lint1/cgram.y:1.339
--- src/usr.bin/xlint/lint1/cgram.y:1.338	Sun Jul 25 16:57:23 2021
+++ src/usr.bin/xlint/lint1/cgram.y	Sun Jul 25 17:40:04 2021
@@ -1,5 +1,5 @@
 %{
-/* $NetBSD: cgram.y,v 1.338 2021/07/25 16:57:23 rillig Exp $ */
+/* $NetBSD: cgram.y,v 1.339 2021/07/25 17:40:04 rillig Exp $ */
 
 /*
  * Copyright (c) 1996 Christopher G. Demetriou.  All Rights Reserved.
@@ -35,7 +35,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: cgram.y,v 1.338 2021/07/25 16:57:23 rillig Exp $");
+__RCSID("$NetBSD: cgram.y,v 1.339 2021/07/25 17:40:04 rillig Exp $");
 #endif
 
 #include <limits.h>
@@ -124,7 +124,7 @@ anonymize(sym_t *s)
 
 %}
 
-%expect 156
+%expect 159
 
 %union {
 	val_t	*y_val;
@@ -833,11 +833,7 @@ type_attribute_opt:
 	;
 
 type_attribute:			/* See C11 6.7 declaration-specifiers */
-	  T_ATTRIBUTE T_LPAREN T_LPAREN {
-	    attron = true;
-	  } gcc_attribute_spec_list {
-	    attron = false;
-	  } T_RPAREN T_RPAREN
+	  gcc_attribute
 	  /* TODO: c11ism */
 	| T_ALIGNAS T_LPAREN align_as T_RPAREN
 	| T_PACKED {
@@ -1592,11 +1588,11 @@ asm_or_symbolrename_opt:	/* GCC extensio
 	  /* empty */ {
 		$$ = NULL;
 	  }
-	| T_ASM T_LPAREN T_STRING T_RPAREN {
+	| T_ASM T_LPAREN T_STRING T_RPAREN gcc_attribute_list_opt {
 		freeyyv(&$3, T_STRING);
 		$$ = NULL;
 	  }
-	| T_SYMBOLRENAME T_LPAREN T_NAME T_RPAREN {
+	| T_SYMBOLRENAME T_LPAREN T_NAME T_RPAREN gcc_attribute_list_opt {
 		$$ = $3;
 	  }
 	;
@@ -2006,6 +2002,24 @@ arg_declaration:
 	| begin_type_declaration_specifiers error
 	;
 
+gcc_attribute_list_opt:
+	  /* empty */
+	| gcc_attribute_list
+	;
+
+gcc_attribute_list:
+	  gcc_attribute
+	| gcc_attribute_list gcc_attribute
+	;
+
+gcc_attribute:
+	  T_ATTRIBUTE T_LPAREN T_LPAREN {
+	    attron = true;
+	  } gcc_attribute_spec_list {
+	    attron = false;
+	  } T_RPAREN T_RPAREN
+	;
+
 gcc_attribute_spec_list:
 	  gcc_attribute_spec
 	| gcc_attribute_spec_list T_COMMA gcc_attribute_spec

Reply via email to