-
Notifications
You must be signed in to change notification settings - Fork 13.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Avoid ever constructing cyclic types in the first place, rather than …
…detecting them in resolve. This simplifies logic elsewhere in the compiler. cc #5527
- Loading branch information
1 parent
b625d43
commit c4d56b7
Showing
6 changed files
with
127 additions
and
51 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
// Copyright 2012 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. | ||
|
||
use std::gc::GC; | ||
|
||
fn main() { | ||
let f; | ||
let g; | ||
g = f; | ||
f = box(GC) g; //~ ERROR cyclic type of infinite size | ||
} |
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
c4d56b7
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 pcwalton
at nikomatsakis@c4d56b7
c4d56b7
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/occurs-check = c4d56b7 into auto
c4d56b7
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/occurs-check = c4d56b7 merged ok, testing candidate = c8b0d66
c4d56b7
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/1305
success: http://buildbot.rust-lang.org/builders/auto-mac-64-opt/builds/1304
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-c/builds/1304
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-t/builds/1305
success: http://buildbot.rust-lang.org/builders/auto-linux-32-opt/builds/1299
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-c/builds/1298
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-t/builds/1299
success: http://buildbot.rust-lang.org/builders/auto-linux-64-opt/builds/1303
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-c/builds/1298
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-t/builds/1298
success: http://buildbot.rust-lang.org/builders/auto-linux-64-x-android-t/builds/1302
success: http://buildbot.rust-lang.org/builders/auto-win32-32-opt/builds/135
success: http://buildbot.rust-lang.org/builders/auto-win32-32-nopt-t/builds/135
success: http://buildbot.rust-lang.org/builders/auto-win32-32-nopt-c/builds/135
success: http://buildbot.rust-lang.org/builders/auto-win64-64-opt/builds/135
success: http://buildbot.rust-lang.org/builders/auto-win64-64-nopt-t/builds/135
success: http://buildbot.rust-lang.org/builders/auto-win64-64-nopt-c/builds/135
c4d56b7
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 = c8b0d66