diff options
| author | Niko Matsakis <niko@alum.mit.edu> | 2018-09-26 16:37:31 -0400 |
|---|---|---|
| committer | Niko Matsakis <niko@alum.mit.edu> | 2018-09-26 17:07:25 -0400 |
| commit | bcfdfe4e5007867dcd2e80a36921dfc538aae9d9 (patch) | |
| tree | d4d96a5ca2de12a160efed3fbc07f61423b2230b /src/test | |
| parent | c7df1f530b8a88f471e60e933868e7ddf456974d (diff) | |
| download | rust-bcfdfe4e5007867dcd2e80a36921dfc538aae9d9.tar.gz rust-bcfdfe4e5007867dcd2e80a36921dfc538aae9d9.zip | |
use the closure def-id in returns, but closure-base def-id in locals
Using the `closure_base_def_id` indiscriminantely, as we were doing before, winds up "going wrong" if the closure type includes the `impl Trait` from the parent. The problem arises because the return value for closures is inferred and meant to treat the return type *opaquely*, so we don't want to be "desugaring" it into the underlying type.
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/ui/impl-trait/closure-calling-parent-fn.rs | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/test/ui/impl-trait/closure-calling-parent-fn.rs b/src/test/ui/impl-trait/closure-calling-parent-fn.rs new file mode 100644 index 00000000000..cb5f78bd6fc --- /dev/null +++ b/src/test/ui/impl-trait/closure-calling-parent-fn.rs @@ -0,0 +1,14 @@ +#![feature(nll)] + +// Regression test for #54593: the MIR type checker was going wrong +// when a closure returns the `impl Copy` from its parent fn. It was +// (incorrectly) replacing the `impl Copy` in its return type with the +// hidden type (`()`) but that type resulted from a recursive call to +// `foo` and hence is treated opaquely within the closure body. This +// resulted in a failed subtype relationship. +// +// run-pass + +fn foo() -> impl Copy { || foo(); } +fn bar() -> impl Copy { || bar(); } +fn main() { } |
