-
Notifications
You must be signed in to change notification settings - Fork 13k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
When generating WF criteria, do not visit the same type more than
once. Fixes an infinite stack overflow (#23003).
- Loading branch information
1 parent
14f0942
commit 8c28284
Showing
3 changed files
with
87 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
// Copyright 2015 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 <LICENSE-APACHE or | ||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license | ||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your | ||
// option. This file may not be copied, modified, or distributed | ||
// except according to those terms. | ||
|
||
// A variant of traits-issue-23003 in which an infinite series of | ||
// types are required. This currently creates an overflow. This test | ||
// is included to ensure that some controlled failure, at least, | ||
// results -- but it might be that we should adjust the rules somewhat | ||
// to make this legal. -nmatsakis | ||
|
||
use std::marker::PhantomData; | ||
|
||
trait Async { | ||
type Cancel; | ||
} | ||
|
||
struct Receipt<A:Async> { | ||
marker: PhantomData<A>, | ||
} | ||
|
||
struct Complete<B> { | ||
core: Option<B>, | ||
} | ||
|
||
impl<B> Async for Complete<B> { | ||
type Cancel = Receipt<Complete<Option<B>>>; | ||
} | ||
|
||
fn foo(r: Receipt<Complete<()>>) { } | ||
//~^ ERROR overflow | ||
|
||
fn main() { } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
// Copyright 2015 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 <LICENSE-APACHE or | ||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license | ||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your | ||
// option. This file may not be copied, modified, or distributed | ||
// except according to those terms. | ||
|
||
// Test stack overflow triggered by evaluating the implications. To be | ||
// WF, the type `Receipt<Complete>` would require that `<Complete as | ||
// Async>::Cancel` be WF. This normalizes to `Receipt<Complete>` | ||
// again, leading to an infinite cycle. Issue #23003. | ||
|
||
#![allow(dead_code)] | ||
#![allow(unused_variables)] | ||
|
||
use std::marker::PhantomData; | ||
|
||
trait Async { | ||
type Cancel; | ||
} | ||
|
||
struct Receipt<A:Async> { | ||
marker: PhantomData<A>, | ||
} | ||
|
||
struct Complete { | ||
core: Option<()>, | ||
} | ||
|
||
impl Async for Complete { | ||
type Cancel = Receipt<Complete>; | ||
} | ||
|
||
fn foo(r: Receipt<Complete>) { } | ||
|
||
fn main() { } |