summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/ExprConstant.cpp
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-01-29 06:43:41 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-01-29 06:43:41 +0000
commit74f2425b899f228fcb5c19acbf8e2598006e4878 (patch)
tree5d4a4c85630514fd143cbe2b5fd68eee84cb6039 /clang/lib/AST/ExprConstant.cpp
parent7bb8dfae53e949e0431b355a3ebd0f2c36fdaae7 (diff)
downloadbcm5719-llvm-74f2425b899f228fcb5c19acbf8e2598006e4878.tar.gz
bcm5719-llvm-74f2425b899f228fcb5c19acbf8e2598006e4878.zip
Evaluate ==,!= for complex types.
llvm-svn: 63280
Diffstat (limited to 'clang/lib/AST/ExprConstant.cpp')
-rw-r--r--clang/lib/AST/ExprConstant.cpp44
1 files changed, 44 insertions, 0 deletions
diff --git a/clang/lib/AST/ExprConstant.cpp b/clang/lib/AST/ExprConstant.cpp
index eae3f64ac96..97985205077 100644
--- a/clang/lib/AST/ExprConstant.cpp
+++ b/clang/lib/AST/ExprConstant.cpp
@@ -729,6 +729,50 @@ bool IntExprEvaluator::VisitBinaryOperator(const BinaryOperator *E) {
QualType LHSTy = E->getLHS()->getType();
QualType RHSTy = E->getRHS()->getType();
+
+ if (LHSTy->isAnyComplexType()) {
+ assert(RHSTy->isAnyComplexType() && "Invalid comparison");
+ APValue LHS, RHS;
+
+ if (!EvaluateComplex(E->getLHS(), LHS, Info))
+ return false;
+
+ if (!EvaluateComplex(E->getRHS(), RHS, Info))
+ return false;
+
+ if (LHS.isComplexFloat()) {
+ APFloat::cmpResult CR_r =
+ LHS.getComplexFloatReal().compare(RHS.getComplexFloatReal());
+ APFloat::cmpResult CR_i =
+ LHS.getComplexFloatImag().compare(RHS.getComplexFloatImag());
+
+ Result.setIsUnsigned(E->getType()->isUnsignedIntegerType());
+ if (E->getOpcode() == BinaryOperator::EQ)
+ Result = (CR_r == APFloat::cmpEqual &&
+ CR_i == APFloat::cmpEqual);
+ else if (E->getOpcode() == BinaryOperator::NE)
+ Result = ((CR_r == APFloat::cmpGreaterThan ||
+ CR_r == APFloat::cmpLessThan) &&
+ (CR_i == APFloat::cmpGreaterThan ||
+ CR_i == APFloat::cmpLessThan));
+ else
+ assert(0 && "Invalid complex compartison.");
+ Result.setIsUnsigned(E->getType()->isUnsignedIntegerType());
+ return true;
+ } else {
+ Result.zextOrTrunc(getIntTypeSizeInBits(E->getType()));
+ if (E->getOpcode() == BinaryOperator::EQ)
+ Result = (LHS.getComplexIntReal() == RHS.getComplexIntReal() &&
+ LHS.getComplexIntImag() == RHS.getComplexIntImag());
+ else if (E->getOpcode() == BinaryOperator::NE)
+ Result = (LHS.getComplexIntReal() != RHS.getComplexIntReal() ||
+ LHS.getComplexIntImag() != RHS.getComplexIntImag());
+ else
+ assert(0 && "Invalid complex compartison.");
+ Result.setIsUnsigned(E->getType()->isUnsignedIntegerType());
+ return true;
+ }
+ }
if (LHSTy->isRealFloatingType() &&
RHSTy->isRealFloatingType()) {
OpenPOWER on IntegriCloud