about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorAlex Crichton <alex@alexcrichton.com>2014-10-30 08:57:40 -0700
committerAlex Crichton <alex@alexcrichton.com>2014-10-30 09:29:24 -0700
commitfc3ed0c8084960ea40e95ee0505d42ede96e8158 (patch)
treebb170a131ee266293053d16ef9ad12114d4efff1 /src/test
parentf3ba5186758589983f13e088ce9ee2003265b9c5 (diff)
parent12619bede2cb08d8d58375e2dd188bd27a03d896 (diff)
downloadrust-fc3ed0c8084960ea40e95ee0505d42ede96e8158.tar.gz
rust-fc3ed0c8084960ea40e95ee0505d42ede96e8158.zip
rollup merge of #18413 : bkoropoff/issue-18412
Diffstat (limited to 'src/test')
-rw-r--r--src/test/run-pass/issue-18412.rs36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/test/run-pass/issue-18412.rs b/src/test/run-pass/issue-18412.rs
new file mode 100644
index 00000000000..c03301f17f3
--- /dev/null
+++ b/src/test/run-pass/issue-18412.rs
@@ -0,0 +1,36 @@
+// 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.
+
+#![feature(tuple_indexing)]
+
+// Test that non-static methods can be assigned to local variables as
+// function pointers.
+
+trait Foo {
+    fn foo(&self) -> uint;
+}
+
+struct A(uint);
+
+impl A {
+    fn bar(&self) -> uint { self.0 }
+}
+
+impl Foo for A {
+    fn foo(&self) -> uint { self.bar() }
+}
+
+fn main() {
+    let f = A::bar;
+    let g = Foo::foo;
+    let a = A(42);
+
+    assert_eq!(f(&a), g(&a));
+}