From 145c08360a8ef90392bb0482c94f47e632e78f8c Mon Sep 17 00:00:00 2001 From: Eli Friedman Date: Fri, 16 May 2008 17:37:11 +0000 Subject: [PATCH] Patch for PR2334, and a similar ObjC bug. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@51193 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGExprScalar.cpp | 6 ++++-- test/CodeGen/conditional.c | 5 +++++ 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index bdd7975fa0..8442b8174e 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -1050,7 +1050,8 @@ VisitConditionalOperator(const ConditionalOperator *E) { // Handle the GNU extension for missing LHS. Value *LHS; if (E->getLHS()) - LHS = Visit(E->getLHS()); + LHS = EmitScalarConversion(Visit(E->getLHS()), E->getLHS()->getType(), + E->getType()); else // Perform promotions, to handle cases like "short ?: int" LHS = EmitScalarConversion(CondVal, E->getCond()->getType(), E->getType()); @@ -1059,7 +1060,8 @@ VisitConditionalOperator(const ConditionalOperator *E) { CGF.EmitBlock(RHSBlock); - Value *RHS = Visit(E->getRHS()); + Value *RHS = EmitScalarConversion(Visit(E->getRHS()), E->getRHS()->getType(), + E->getType()); Builder.CreateBr(ContBlock); RHSBlock = Builder.GetInsertBlock(); diff --git a/test/CodeGen/conditional.c b/test/CodeGen/conditional.c index ae44207115..d3e5c0b938 100644 --- a/test/CodeGen/conditional.c +++ b/test/CodeGen/conditional.c @@ -25,3 +25,8 @@ void test5() { void* vp; cip = 0 ? vp : cip; } + +void test6(); +void test7(int); +void* test8() {return 1 ? test6 : test7;} + -- 2.50.1