Added a test for C++11 statement attributes serialization.

Summary: Uses [[clang::fallthrough]] attribute in a template function, and -Wimplicit-fallthrough to check the attribute presence in an instantiation.

Reviewers: rsmith

Reviewed By: rsmith

CC: cfe-commits

Differential Revision: http://llvm-reviews.chandlerc.com/D55

llvm-svn: 165068
This commit is contained in:
Alexander Kornienko 2012-10-02 23:11:53 +00:00
parent aa7aeaa0a5
commit 2d4f311642
2 changed files with 26 additions and 0 deletions

View File

@ -0,0 +1,14 @@
// To be used with cxx11-statement-attributes.cpp.
template<const int N>
int f(int n) {
switch (n * N) {
case 0:
n += 15;
[[clang::fallthrough]]; // This shouldn't generate a warning.
case 1:
n += 20;
[[clang::fallthrough]]; // This should generate a warning: "fallthrough annotation does not directly precede switch label".
break;
}
return n;
}

View File

@ -0,0 +1,12 @@
// Sanity check.
// RUN: %clang_cc1 -include %S/Inputs/cxx11-statement-attributes.h -std=c++11 -Wimplicit-fallthrough -fsyntax-only %s -o - -verify
// Run the same tests, this time with the attributes loaded from the PCH file.
// RUN: %clang_cc1 -x c++-header -emit-pch -std=c++11 -o %t %S/Inputs/cxx11-statement-attributes.h
// RUN: %clang_cc1 -include-pch %t -std=c++11 -Wimplicit-fallthrough -fsyntax-only %s -o - -verify
// Warning from Inputs/cxx11-statement-attributes.h:
// expected-warning@10 {{fallthrough annotation does not directly precede switch label}}
void g(int n) {
f<1>(n); // expected-note {{in instantiation of function template specialization 'f<1>' requested here}}
}