diff options
| author | Niko Matsakis <niko@alum.mit.edu> | 2018-08-21 19:23:30 -0400 |
|---|---|---|
| committer | Niko Matsakis <niko@alum.mit.edu> | 2018-08-23 07:38:47 -0400 |
| commit | 89574a6fc7c660172030724a5d1e8c0ef83094a4 (patch) | |
| tree | f56ec1301ce9b6c45d113be5d6a90090a8f4739e | |
| parent | 1ca467d4a1ee8036a91250650c4b785048b77988 (diff) | |
| download | rust-89574a6fc7c660172030724a5d1e8c0ef83094a4.tar.gz rust-89574a6fc7c660172030724a5d1e8c0ef83094a4.zip | |
resolve type variables in the custom type op pathway
| -rw-r--r-- | src/librustc/traits/query/type_op/custom.rs | 3 | ||||
| -rw-r--r-- | src/test/ui/issue-53568.rs | 61 |
2 files changed, 63 insertions, 1 deletions
diff --git a/src/librustc/traits/query/type_op/custom.rs b/src/librustc/traits/query/type_op/custom.rs index 5cf7064b0c2..6a5ef75a660 100644 --- a/src/librustc/traits/query/type_op/custom.rs +++ b/src/librustc/traits/query/type_op/custom.rs @@ -106,7 +106,8 @@ fn scrape_region_constraints<'gcx, 'tcx, R>( infcx.tcx, region_obligations .iter() - .map(|(_, r_o)| (r_o.sup_type, r_o.sub_region)), + .map(|(_, r_o)| (r_o.sup_type, r_o.sub_region)) + .map(|(ty, r)| (infcx.resolve_type_vars_if_possible(&ty), r)), ®ion_constraint_data, ); diff --git a/src/test/ui/issue-53568.rs b/src/test/ui/issue-53568.rs new file mode 100644 index 00000000000..6b479f75172 --- /dev/null +++ b/src/test/ui/issue-53568.rs @@ -0,0 +1,61 @@ +// Copyright 2018 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// Regression test for an NLL-related ICE (#53568) -- we failed to +// resolve inference variables in "custom type-ops". +// +// compile-pass + +#![feature(nll)] +#![allow(dead_code)] + +trait Future { + type Item; +} + +impl<F, T> Future for F +where F: Fn() -> T +{ + type Item = T; +} + +trait Connect {} + +struct Connector<H> { + handler: H, +} + +impl<H, T> Connect for Connector<H> +where + T: 'static, + H: Future<Item = T> +{ +} + +struct Client<C> { + connector: C, +} + +fn build<C>(_connector: C) -> Client<C> { + unimplemented!() +} + +fn client<H>(handler: H) -> Client<impl Connect> +where H: Fn() + Copy +{ + let connector = Connector { + handler, + }; + let client = build(connector); + client +} + +fn main() { } + |
