summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaDecl.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-01-08 04:04:30 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-01-08 04:04:30 +0000
commit9a5a6dddf910eedaf80458420d4089570dfa49b2 (patch)
treed6c14c6027f75f7e8a0b2fa41b165f94ac67f834 /clang/lib/Sema/SemaDecl.cpp
parent95de6bd469d5e183ac86420533c8d276ba3bd167 (diff)
downloadbcm5719-llvm-9a5a6dddf910eedaf80458420d4089570dfa49b2.tar.gz
bcm5719-llvm-9a5a6dddf910eedaf80458420d4089570dfa49b2.zip
Clear the LV cache when merging the availability attribute.
The availability implies default visibility, so it can change the computed visibility. llvm-svn: 171840
Diffstat (limited to 'clang/lib/Sema/SemaDecl.cpp')
-rw-r--r--clang/lib/Sema/SemaDecl.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index 84b0d3f36bf..3b37890f218 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/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);
OpenPOWER on IntegriCloud