aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@gcc.gnu.org>2017-06-09 04:35:57 +0000
committerIan Lance Taylor <ian@gcc.gnu.org>2017-06-09 04:35:57 +0000
commit1ee77fbdea58944b047de8ff88901aea4e93ed7d (patch)
treefde3276ecdbc4adc9069be75cd0ed4b3fbe684f7 /gcc
parent120ef1d50ab7fe53a67fb2026374b2bdd67838bd (diff)
downloadgcc-1ee77fbdea58944b047de8ff88901aea4e93ed7d.zip
gcc-1ee77fbdea58944b047de8ff88901aea4e93ed7d.tar.gz
gcc-1ee77fbdea58944b047de8ff88901aea4e93ed7d.tar.bz2
compiler: additional lvalue/rvalue context fixes
Fix lvalue/rvalue context mixup Set_and_use_temporary_expression's do_get_backend() method. Enhance Mark_lvalue_varexprs to handle conversions and temporary reference expressions, since occasionally the front end emits code such as "deref(conv(tempref)) = ...". Reviewed-on: https://go-review.googlesource.com/45141 From-SVN: r249047
Diffstat (limited to 'gcc')
-rw-r--r--gcc/go/gofrontend/MERGE2
-rw-r--r--gcc/go/gofrontend/expressions.cc4
-rw-r--r--gcc/go/gofrontend/statements.cc15
3 files changed, 18 insertions, 3 deletions
diff --git a/gcc/go/gofrontend/MERGE b/gcc/go/gofrontend/MERGE
index 3280bcf..1bfac59 100644
--- a/gcc/go/gofrontend/MERGE
+++ b/gcc/go/gofrontend/MERGE
@@ -1,4 +1,4 @@
-82961ce59e8bb02598d963d2a05b3acca860d9dd
+d4875b19266d5f726e0e32843b903075f5c50b4c
The first line of this file holds the git revision number of the last
merge done from the gofrontend repository.
diff --git a/gcc/go/gofrontend/expressions.cc b/gcc/go/gofrontend/expressions.cc
index 5689c77..d6d27ee 100644
--- a/gcc/go/gofrontend/expressions.cc
+++ b/gcc/go/gofrontend/expressions.cc
@@ -962,7 +962,7 @@ Set_and_use_temporary_expression::do_get_backend(Translate_context* context)
Location loc = this->location();
Gogo* gogo = context->gogo();
Bvariable* bvar = this->statement_->get_backend_variable(context);
- Bexpression* lvar_ref = gogo->backend()->var_expression(bvar, VE_rvalue, loc);
+ Bexpression* lvar_ref = gogo->backend()->var_expression(bvar, VE_lvalue, loc);
Named_object* fn = context->function();
go_assert(fn != NULL);
@@ -970,7 +970,7 @@ Set_and_use_temporary_expression::do_get_backend(Translate_context* context)
Bexpression* bexpr = this->expr_->get_backend(context);
Bstatement* set = gogo->backend()->assignment_statement(bfn, lvar_ref,
bexpr, loc);
- Bexpression* var_ref = gogo->backend()->var_expression(bvar, VE_lvalue, loc);
+ Bexpression* var_ref = gogo->backend()->var_expression(bvar, VE_rvalue, loc);
Bexpression* ret = gogo->backend()->compound_expression(set, var_ref, loc);
return ret;
}
diff --git a/gcc/go/gofrontend/statements.cc b/gcc/go/gofrontend/statements.cc
index ae3873e..7a448d7 100644
--- a/gcc/go/gofrontend/statements.cc
+++ b/gcc/go/gofrontend/statements.cc
@@ -912,6 +912,21 @@ int Mark_lvalue_varexprs::expression(Expression** ppexpr)
if (ue && ue->op() == OPERATOR_MULT)
return TRAVERSE_CONTINUE;
+ Type_conversion_expression* ce = e->conversion_expression();
+ if (ce)
+ return TRAVERSE_CONTINUE;
+
+ Temporary_reference_expression* tre =
+ e->temporary_reference_expression();
+ if (tre)
+ {
+ tre = new Temporary_reference_expression(tre->statement(),
+ tre->location());
+ *ppexpr = tre;
+ tre->set_is_lvalue();
+ return TRAVERSE_EXIT;
+ }
+
return TRAVERSE_EXIT;
}