hokein created this revision. hokein added a reviewer: kadircet. Herald added a project: All. hokein requested review of this revision. Herald added a subscriber: alextsao1999. Herald added a project: clang-tools-extra.
We happened to introduce a `member-declaration := ;` rule when inlining the `member-declaration := decl-specifier-seq_opt member-declarator-list_opt ;`. And with the `member-declaration := empty-declaration` rule, we had two parses of `;`. This patch is to restrict the grammar to eliminate the `member-declaration := ;` rule. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D131724 Files: clang-tools-extra/pseudo/lib/cxx/cxx.bnf clang-tools-extra/pseudo/test/cxx/empty-member-declaration.cpp Index: clang-tools-extra/pseudo/test/cxx/empty-member-declaration.cpp =================================================================== --- /dev/null +++ clang-tools-extra/pseudo/test/cxx/empty-member-declaration.cpp @@ -0,0 +1,7 @@ +// RUN: clang-pseudo -grammar=cxx -source=%s --print-forest --forest-abbrev=false | FileCheck %s +class A { + ; +// CHECK-NOT: member-declaration := ; +// CHECK: member-declaration := empty-declaration +// CHECK-NOT: member-declaration := ; +}; Index: clang-tools-extra/pseudo/lib/cxx/cxx.bnf =================================================================== --- clang-tools-extra/pseudo/lib/cxx/cxx.bnf +++ clang-tools-extra/pseudo/lib/cxx/cxx.bnf @@ -557,7 +557,8 @@ class-key := UNION member-specification := member-declaration member-specification_opt member-specification := access-specifier : member-specification_opt -member-declaration := decl-specifier-seq_opt member-declarator-list_opt ; +member-declaration := decl-specifier-seq member-declarator-list_opt ; +member-declaration := member-declarator-list ; member-declaration := function-definition member-declaration := using-declaration member-declaration := using-enum-declaration
Index: clang-tools-extra/pseudo/test/cxx/empty-member-declaration.cpp =================================================================== --- /dev/null +++ clang-tools-extra/pseudo/test/cxx/empty-member-declaration.cpp @@ -0,0 +1,7 @@ +// RUN: clang-pseudo -grammar=cxx -source=%s --print-forest --forest-abbrev=false | FileCheck %s +class A { + ; +// CHECK-NOT: member-declaration := ; +// CHECK: member-declaration := empty-declaration +// CHECK-NOT: member-declaration := ; +}; Index: clang-tools-extra/pseudo/lib/cxx/cxx.bnf =================================================================== --- clang-tools-extra/pseudo/lib/cxx/cxx.bnf +++ clang-tools-extra/pseudo/lib/cxx/cxx.bnf @@ -557,7 +557,8 @@ class-key := UNION member-specification := member-declaration member-specification_opt member-specification := access-specifier : member-specification_opt -member-declaration := decl-specifier-seq_opt member-declarator-list_opt ; +member-declaration := decl-specifier-seq member-declarator-list_opt ; +member-declaration := member-declarator-list ; member-declaration := function-definition member-declaration := using-declaration member-declaration := using-enum-declaration
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits