]> granicus.if.org Git - clang/commitdiff
Patch to ir-gen user-defined conversions used in expressions
authorFariborz Jahanian <fjahanian@apple.com>
Sat, 29 Aug 2009 20:33:32 +0000 (20:33 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Sat, 29 Aug 2009 20:33:32 +0000 (20:33 +0000)
[12.3.2-p3]

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@80436 91177308-0d34-0410-b5e6-96231b3b80d8

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

index 68ab6dfc5894281df037005bae59877b9ba365df..e3511edd2be47f6ff8e6464ea315f004dd9f0ba3 100644 (file)
@@ -324,6 +324,17 @@ void CodeGenFunction::EmitBranchOnBoolExpr(const Expr *Cond,
                                            llvm::BasicBlock *FalseBlock) {
   if (const ParenExpr *PE = dyn_cast<ParenExpr>(Cond))
     return EmitBranchOnBoolExpr(PE->getSubExpr(), TrueBlock, FalseBlock);
+  if (const CastExpr *E = dyn_cast<CastExpr>(Cond))
+    if (E->getCastKind() == CastExpr::CK_UserDefinedConversion) {
+      if (const CXXFunctionalCastExpr *CXXFExpr = 
+            dyn_cast<CXXFunctionalCastExpr>(E)) {
+          EmitCXXFunctionalCastExpr(CXXFExpr);
+        return;
+      }
+      else if (isa<CStyleCastExpr>(E))
+        return EmitBranchOnBoolExpr(E->getSubExpr(), TrueBlock, FalseBlock);
+      assert(false && "EmitBranchOnBoolExpr - Expected CStyleCastExpr");
+    }
   
   if (const BinaryOperator *CondBOp = dyn_cast<BinaryOperator>(Cond)) {
     // Handle X && Y in a condition.
index f3c0e33bf12ce1e3574f1a1b1ac0ec6542adf2df..e7820bb44f09d7e414070168ec9fa1b219517479 100644 (file)
@@ -39,6 +39,22 @@ class Y { // ...
 
 Y y;
 
+int count=0;
+class O { // ...
+public: 
+       operator int(){ return ++iO; }
+        O() : iO(count++) {}
+       int iO;
+};
+
+void g(O a, O b)
+{
+        int i = (a) ? 1+a : 0; 
+        int j = (a&&b) ? a+b : i; 
+        if (a) { }
+       printf("i = %d j = %d a.iO = %d b.iO = %d\n", i, j, a.iO, b.iO);
+}
+
 int main() {
     int c = X(Z(y)); // OK: y.operator Z().operator X().operator int()
     printf("c = %d\n", c);
@@ -58,6 +74,8 @@ int main() {
 
     int e = (int)((X)((Z)y));
     printf("e = %d\n", e);
+    O o1, o2;
+    g(o1, o2);
 }
 // CHECK-LP64: .globl  __ZN1ScviEv
 // CHECK-LP64-NEXT: __ZN1ScviEv: