| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
 | // run-pass
#![allow(dead_code)]
#![allow(non_camel_case_types)]
// aux-build:xc.rs
extern crate xc as aux;
use aux::{A, TestEquality, Something};
use aux::B;
fn f<T: aux::A>(i: T) {
    assert_eq!(i.g(), 10);
}
fn welp<T>(i: isize, _x: &T) -> isize {
    i.g()
}
mod stuff {
    pub struct thing { pub x: isize }
}
impl A for stuff::thing {
    fn f(&self) -> isize { 10 }
}
fn g<T, U, V: B<T>>(i: V, j: T, k: U) -> (T, U) {
    i.thing(j, k)
}
fn eq<T: TestEquality>(lhs: &T, rhs: &T) -> bool {
    lhs.test_eq(rhs)
}
fn neq<T: TestEquality>(lhs: &T, rhs: &T) -> bool {
    lhs.test_neq(rhs)
}
impl TestEquality for stuff::thing {
    fn test_eq(&self, rhs: &stuff::thing) -> bool {
        //self.x.test_eq(&rhs.x)
        eq(&self.x, &rhs.x)
    }
}
pub fn main() {
    // Some tests of random things
    f(0);
    assert_eq!(A::lurr(&0, &1), 21);
    let a = stuff::thing { x: 0 };
    let b = stuff::thing { x: 1 };
    let c = Something { x: 1 };
    assert_eq!(0.g(), 10);
    assert_eq!(a.g(), 10);
    assert_eq!(a.h(), 11);
    assert_eq!(c.h(), 11);
    assert_eq!(0.thing(3.14f64, 1), (3.14f64, 1));
    assert_eq!(B::staticthing(&0, 3.14f64, 1), (3.14f64, 1));
    assert_eq!(B::<f64>::staticthing::<isize>(&0, 3.14, 1), (3.14, 1));
    assert_eq!(g(0, 3.14f64, 1), (3.14f64, 1));
    assert_eq!(g(false, 3.14f64, 1), (3.14, 1));
    // Trying out a real one
    assert!(12.test_neq(&10));
    assert!(!10.test_neq(&10));
    assert!(a.test_neq(&b));
    assert!(!a.test_neq(&a));
    assert!(neq(&12, &10));
    assert!(!neq(&10, &10));
    assert!(neq(&a, &b));
    assert!(!neq(&a, &a));
}
 |