]> git.lizzy.rs Git - rust.git/commitdiff
Add missing test case for contravariant trait matching
authorNiko Matsakis <niko@alum.mit.edu>
Sat, 31 May 2014 22:48:20 +0000 (18:48 -0400)
committerNiko Matsakis <niko@alum.mit.edu>
Fri, 6 Jun 2014 23:51:23 +0000 (19:51 -0400)
src/test/run-pass/trait-contravariant-self.rs [new file with mode: 0644]

diff --git a/src/test/run-pass/trait-contravariant-self.rs b/src/test/run-pass/trait-contravariant-self.rs
new file mode 100644 (file)
index 0000000..1576c64
--- /dev/null
@@ -0,0 +1,37 @@
+// 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.
+
+// This is an interesting test case. We have a trait (Bar) that is
+// implemented for a `Box<Foo>` object (note: no bounds). And then we
+// have a `Box<Foo:Send>` object. The impl for `Box<Foo>` is applicable
+// to `Box<Foo:Send>` because:
+//
+// 1. The trait Bar is contravariant w/r/t Self because `Self` appears
+//    only in argument position.
+// 2. The impl provides `Bar for Box<Foo>`
+// 3. The fn `wants_bar()` requires `Bar for Box<Foo:Send>`.
+// 4. `Bar for Box<Foo> <: Bar for Box<Foo:Send>` because
+//    `Box<Foo:Send> <: Box<Foo>`.
+
+trait Foo { }
+struct SFoo;
+impl Foo for SFoo { }
+
+trait Bar { fn dummy(&self); }
+impl Bar for Box<Foo> { fn dummy(&self) { } }
+
+fn wants_bar<B:Bar>(b: &B) { }
+
+fn main() {
+    let x: Box<Foo:Send> = (box SFoo);
+    wants_bar(&x);
+}
+
+