about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2015-10-26 10:16:52 +0000
committerbors <bors@rust-lang.org>2015-10-26 10:16:52 +0000
commitbf7eec04d8fe597f3da77c84f9855efee8bb2f25 (patch)
treec672788d1e070dc9cd4b89e67e1d8a9d7408ba55 /src/test
parentc44316d4a1ad0fe01ae366e163993aa3980c755f (diff)
parentfbc53e5a63339875922c47b1b87731d012e89848 (diff)
downloadrust-bf7eec04d8fe597f3da77c84f9855efee8bb2f25.tar.gz
rust-bf7eec04d8fe597f3da77c84f9855efee8bb2f25.zip
Auto merge of #29312 - apasel422:issue-21410, r=alexcrichton
Closes #21410.
Closes #24972.
Diffstat (limited to 'src/test')
-rw-r--r--src/test/run-pass/issue-21410.rs15
-rw-r--r--src/test/run-pass/issue-24972.rs36
2 files changed, 51 insertions, 0 deletions
diff --git a/src/test/run-pass/issue-21410.rs b/src/test/run-pass/issue-21410.rs
new file mode 100644
index 00000000000..bc525ba54c3
--- /dev/null
+++ b/src/test/run-pass/issue-21410.rs
@@ -0,0 +1,15 @@
+// Copyright 2015 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 g<F>(_: F) where F: FnOnce(Option<F>) {}
+
+fn main() {
+    g(|_| {  });
+}
diff --git a/src/test/run-pass/issue-24972.rs b/src/test/run-pass/issue-24972.rs
new file mode 100644
index 00000000000..ae7eb84d3e8
--- /dev/null
+++ b/src/test/run-pass/issue-24972.rs
@@ -0,0 +1,36 @@
+// Copyright 2015 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(rustc_private)]
+
+extern crate serialize;
+
+use serialize::{Encodable, Decodable};
+use std::fmt::Display;
+
+pub trait Entity : Decodable + Encodable + Sized {
+    type Key: Clone + Decodable + Encodable + ToString + Display + Eq + Ord + Sized;
+
+    fn id(&self) -> Self::Key;
+
+    fn find_by_id(id: Self::Key) -> Option<Self>;
+}
+
+pub struct DbRef<E: Entity> {
+    pub id: E::Key,
+}
+
+impl<E> DbRef<E> where E: Entity {
+    fn get(self) -> Option<E> {
+        E::find_by_id(self.id)
+    }
+}
+
+fn main() {}