aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen
diff options
context:
space:
mode:
Diffstat (limited to 'lib/CodeGen')
-rw-r--r--lib/CodeGen/CGExpr.cpp13
-rw-r--r--lib/CodeGen/CGExprAgg.cpp8
-rw-r--r--lib/CodeGen/CGExprScalar.cpp7
3 files changed, 18 insertions, 10 deletions
diff --git a/lib/CodeGen/CGExpr.cpp b/lib/CodeGen/CGExpr.cpp
index 24442c3a73..400d45ffe5 100644
--- a/lib/CodeGen/CGExpr.cpp
+++ b/lib/CodeGen/CGExpr.cpp
@@ -1173,8 +1173,13 @@ LValue CodeGenFunction::EmitConditionalOperator(const ConditionalOperator* E) {
/// noop aggregate casts, and cast from scalar to union.
LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {
if (E->getCastKind() == CastExpr::CK_UserDefinedConversion) {
- const CXXFunctionalCastExpr *CXXFExpr = cast<CXXFunctionalCastExpr>(E);
- return LValue::MakeAddr(EmitCXXFunctionalCastExpr(CXXFExpr).getScalarVal(), 0);
+ if (const CXXFunctionalCastExpr *CXXFExpr =
+ dyn_cast<CXXFunctionalCastExpr>(E))
+ return LValue::MakeAddr(
+ EmitCXXFunctionalCastExpr(CXXFExpr).getScalarVal(), 0);
+ assert(isa<CStyleCastExpr>(E) &&
+ "EmitCastLValue - Expected CStyleCastExpr");
+ return EmitLValue(E->getSubExpr());
}
// If this is an aggregate-to-aggregate cast, just use the input's address as
@@ -1188,10 +1193,6 @@ LValue CodeGenFunction::EmitCastLValue(const CastExpr *E) {
if (ICE->isLvalueCast())
return EmitLValue(E->getSubExpr());
- // FIXME: Implement this properly!
- if (E->getCastKind() == CastExpr::CK_UserDefinedConversion)
- return EmitUnsupportedLValue(E, "user-defined conversion");
-
// Otherwise, we must have a cast from scalar to union.
assert(E->getCastKind() == CastExpr::CK_ToUnion &&
"Expected scalar-to-union cast");
diff --git a/lib/CodeGen/CGExprAgg.cpp b/lib/CodeGen/CGExprAgg.cpp
index 002c77430f..4155738a22 100644
--- a/lib/CodeGen/CGExprAgg.cpp
+++ b/lib/CodeGen/CGExprAgg.cpp
@@ -178,8 +178,12 @@ void AggExprEmitter::VisitCastExpr(CastExpr *E) {
return;
}
if (E->getCastKind() == CastExpr::CK_UserDefinedConversion) {
- CXXFunctionalCastExpr *CXXFExpr = cast<CXXFunctionalCastExpr>(E);
- CGF.EmitCXXFunctionalCastExpr(CXXFExpr);
+ if (const CXXFunctionalCastExpr *CXXFExpr =
+ dyn_cast<CXXFunctionalCastExpr>(E))
+ CGF.EmitCXXFunctionalCastExpr(CXXFExpr);
+ else
+ if (isa<CStyleCastExpr>(E))
+ Visit(E->getSubExpr());
return;
}
diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp
index 299296a633..f3a841dbb2 100644
--- a/lib/CodeGen/CGExprScalar.cpp
+++ b/lib/CodeGen/CGExprScalar.cpp
@@ -228,8 +228,11 @@ public:
}
Value *VisitCastExpr(const CastExpr *E) {
if (E->getCastKind() == CastExpr::CK_UserDefinedConversion) {
- const CXXFunctionalCastExpr *CXXFExpr = cast<CXXFunctionalCastExpr>(E);
- return CGF.EmitCXXFunctionalCastExpr(CXXFExpr).getScalarVal();
+ if (const CXXFunctionalCastExpr *CXXFExpr =
+ dyn_cast<CXXFunctionalCastExpr>(E))
+ return CGF.EmitCXXFunctionalCastExpr(CXXFExpr).getScalarVal();
+ assert(isa<CStyleCastExpr>(E) &&
+ "VisitCastExpr - missing CStyleCastExpr");
}
// Make sure to evaluate VLA bounds now so that we have them for later.