Skip to content

Commit

Permalink
Add test for issue #70303
Browse files Browse the repository at this point in the history
  • Loading branch information
marmeladema committed Apr 20, 2021
1 parent 25cb1af commit 1ef760d
Showing 1 changed file with 60 additions and 0 deletions.
60 changes: 60 additions & 0 deletions src/test/ui/generic-associated-types/issue-70303.rs
Original file line number Diff line number Diff line change
@@ -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);
}

0 comments on commit 1ef760d

Please sign in to comment.