about summary refs log tree commit diff
path: root/tests/ui/coroutine/layout-error.rs
blob: 6cf32134025caa849d0c53fb712748c0ef63f6d3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// Verifies that computing a layout of a coroutine tainted by type errors
// doesn't ICE. Regression test for #80998.
//
//@ edition:2018

#![feature(type_alias_impl_trait)]
use std::future::Future;

pub struct Task<F: Future>(F);
impl<F: Future> Task<F> {
    const fn new() -> Self {
        todo!()
    }
    fn spawn(&self, _: impl FnOnce() -> F) {
        todo!()
    }
}

pub type F = impl Future;
#[define_opaque(F)]
fn foo()
where
    F:,
{
    async fn cb() {
        let a = Foo; //~ ERROR cannot find value `Foo` in this scope
    }

    Task::spawn(&POOL, || cb());
}

// Check that statics are inhabited computes they layout.
static POOL: Task<F> = Task::new();

fn main() {}