Skip to content

Commit

Permalink
Rollup merge of #99307 - JohnTitor:issue-64401, r=compiler-errors
Browse files Browse the repository at this point in the history
Add regression test for #64401

Closes #64401
r? `@compiler-errors`

Signed-off-by: Yuki Okushi <jtitor@2k36.org>
  • Loading branch information
JohnTitor committed Jul 16, 2022
2 parents 083a253 + 6465980 commit 202c11b
Showing 1 changed file with 51 additions and 0 deletions.
51 changes: 51 additions & 0 deletions src/test/ui/codegen/issue-64401.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
// build-pass
// The ICE didn't happen with `cargo check` but `cargo build`.

use std::marker::PhantomData;

trait Owned<'a> {
type Reader;
}

impl<'a> Owned<'a> for () {
type Reader = ();
}

trait Handler {
fn handle(&self);
}

struct CtxHandlerWithoutState<M, F> {
message_type: PhantomData<M>,
_function: F,
}

impl<M, F> CtxHandlerWithoutState<M, F> {
pub fn new(_function: F) -> Self {
Self {
message_type: PhantomData,
_function,
}
}
}

impl<'a, M, F> Handler for CtxHandlerWithoutState<M, F>
where
F: Fn(<M as Owned<'a>>::Reader),
M: Owned<'a>,
{
fn handle(&self) {}
}

fn e_to_i<M: for<'a> Owned<'a>>(_: <M as Owned<'_>>::Reader) {}

fn send_external_to_internal<M>()
where
M: for<'a> Owned<'a>,
{
let _: Box<dyn Handler> = Box::new(CtxHandlerWithoutState::<M, _>::new(e_to_i::<M>));
}

fn main() {
send_external_to_internal::<()>()
}

0 comments on commit 202c11b

Please sign in to comment.