-
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.
Normalize bounds that we extract from where clauses. Fixes #20765.
- Loading branch information
1 parent
b21a6da
commit 47424cd
Showing
6 changed files
with
129 additions
and
30 deletions.
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
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
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
34 changes: 34 additions & 0 deletions
34
src/test/run-pass/associated-types-projection-in-where-clause.rs
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,34 @@ | ||
// 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 a where clause that uses a non-normalized projection type. | ||
|
||
trait Int | ||
{ | ||
type T; | ||
} | ||
|
||
trait NonZero | ||
{ | ||
fn non_zero(self) -> bool; | ||
} | ||
|
||
fn foo<I:Int<T=J>,J>(t: I) -> bool | ||
where <I as Int>::T : NonZero | ||
// ^~~~~~~~~~~~~ canonical form is just J | ||
{ | ||
bar::<J>() | ||
} | ||
|
||
fn bar<NZ:NonZero>() -> bool { true } | ||
|
||
fn main () | ||
{ | ||
} |
47424cd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
saw approval from nrc
at nikomatsakis@47424cd
47424cd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
merging nikomatsakis/rust/issue-20765-normalize-where-clause = 47424cd into auto
47424cd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
status: {"merge_sha": "055cc2ee742e29e389c5bd1da3a9d49ff8ca3724"}
47424cd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nikomatsakis/rust/issue-20765-normalize-where-clause = 47424cd merged ok, testing candidate = 055cc2e
47424cd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
all tests pass:
success: http://buildbot.rust-lang.org/builders/auto-mac-32-opt/builds/3117
success: http://buildbot.rust-lang.org/builders/auto-mac-64-opt/builds/3110
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-t/builds/3111
success: http://buildbot.rust-lang.org/builders/auto-linux-32-opt/builds/3102
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-t/builds/3102
success: http://buildbot.rust-lang.org/builders/auto-linux-64-opt/builds/3105
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-t/builds/3098
success: http://buildbot.rust-lang.org/builders/auto-linux-64-x-android-t/builds/3093
success: http://buildbot.rust-lang.org/builders/auto-win-32-opt/builds/2770
success: http://buildbot.rust-lang.org/builders/auto-win-32-nopt-t/builds/2768
success: http://buildbot.rust-lang.org/builders/auto-win-64-opt/builds/1606
success: http://buildbot.rust-lang.org/builders/auto-win-64-nopt-t/builds/1599
47424cd
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fast-forwarding master to auto = 055cc2e