]> Cypherpunks repositories - gostls13.git/commit
cmd/compile: rewrite f(g()) for multi-value g() during typecheck
authorMatthew Dempsky <mdempsky@google.com>
Wed, 12 Dec 2018 19:15:37 +0000 (11:15 -0800)
committerMatthew Dempsky <mdempsky@google.com>
Thu, 28 Feb 2019 22:50:08 +0000 (22:50 +0000)
commitd96b7fbf98bfac4861cda1b5c17a002ce8d62aa5
tree2aa17da158ef8ba603a66e1dac0181eefd640009
parent9d40fadb1c3245a318b155ee3e19a4de139401dc
cmd/compile: rewrite f(g()) for multi-value g() during typecheck

This CL moves order.go's copyRet logic for rewriting f(g()) into t1,
t2, ... = g(); f(t1, t2, ...) earlier into typecheck. This allows the
rest of the compiler to stop worrying about multi-value functions
appearing outside of OAS2FUNC nodes.

This changes compiler behavior in a few observable ways:

1. Typechecking error messages for builtin functions now use general
case error messages rather than unnecessarily differing ones.

2. Because f(g()) is rewritten before inlining, saved inline bodies
now see the rewritten form too. This could be addressed, but doesn't
seem worthwhile.

3. Most notably, this simplifies escape analysis and fixes a memory
corruption issue in esc.go. See #29197 for details.

Fixes #15992.
Fixes #29197.

Change-Id: I86a70668301efeec8fbd11fe2d242e359a3ad0af
Reviewed-on: https://go-review.googlesource.com/c/153841
Reviewed-by: Robert Griesemer <gri@golang.org>
13 files changed:
src/cmd/compile/internal/gc/esc.go
src/cmd/compile/internal/gc/fmt.go
src/cmd/compile/internal/gc/iexport.go
src/cmd/compile/internal/gc/init.go
src/cmd/compile/internal/gc/inl.go
src/cmd/compile/internal/gc/order.go
src/cmd/compile/internal/gc/typecheck.go
test/cmplx.go
test/copy1.go
test/fixedbugs/issue15992.go [new file with mode: 0644]
test/fixedbugs/issue15992.out [new file with mode: 0644]
test/fixedbugs/issue17038.go
test/fixedbugs/issue9521.go