forked from OSchip/llvm-project
Bug #:
Submitted by: Reviewed by: Bozo bug in last checkin. Needed to move the check for null pointers up (and out of the pointer/pointer clause). llvm-svn: 39466
This commit is contained in:
parent
5ab15f154d
commit
30d1fbc803
|
@ -421,6 +421,11 @@ inline QualType Sema::CheckConditionalOperands( // C99 6.5.15
|
||||||
return QualType();
|
return QualType();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (lhs->isPointerType() && RHS->isNullPointerConstant()) // C99 6.5.15p3
|
||||||
|
return lhs;
|
||||||
|
if (rhs->isPointerType() && LHS->isNullPointerConstant())
|
||||||
|
return rhs;
|
||||||
|
|
||||||
if (lhs->isPointerType() && rhs->isPointerType()) { // C99 6.5.15p3,6
|
if (lhs->isPointerType() && rhs->isPointerType()) { // C99 6.5.15p3,6
|
||||||
QualType lhptee, rhptee;
|
QualType lhptee, rhptee;
|
||||||
|
|
||||||
|
@ -428,11 +433,6 @@ inline QualType Sema::CheckConditionalOperands( // C99 6.5.15
|
||||||
lhptee = cast<PointerType>(lhs.getCanonicalType())->getPointeeType();
|
lhptee = cast<PointerType>(lhs.getCanonicalType())->getPointeeType();
|
||||||
rhptee = cast<PointerType>(rhs.getCanonicalType())->getPointeeType();
|
rhptee = cast<PointerType>(rhs.getCanonicalType())->getPointeeType();
|
||||||
|
|
||||||
if (RHS->isNullPointerConstant()) // C99 6.5.15p3
|
|
||||||
return lhs;
|
|
||||||
if (LHS->isNullPointerConstant())
|
|
||||||
return rhs;
|
|
||||||
|
|
||||||
// ignore qualifiers on void (C99 6.5.15p3, clause 6)
|
// ignore qualifiers on void (C99 6.5.15p3, clause 6)
|
||||||
if (lhptee.getUnqualifiedType()->isVoidType() &&
|
if (lhptee.getUnqualifiedType()->isVoidType() &&
|
||||||
(rhptee->isObjectType() || rhptee->isIncompleteType()))
|
(rhptee->isObjectType() || rhptee->isIncompleteType()))
|
||||||
|
|
|
@ -421,6 +421,11 @@ inline QualType Sema::CheckConditionalOperands( // C99 6.5.15
|
||||||
return QualType();
|
return QualType();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (lhs->isPointerType() && RHS->isNullPointerConstant()) // C99 6.5.15p3
|
||||||
|
return lhs;
|
||||||
|
if (rhs->isPointerType() && LHS->isNullPointerConstant())
|
||||||
|
return rhs;
|
||||||
|
|
||||||
if (lhs->isPointerType() && rhs->isPointerType()) { // C99 6.5.15p3,6
|
if (lhs->isPointerType() && rhs->isPointerType()) { // C99 6.5.15p3,6
|
||||||
QualType lhptee, rhptee;
|
QualType lhptee, rhptee;
|
||||||
|
|
||||||
|
@ -428,11 +433,6 @@ inline QualType Sema::CheckConditionalOperands( // C99 6.5.15
|
||||||
lhptee = cast<PointerType>(lhs.getCanonicalType())->getPointeeType();
|
lhptee = cast<PointerType>(lhs.getCanonicalType())->getPointeeType();
|
||||||
rhptee = cast<PointerType>(rhs.getCanonicalType())->getPointeeType();
|
rhptee = cast<PointerType>(rhs.getCanonicalType())->getPointeeType();
|
||||||
|
|
||||||
if (RHS->isNullPointerConstant()) // C99 6.5.15p3
|
|
||||||
return lhs;
|
|
||||||
if (LHS->isNullPointerConstant())
|
|
||||||
return rhs;
|
|
||||||
|
|
||||||
// ignore qualifiers on void (C99 6.5.15p3, clause 6)
|
// ignore qualifiers on void (C99 6.5.15p3, clause 6)
|
||||||
if (lhptee.getUnqualifiedType()->isVoidType() &&
|
if (lhptee.getUnqualifiedType()->isVoidType() &&
|
||||||
(rhptee->isObjectType() || rhptee->isIncompleteType()))
|
(rhptee->isObjectType() || rhptee->isIncompleteType()))
|
||||||
|
|
Loading…
Reference in New Issue