-
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.
more consistent handling of inner items
- Loading branch information
1 parent
428d5ac
commit 0f847ba
Showing
5 changed files
with
50 additions
and
9 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
-include ../tools.mk | ||
|
||
# Test to make sure that inner functions within a polymorphic outer function | ||
# don't get re-translated when the outer function is monomorphized. The test | ||
# code monomorphizes the outer functions several times, but the magic constants | ||
# used in the inner functions should each appear only once in the generated IR. | ||
|
||
all: | ||
$(RUSTC) foo.rs --emit=ir | ||
[ "$$(grep -c 8675309 "$(TMPDIR)/foo.ll")" -eq "1" ] | ||
[ "$$(grep -c 11235813 "$(TMPDIR)/foo.ll")" -eq "1" ] |
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,30 @@ | ||
// Copyright 2014 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. | ||
|
||
fn outer<T>() { | ||
#[allow(dead_code)] | ||
fn inner() -> uint { | ||
8675309 | ||
} | ||
} | ||
|
||
extern "C" fn outer_foreign<T>() { | ||
#[allow(dead_code)] | ||
fn inner() -> uint { | ||
11235813 | ||
} | ||
} | ||
|
||
fn main() { | ||
outer::<int>(); | ||
outer::<uint>(); | ||
outer_foreign::<int>(); | ||
outer_foreign::<uint>(); | ||
} |
0f847ba
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 https://github.com/epdtry/rust/commit/0f847ba74da083124f3d5d38d36fc1135737c12c
0f847ba
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 epdtry/rust/unreachable-item-ice = 0f847ba into auto
0f847ba
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.
epdtry/rust/unreachable-item-ice = 0f847ba merged ok, testing candidate = e189122
0f847ba
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/798
success: http://buildbot.rust-lang.org/builders/auto-mac-64-opt/builds/798
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-c/builds/797
success: http://buildbot.rust-lang.org/builders/auto-mac-64-nopt-t/builds/798
success: http://buildbot.rust-lang.org/builders/auto-linux-32-opt/builds/794
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-c/builds/795
success: http://buildbot.rust-lang.org/builders/auto-linux-32-nopt-t/builds/794
success: http://buildbot.rust-lang.org/builders/auto-linux-64-opt/builds/800
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-c/builds/795
success: http://buildbot.rust-lang.org/builders/auto-linux-64-nopt-t/builds/794
success: http://buildbot.rust-lang.org/builders/auto-linux-64-x-android-t/builds/797
success: http://buildbot.rust-lang.org/builders/auto-win-32-opt/builds/795
success: http://buildbot.rust-lang.org/builders/auto-win-32-nopt-t/builds/795
success: http://buildbot.rust-lang.org/builders/auto-win-32-nopt-c/builds/796
0f847ba
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 = e189122