{
// Make sure the signs are equal for signed zeros.
if (HONOR_SIGNED_ZEROS (m_type) && real_iszero (rv))
- return m_min.sign == m_max.sign && m_min.sign == rv->sign;
+ return rv->sign == m_min.sign || rv->sign == m_max.sign;
return true;
}
return false;
ASSERT_TRUE (r0.contains_p (neg_zero));
ASSERT_FALSE (r0.contains_p (zero));
+ r0 = frange (neg_zero, zero);
+ ASSERT_TRUE (r0.contains_p (neg_zero));
+ ASSERT_TRUE (r0.contains_p (zero));
+
+ r0 = frange_float ("-3", "5");
+ ASSERT_TRUE (r0.contains_p (neg_zero));
+ ASSERT_TRUE (r0.contains_p (zero));
+
// The intersection of zeros that differ in sign is a NAN (or
// undefined if not honoring NANs).
r0 = frange (neg_zero, neg_zero);