about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorBrian Koropoff <bkoropoff@gmail.com>2014-10-18 12:26:54 -0700
committerBrian Koropoff <bkoropoff@gmail.com>2014-10-27 18:51:43 -0700
commite46af8caec4d6b378ba07080ca6a4ee4c92e4856 (patch)
treef89c15d0b611451e5a78a04cbbcce564e173b153 /src/test
parentf0cc3a93651d237a8c5dda1571e823a3cba7ce60 (diff)
downloadrust-e46af8caec4d6b378ba07080ca6a4ee4c92e4856.tar.gz
rust-e46af8caec4d6b378ba07080ca6a4ee4c92e4856.zip
Add regression test for issue #16791
Diffstat (limited to 'src/test')
-rw-r--r--src/test/run-pass/unboxed-closures-monomorphization.rs36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/test/run-pass/unboxed-closures-monomorphization.rs b/src/test/run-pass/unboxed-closures-monomorphization.rs
new file mode 100644
index 00000000000..43fb4b296cc
--- /dev/null
+++ b/src/test/run-pass/unboxed-closures-monomorphization.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.
+
+// Test that unboxed closures in contexts with free type parameters
+// monomorphize correctly (issue #16791)
+
+#![feature(unboxed_closures)]
+
+fn main(){
+    fn bar<'a, T:'a> (t: T) -> Box<FnOnce<(),T> + 'a> {
+        box move |:| t
+    }
+
+    let f = bar(42u);
+    assert_eq!(f.call_once(()), 42);
+
+    let f = bar("forty-two");
+    assert_eq!(f.call_once(()), "forty-two");
+
+    let x = 42u;
+    let f = bar(&x);
+    assert_eq!(f.call_once(()), &x);
+
+    #[deriving(Show, PartialEq)]
+    struct Foo(uint, &'static str);
+    let x = Foo(42, "forty-two");
+    let f = bar(x);
+    assert_eq!(f.call_once(()), x);
+}