Add test for issue #70303

This commit is contained in:
marmeladema 2021-04-20 23:49:04 +01:00
parent 25cb1af7b2
commit 1ef760d88e

View file

@ -0,0 +1,60 @@
// check-pass
#![allow(incomplete_features)]
#![feature(generic_associated_types)]
trait Document {
type Cursor<'a>: DocCursor<'a>;
fn cursor(&self) -> Self::Cursor<'_>;
}
struct DocumentImpl {}
impl Document for DocumentImpl {
type Cursor<'a> = DocCursorImpl<'a>;
fn cursor(&self) -> Self::Cursor<'_> {
DocCursorImpl {
document: &self,
}
}
}
trait DocCursor<'a> {}
struct DocCursorImpl<'a> {
document: &'a DocumentImpl,
}
impl<'a> DocCursor<'a> for DocCursorImpl<'a> {}
struct Lexer<'d, Cursor>
where
Cursor: DocCursor<'d>,
{
cursor: Cursor,
_phantom: std::marker::PhantomData<&'d ()>,
}
impl<'d, Cursor> Lexer<'d, Cursor>
where
Cursor: DocCursor<'d>,
{
pub fn from<Doc>(document: &'d Doc) -> Lexer<'d, Cursor>
where
Doc: Document<Cursor<'d> = Cursor>,
{
Lexer {
cursor: document.cursor(),
_phantom: std::marker::PhantomData,
}
}
}
pub fn main() {
let doc = DocumentImpl {};
let lexer: Lexer<'_, DocCursorImpl<'_>> = Lexer::from(&doc);
}