aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2008-05-16 17:37:11 +0000
committerEli Friedman <eli.friedman@gmail.com>2008-05-16 17:37:11 +0000
commit145c08360a8ef90392bb0482c94f47e632e78f8c (patch)
tree22287dc136aa75e042304dc8d19ef70986fdc483 /lib/CodeGen
parent9c2535a35db35b3a821a0d0c36a01a16f52f1ad0 (diff)
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
Diffstat (limited to 'lib/CodeGen')
-rw-r--r--lib/CodeGen/CGExprScalar.cpp6
1 files changed, 4 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();