summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2011-10-31 20:59:03 +0000
committerEli Friedman <eli.friedman@gmail.com>2011-10-31 20:59:03 +0000
commit90a2cdf1fb9b00c45f53d1fa3f4f349f0aeaba7c (patch)
tree2d5f7a5a2ceb2747f3c68c8cc947d93ce3c8ed2e /clang/lib
parentdd78544d4474154fa8ee097aed3d6c5b2dff72f5 (diff)
downloadbcm5719-llvm-90a2cdf1fb9b00c45f53d1fa3f4f349f0aeaba7c.tar.gz
bcm5719-llvm-90a2cdf1fb9b00c45f53d1fa3f4f349f0aeaba7c.zip
Add missing lvalue-to-rvalue conversion.
llvm-svn: 143364
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/Sema/SemaCast.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaCast.cpp b/clang/lib/Sema/SemaCast.cpp
index 7a063036c2f..20742a0c35a 100644
--- a/clang/lib/Sema/SemaCast.cpp
+++ b/clang/lib/Sema/SemaCast.cpp
@@ -529,6 +529,12 @@ CastsAwayConstness(Sema &Self, QualType SrcType, QualType DestType,
/// Refer to C++ 5.2.7 for details. Dynamic casts are used mostly for runtime-
/// checked downcasts in class hierarchies.
void CastOperation::CheckDynamicCast() {
+ if (ValueKind == VK_RValue && !isPlaceholder(BuiltinType::Overload)) {
+ SrcExpr = Self.DefaultFunctionArrayLvalueConversion(SrcExpr.take());
+ if (SrcExpr.isInvalid()) // if conversion failed, don't report another error
+ return;
+ }
+
QualType OrigSrcType = SrcExpr.get()->getType();
QualType DestType = Self.Context.getCanonicalType(this->DestType);
OpenPOWER on IntegriCloud