diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-01-08 04:04:30 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-01-08 04:04:30 +0000 |
commit | d63b19ea855a66df8c58764604d48497c48829d9 (patch) | |
tree | 28aa05da2d986da08bc40f0807876b12796a4cdf /lib/Sema/SemaDecl.cpp | |
parent | 2fcadfe262e7574183c6cd1af5dbde2901f92275 (diff) |
Clear the LV cache when merging the availability attribute.
The availability implies default visibility, so it can change the computed
visibility.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@171840 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDecl.cpp')
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index 84b0d3f36b..3b37890f21 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -1790,12 +1790,16 @@ DeclHasAttr(const Decl *D, const Attr *A) { bool Sema::mergeDeclAttribute(Decl *D, InheritableAttr *Attr) { InheritableAttr *NewAttr = NULL; - if (AvailabilityAttr *AA = dyn_cast<AvailabilityAttr>(Attr)) + if (AvailabilityAttr *AA = dyn_cast<AvailabilityAttr>(Attr)) { NewAttr = mergeAvailabilityAttr(D, AA->getRange(), AA->getPlatform(), AA->getIntroduced(), AA->getDeprecated(), AA->getObsoleted(), AA->getUnavailable(), AA->getMessage()); - else if (VisibilityAttr *VA = dyn_cast<VisibilityAttr>(Attr)) { + if (NewAttr) { + NamedDecl *ND = cast<NamedDecl>(D); + ND->ClearLVCache(); + } + } else if (VisibilityAttr *VA = dyn_cast<VisibilityAttr>(Attr)) { NewAttr = mergeVisibilityAttr(D, VA->getRange(), VA->getVisibility()); if (NewAttr) { NamedDecl *ND = cast<NamedDecl>(D); |