]> granicus.if.org Git - clang/commitdiff
It's perfectly fine to see UserDefinedConversion casts when emitting scalar expressions.
authorAnders Carlsson <andersca@mac.com>
Fri, 18 Dec 2009 14:42:03 +0000 (14:42 +0000)
committerAnders Carlsson <andersca@mac.com>
Fri, 18 Dec 2009 14:42:03 +0000 (14:42 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91686 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExprScalar.cpp
test/CodeGenCXX/conversion-function.cpp

index 07909faa75eac4bcb7123ddb1eb09ea313520f77..0a0690754fe531853c9b58e6afb56fa76a7d8f21 100644 (file)
@@ -816,6 +816,7 @@ Value *ScalarExprEmitter::EmitCastExpr(CastExpr *CE) {
     return Builder.CreateBitCast(Src, ConvertType(DestTy));
   }
   case CastExpr::CK_NoOp:
+  case CastExpr::CK_UserDefinedConversion:
     return Visit(const_cast<Expr*>(E));
 
   case CastExpr::CK_BaseToDerived: {
@@ -903,7 +904,6 @@ Value *ScalarExprEmitter::EmitCastExpr(CastExpr *CE) {
     return Src;
   }
 
-  case CastExpr::CK_UserDefinedConversion:
   case CastExpr::CK_ConstructorConversion:
     assert(0 && "Should be unreachable!");
     break;
index ef45fc234242b03519f3e6910836300f58b0a3ec..fccb6f094e078ed8f8fe1465b28f4e912baaf5d9 100644 (file)
@@ -12,6 +12,9 @@ S::operator int() {
   return 10;
 }
 
+int f(S s) {
+  return s;
+}
 
 class X { // ...
   public: operator int() { printf("operator int()\n"); return iX; }
@@ -94,6 +97,9 @@ void f(Yb& a) {
   char ch = a;  // OK. calls Yb::operator char();
 }
 
+struct A {
+  operator int() const;
+};
 
 // CHECK-LP64: .globl __ZN1ScviEv
 // CHECK-LP64-NEXT: __ZN1ScviEv: