diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-06-29 21:51:31 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-06-29 21:51:31 +0000 |
commit | a82064ca27b5852349a974c7f7e833a464077c3c (patch) | |
tree | 2bab72a4c412da7470e7795e7d4d4f8c789d2cff /clang | |
parent | 8bae20f7f74e9eae82c3deded33a62d8ae389f5b (diff) | |
download | bcm5719-llvm-a82064ca27b5852349a974c7f7e833a464077c3c.tar.gz bcm5719-llvm-a82064ca27b5852349a974c7f7e833a464077c3c.zip |
Check for deprecated/unavailable/etc attributes on fields that are
initialized via initializer lists. Fixes <rdar://problem/9694686>.
llvm-svn: 134099
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/Sema/SemaInit.cpp | 15 | ||||
-rw-r--r-- | clang/test/Sema/attr-deprecated.c | 2 |
2 files changed, 17 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index da20e0e8fde..58565af9cee 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -1184,6 +1184,15 @@ void InitListChecker::CheckStructUnionTypes(const InitializedEntity &Entity, continue; } + // Make sure we can use this declaration. + if (SemaRef.DiagnoseUseOfDecl(*Field, + IList->getInit(Index)->getLocStart())) { + ++Index; + ++Field; + hadError = true; + continue; + } + InitializedEntity MemberEntity = InitializedEntity::InitializeMember(*Field, &Entity); CheckSubElementType(MemberEntity, IList, Field->getType(), Index, @@ -1503,6 +1512,12 @@ InitListChecker::CheckDesignatedInitializer(const InitializedEntity &Entity, StructuredList->setInitializedFieldInUnion(*Field); } + // Make sure we can use this declaration. + if (SemaRef.DiagnoseUseOfDecl(*Field, D->getFieldLoc())) { + ++Index; + return true; + } + // Update the designator with the field declaration. D->setField(*Field); diff --git a/clang/test/Sema/attr-deprecated.c b/clang/test/Sema/attr-deprecated.c index b26171b86b0..eeef0d757a7 100644 --- a/clang/test/Sema/attr-deprecated.c +++ b/clang/test/Sema/attr-deprecated.c @@ -37,6 +37,8 @@ struct foo { void test1(struct foo *F) { ++F->x; // expected-warning {{'x' is deprecated}} + struct foo f1 = { .x = 17 }; // expected-warning {{'x' is deprecated}} + struct foo f2 = { 17 }; // expected-warning {{'x' is deprecated}} } typedef struct foo foo_dep __attribute__((deprecated)); |