2011-06-24 16:19:58 -05:00
|
|
|
// Binop corner cases
|
|
|
|
|
2011-08-11 00:25:23 -05:00
|
|
|
use std;
|
2011-12-13 18:25:51 -06:00
|
|
|
import unsafe::reinterpret_cast;
|
|
|
|
import task;
|
|
|
|
import comm;
|
2011-08-11 00:25:23 -05:00
|
|
|
|
2011-06-24 16:19:58 -05:00
|
|
|
fn test_nil() {
|
2011-07-27 07:19:39 -05:00
|
|
|
assert (() == ());
|
|
|
|
assert (!(() != ()));
|
|
|
|
assert (!(() < ()));
|
|
|
|
assert (() <= ());
|
|
|
|
assert (!(() > ()));
|
|
|
|
assert (() >= ());
|
2011-06-24 16:19:58 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_bool() {
|
2011-07-27 07:19:39 -05:00
|
|
|
assert (!(true < false));
|
|
|
|
assert (!(true <= false));
|
|
|
|
assert (true > false);
|
|
|
|
assert (true >= false);
|
|
|
|
|
|
|
|
assert (false < true);
|
|
|
|
assert (false <= true);
|
|
|
|
assert (!(false > true));
|
|
|
|
assert (!(false >= true));
|
|
|
|
|
|
|
|
// Bools support bitwise binops
|
|
|
|
assert (false & false == false);
|
|
|
|
assert (true & false == false);
|
|
|
|
assert (true & true == true);
|
|
|
|
assert (false | false == false);
|
|
|
|
assert (true | false == true);
|
|
|
|
assert (true | true == true);
|
|
|
|
assert (false ^ false == false);
|
|
|
|
assert (true ^ false == true);
|
|
|
|
assert (true ^ true == false);
|
2011-06-24 16:19:58 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_char() {
|
2011-07-27 07:19:39 -05:00
|
|
|
let ch10 = 10 as char;
|
|
|
|
let ch4 = 4 as char;
|
|
|
|
let ch2 = 2 as char;
|
|
|
|
assert (ch10 + ch4 == 14 as char);
|
|
|
|
assert (ch10 - ch4 == 6 as char);
|
|
|
|
assert (ch10 * ch4 == 40 as char);
|
|
|
|
assert (ch10 / ch4 == ch2);
|
|
|
|
assert (ch10 % ch4 == ch2);
|
|
|
|
assert (ch10 >> ch2 == ch2);
|
|
|
|
assert (ch10 << ch4 == 160 as char);
|
|
|
|
assert (ch10 | ch4 == 14 as char);
|
|
|
|
assert (ch10 & ch2 == ch2);
|
|
|
|
assert (ch10 ^ ch2 == 8 as char);
|
2011-06-24 16:19:58 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_box() {
|
2011-08-12 17:14:17 -05:00
|
|
|
assert (@10 == @10);
|
2011-06-24 16:19:58 -05:00
|
|
|
}
|
|
|
|
|
2012-02-05 18:50:54 -06:00
|
|
|
fn test_ptr() unsafe {
|
|
|
|
let p1: *u8 = unsafe::reinterpret_cast(0);
|
|
|
|
let p2: *u8 = unsafe::reinterpret_cast(0);
|
|
|
|
let p3: *u8 = unsafe::reinterpret_cast(1);
|
|
|
|
|
|
|
|
assert p1 == p2;
|
|
|
|
assert p1 != p3;
|
|
|
|
assert p1 < p3;
|
|
|
|
assert p1 <= p3;
|
|
|
|
assert p3 > p1;
|
|
|
|
assert p3 >= p3;
|
|
|
|
assert p1 <= p2;
|
|
|
|
assert p1 >= p2;
|
2011-06-24 16:19:58 -05:00
|
|
|
}
|
|
|
|
|
2011-11-16 22:49:38 -06:00
|
|
|
#[abi = "cdecl"]
|
2011-12-15 14:25:29 -06:00
|
|
|
#[nolink]
|
2012-07-03 18:11:00 -05:00
|
|
|
extern mod test {
|
2012-07-17 21:10:52 -05:00
|
|
|
fn rust_get_sched_id() -> libc::intptr_t;
|
|
|
|
fn get_task_id() -> libc::intptr_t;
|
2011-06-24 16:19:58 -05:00
|
|
|
}
|
|
|
|
|
2012-08-15 20:46:55 -05:00
|
|
|
struct p {
|
2012-06-25 14:20:10 -05:00
|
|
|
let mut x: int;
|
|
|
|
let mut y: int;
|
|
|
|
new(x: int, y: int) { self.x = x; self.y = y; }
|
|
|
|
}
|
|
|
|
|
2012-08-27 18:26:35 -05:00
|
|
|
impl p : cmp::Eq {
|
|
|
|
pure fn eq(&&other: p) -> bool {
|
|
|
|
self.x == other.x && self.y == other.y
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-25 14:20:10 -05:00
|
|
|
fn test_class() {
|
|
|
|
let q = p(1, 2);
|
|
|
|
let r = p(1, 2);
|
|
|
|
|
|
|
|
unsafe {
|
2012-08-22 19:24:52 -05:00
|
|
|
error!("q = %x, r = %x",
|
2012-06-25 14:20:10 -05:00
|
|
|
(unsafe::reinterpret_cast::<*p, uint>(ptr::addr_of(q))),
|
2012-08-22 19:24:52 -05:00
|
|
|
(unsafe::reinterpret_cast::<*p, uint>(ptr::addr_of(r))));
|
2012-06-25 14:20:10 -05:00
|
|
|
}
|
|
|
|
assert(q == r);
|
|
|
|
r.y = 17;
|
|
|
|
assert(r.y != q.y);
|
|
|
|
assert(r.y == 17);
|
|
|
|
assert(q != r);
|
|
|
|
}
|
|
|
|
|
2011-06-24 16:19:58 -05:00
|
|
|
fn main() {
|
2011-07-27 07:19:39 -05:00
|
|
|
test_nil();
|
|
|
|
test_bool();
|
|
|
|
test_char();
|
|
|
|
test_box();
|
|
|
|
test_ptr();
|
2012-06-25 21:28:27 -05:00
|
|
|
test_class();
|
2011-08-09 18:28:10 -05:00
|
|
|
}
|