Commit 28d18db3 by Ian Lance Taylor

compiler: don't permit nil assignment to blank identifier.

Fixes https://code.google.com/p/go/issues/detail?id=6005.

From-SVN: r202881
parent 6a9502fd
......@@ -1940,12 +1940,9 @@ Parse::init_var(const Typed_identifier& tid, Type* type, Expression* init,
{
if (this->gogo_->in_global_scope())
return this->create_dummy_global(type, init, location);
else if (type == NULL)
this->gogo_->add_statement(Statement::make_statement(init, true));
else
{
// With both a type and an initializer, create a dummy
// variable so that we will check whether the
// Create a dummy variable so that we will check whether the
// initializer can be assigned to the type.
Variable* var = new Variable(type, init, false, false, false,
location);
......
......@@ -594,6 +594,15 @@ Assignment_statement::do_check_types(Gogo*)
Type* lhs_type = this->lhs_->type();
Type* rhs_type = this->rhs_->type();
// Invalid assignment of nil to the blank identifier.
if (lhs_type->is_sink_type()
&& rhs_type->is_nil_type())
{
this->report_error(_("use of untyped nil"));
return;
}
std::string reason;
bool ok;
if (this->are_hidden_fields_ok_)
......@@ -975,7 +984,10 @@ Tuple_assignment_statement::do_lower(Gogo*, Named_object*, Block* enclosing,
if ((*plhs)->is_sink_expression())
{
b->add_statement(Statement::make_statement(*prhs, true));
if ((*prhs)->type()->is_nil_type())
this->report_error(_("use of untyped nil"));
else
b->add_statement(Statement::make_statement(*prhs, true));
continue;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment