Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
riscv-gcc-1
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
riscv-gcc-1
Commits
686875c1
Commit
686875c1
authored
14 years ago
by
Ian Lance Taylor
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Correct handling of methods which call recover.
From-SVN: r168132
parent
059e2a26
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
4 additions
and
10 deletions
+4
-10
gcc/go/gofrontend/expressions.cc
+1
-0
gcc/go/gofrontend/gogo.cc
+3
-10
No files found.
gcc/go/gofrontend/expressions.cc
View file @
686875c1
...
...
@@ -8630,6 +8630,7 @@ Call_expression::do_get_tree(Translate_context* context)
pe
!=
this
->
args_
->
end
();
++
pe
,
++
pp
,
++
i
)
{
gcc_assert
(
pp
!=
params
->
end
());
tree
arg_val
=
(
*
pe
)
->
get_tree
(
context
);
args
[
i
]
=
Expression
::
convert_for_assignment
(
context
,
pp
->
type
(),
...
...
This diff is collapsed.
Click to expand it.
gcc/go/gofrontend/gogo.cc
View file @
686875c1
...
...
@@ -2093,14 +2093,6 @@ Build_recover_thunks::function(Named_object* orig_no)
Expression
*
fn
=
Expression
::
make_func_reference
(
new_no
,
closure
,
location
);
Expression_list
*
args
=
new
Expression_list
();
if
(
orig_fntype
->
is_method
())
{
Named_object
*
rec_no
=
gogo
->
lookup
(
receiver_name
,
NULL
);
gcc_assert
(
rec_no
!=
NULL
&&
rec_no
->
is_variable
()
&&
rec_no
->
var_value
()
->
is_parameter
());
args
->
push_back
(
Expression
::
make_var_reference
(
rec_no
,
location
));
}
if
(
new_params
!=
NULL
)
{
// Note that we skip the last parameter, which is the boolean
...
...
@@ -2153,10 +2145,11 @@ Build_recover_thunks::function(Named_object* orig_no)
&&
!
orig_rec_no
->
var_value
()
->
is_receiver
());
orig_rec_no
->
var_value
()
->
set_is_receiver
();
Named_object
*
new_rec_no
=
new_bindings
->
lookup_local
(
receiver_name
);
const
std
::
string
&
new_receiver_name
(
orig_fntype
->
receiver
()
->
name
());
Named_object
*
new_rec_no
=
new_bindings
->
lookup_local
(
new_receiver_name
);
gcc_assert
(
new_rec_no
!=
NULL
&&
new_rec_no
->
is_variable
()
&&
!
new_rec_no
->
var_value
()
->
is_receiver
());
&&
new_rec_no
->
var_value
()
->
is_receiver
());
new_rec_no
->
var_value
()
->
set_is_not_receiver
();
}
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment