Auto merge of #25344 - arielb1:fresh-float, r=nikomatsakis
There is no subtyping relationship between the types (or their non-freshened variants), so they can not be merged. Fixes #22645 Fixes #24352 Fixes #23825 Should fix #25235 (no test in issue). Should fix #19976 (test is outdated).
This commit is contained in:
commit
222cd73b8a
8 changed files with 90 additions and 11 deletions
29
src/test/compile-fail/issue-22645.rs
Normal file
29
src/test/compile-fail/issue-22645.rs
Normal file
|
|
@ -0,0 +1,29 @@
|
|||
// 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.
|
||||
|
||||
use std::ops::Add;
|
||||
|
||||
trait Scalar {}
|
||||
impl Scalar for f64 {}
|
||||
|
||||
struct Bob;
|
||||
|
||||
impl<RHS: Scalar> Add <RHS> for Bob {
|
||||
type Output = Bob;
|
||||
fn add(self, rhs : RHS) -> Bob {}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let b = Bob + 3.5;
|
||||
b + 3 //~ ERROR: is not implemented
|
||||
//~^ ERROR: is not implemented
|
||||
//~^^ ERROR: is not implemented
|
||||
//~^^^ ERROR: mismatched types
|
||||
}
|
||||
15
src/test/compile-fail/issue-24352.rs
Normal file
15
src/test/compile-fail/issue-24352.rs
Normal file
|
|
@ -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 main() {
|
||||
1.0f64 - 1.0;
|
||||
1.0f64 - 1 //~ ERROR: is not implemented
|
||||
//~^ ERROR: is not implemented
|
||||
}
|
||||
30
src/test/run-pass/issue-23825.rs
Normal file
30
src/test/run-pass/issue-23825.rs
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
// 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.
|
||||
|
||||
trait Stringify {
|
||||
fn to_string(&self) -> String;
|
||||
}
|
||||
|
||||
impl Stringify for u32 {
|
||||
fn to_string(&self) -> String { format!("u32: {}", *self) }
|
||||
}
|
||||
|
||||
impl Stringify for f32 {
|
||||
fn to_string(&self) -> String { format!("f32: {}", *self) }
|
||||
}
|
||||
|
||||
fn print<T: Stringify>(x: T) -> String {
|
||||
x.to_string()
|
||||
}
|
||||
|
||||
fn main() {
|
||||
assert_eq!(&print(5), "u32: 5");
|
||||
assert_eq!(&print(5.0), "f32: 5");
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue