aboutsummaryrefslogtreecommitdiff
path: root/clang/unittests/Tooling/Syntax/TreeTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'clang/unittests/Tooling/Syntax/TreeTest.cpp')
-rw-r--r--clang/unittests/Tooling/Syntax/TreeTest.cpp33
1 files changed, 32 insertions, 1 deletions
diff --git a/clang/unittests/Tooling/Syntax/TreeTest.cpp b/clang/unittests/Tooling/Syntax/TreeTest.cpp
index bcfb2f7..a7de4b9 100644
--- a/clang/unittests/Tooling/Syntax/TreeTest.cpp
+++ b/clang/unittests/Tooling/Syntax/TreeTest.cpp
@@ -51,6 +51,8 @@ struct TestClangConfig {
TestLanguage Language;
std::string Target;
+ bool isC99OrLater() const { return Language == Lang_C99; }
+
bool isCXX() const {
return Language == Lang_CXX03 || Language == Lang_CXX11 ||
Language == Lang_CXX14 || Language == Lang_CXX17 ||
@@ -1903,7 +1905,6 @@ TEST_P(SyntaxTreeTest, ArraySubscriptsInDeclarators) {
int a[10];
int b[1][2][3];
int c[] = {1,2,3};
-// void f(int xs[static 10]);
)cpp",
R"txt(
*: TranslationUnit
@@ -1960,6 +1961,36 @@ int c[] = {1,2,3};
`-; )txt");
}
+TEST_P(SyntaxTreeTest, StaticArraySubscriptsInDeclarators) {
+ if (!GetParam().isC99OrLater()) {
+ return;
+ }
+ expectTreeDumpEqual(
+ R"cpp(
+void f(int xs[static 10]);
+ )cpp",
+ R"txt(
+*: TranslationUnit
+`-SimpleDeclaration
+ |-void
+ |-SimpleDeclarator
+ | |-f
+ | `-ParametersAndQualifiers
+ | |-(
+ | |-SimpleDeclaration
+ | | |-int
+ | | `-SimpleDeclarator
+ | | |-xs
+ | | `-ArraySubscript
+ | | |-[
+ | | |-static
+ | | |-UnknownExpression
+ | | | `-10
+ | | `-]
+ | `-)
+ `-; )txt");
+}
+
TEST_P(SyntaxTreeTest, ParameterListsInDeclarators) {
if (!GetParam().isCXX()) {
// TODO: Split parts that depend on C++ into a separate test.