about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2014-01-30 07:06:27 -0800
committerbors <bors@rust-lang.org>2014-01-30 07:06:27 -0800
commit30e9bbaa2ce0042406c197cee142cbcbcbb7bc64 (patch)
treedc2f6df9315b0a0914242aee56c4650e79ff2372 /src
parente3dc5f5bcd5f5c8cd4267fb7533587e0fb663a60 (diff)
parentdbd8f2605a23d3999608c83ad9839a463970812f (diff)
downloadrust-30e9bbaa2ce0042406c197cee142cbcbcbb7bc64.tar.gz
rust-30e9bbaa2ce0042406c197cee142cbcbcbb7bc64.zip
auto merge of #11914 : FlaPer87/rust/issue-6157, r=alexcrichton
closes #6157
Diffstat (limited to 'src')
-rw-r--r--src/test/run-pass/issue-6157.rs30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/test/run-pass/issue-6157.rs b/src/test/run-pass/issue-6157.rs
new file mode 100644
index 00000000000..50e5f97034a
--- /dev/null
+++ b/src/test/run-pass/issue-6157.rs
@@ -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.
+
+pub trait OpInt<'a> { fn call<'a>(&'a self, int, int) -> int; }
+
+impl<'a> OpInt<'a> for 'a |int, int| -> int {
+    fn call(&self, a:int, b:int) -> int {
+        (*self)(a, b)
+    }
+}
+
+fn squarei<'a>(x: int, op: &'a OpInt) -> int { op.call(x, x) }
+
+fn muli(x:int, y:int) -> int { x * y }
+
+pub fn main() {
+    let f = |x,y| muli(x,y);
+    {
+        let g = &f;
+        let h = g as &OpInt;
+        squarei(3, h);
+    }
+}