about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2013-09-09 22:41:03 -0700
committerbors <bors@rust-lang.org>2013-09-09 22:41:03 -0700
commit485446b97ff9c59939b8e583adf447b0ad211bd8 (patch)
tree0d0848922b434fed89a3df871f7d98d541b87902
parent7820fb5ca99785c4812ad32be80998a2a4fb4213 (diff)
parent5ecd3b40538c3d0a186e849f3a57e3a6443a4290 (diff)
downloadrust-485446b97ff9c59939b8e583adf447b0ad211bd8.tar.gz
rust-485446b97ff9c59939b8e583adf447b0ad211bd8.zip
auto merge of #9076 : blake2-ppc/rust/test-for-8585, r=huonw
The issue #8587 is fixed (the original testcase now passes); add that testcase to the suite.


Fixes #8587.
-rw-r--r--src/test/run-pass/nested-function-names-issue-8587.rs50
1 files changed, 50 insertions, 0 deletions
diff --git a/src/test/run-pass/nested-function-names-issue-8587.rs b/src/test/run-pass/nested-function-names-issue-8587.rs
new file mode 100644
index 00000000000..054e0e3ae26
--- /dev/null
+++ b/src/test/run-pass/nested-function-names-issue-8587.rs
@@ -0,0 +1,50 @@
+// Copyright 2013 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.
+
+// Make sure nested functions are separate, even if they have
+// equal name.
+//
+// Issue #8587
+
+pub struct X;
+
+impl X {
+    fn f(&self) -> int {
+        #[inline(never)]
+        fn inner() -> int {
+            0
+        }
+        inner()
+    }
+
+    fn g(&self) -> int {
+        #[inline(never)]
+        fn inner_2() -> int {
+            1
+        }
+        inner_2()
+    }
+
+    fn h(&self) -> int {
+        #[inline(never)]
+        fn inner() -> int {
+            2
+        }
+        inner()
+    }
+}
+
+fn main() {
+    let n = X;
+    assert_eq!(n.f(), 0);
+    assert_eq!(n.g(), 1);
+    // This test `h` used to fail.
+    assert_eq!(n.h(), 2);
+}