This patch to the Go frontend avoids a crash when invalid code uses invalid constant types with && or ||. Bootstrapped and ran Go testsuite on x86_64-unknown-linux-gnu. Committed to mainline and 4.7 branch.
Ian
diff -r 59ff38be518a go/expressions.cc --- a/go/expressions.cc Fri May 25 14:49:53 2012 -0700 +++ b/go/expressions.cc Wed May 30 16:02:43 2012 -0700 @@ -4475,9 +4475,8 @@ case OPERATOR_LE: case OPERATOR_GT: case OPERATOR_GE: - // These return boolean values and as such must be handled - // elsewhere. - go_unreachable(); + // These return boolean values, not numeric. + return false; default: break; } @@ -5304,24 +5303,13 @@ bool Binary_expression::do_numeric_constant_value(Numeric_constant* nc) const { - Operator op = this->op_; - - if (op == OPERATOR_EQEQ - || op == OPERATOR_NOTEQ - || op == OPERATOR_LT - || op == OPERATOR_LE - || op == OPERATOR_GT - || op == OPERATOR_GE) - return false; - Numeric_constant left_nc; if (!this->left_->numeric_constant_value(&left_nc)) return false; Numeric_constant right_nc; if (!this->right_->numeric_constant_value(&right_nc)) return false; - - return Binary_expression::eval_constant(op, &left_nc, &right_nc, + return Binary_expression::eval_constant(this->op_, &left_nc, &right_nc, this->location(), nc); }