//@ run-pass // Check that coercions unify the expected return type of a polymorphic // function call, instead of leaving the type variables as they were. //@ pretty-expanded FIXME #23616 struct Foo; impl Foo { fn foo(self, x: T) -> Option { Some(x) } } pub fn main() { let _: Option = Some(main); let _: Option = Foo.foo(main); // The same two cases, with implicit type variables made explicit. let _: Option = Some::<_>(main); let _: Option = Foo.foo::<_>(main); }