// Copyright 2016 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 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. // ignore-tidy-linelength use std::cell::Cell; use std::rc::Rc; // Fast path, main can see the concrete type returned. fn before() -> impl Fn(i32) { let p = Rc::new(Cell::new(0)); move |x| p.set(x) } fn send(_: T) {} fn main() { send(before()); //~^ ERROR the trait bound `std::rc::Rc>: std::marker::Send` is not satisfied send(after()); //~^ ERROR the trait bound `std::rc::Rc>: std::marker::Send` is not satisfied } // Deferred path, main has to wait until typeck finishes, // to check if the return type of after is Send. fn after() -> impl Fn(i32) { let p = Rc::new(Cell::new(0)); move |x| p.set(x) } // Cycles should work as the deferred obligations are // independently resolved and only require the concrete // return type, which can't depend on the obligation. fn cycle1() -> impl Clone { //~^ ERROR cyclic dependency detected //~| cyclic reference send(cycle2().clone()); Rc::new(Cell::new(5)) } fn cycle2() -> impl Clone { send(cycle1().clone()); Rc::new(String::from("foo")) }