rust/src/test/run-pass/binops.rs

128 lines
3.2 KiB
Rust
Raw Normal View History

// Copyright 2012 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.
// Binop corner cases
fn test_nil() {
fail_unless!((() == ()));
fail_unless!((!(() != ())));
fail_unless!((!(() < ())));
fail_unless!((() <= ()));
fail_unless!((!(() > ())));
fail_unless!((() >= ()));
}
fn test_bool() {
fail_unless!((!(true < false)));
fail_unless!((!(true <= false)));
fail_unless!((true > false));
fail_unless!((true >= false));
2011-07-27 07:19:39 -05:00
fail_unless!((false < true));
fail_unless!((false <= true));
fail_unless!((!(false > true)));
fail_unless!((!(false >= true)));
2011-07-27 07:19:39 -05:00
// Bools support bitwise binops
fail_unless!((false & false == false));
fail_unless!((true & false == false));
fail_unless!((true & true == true));
fail_unless!((false | false == false));
fail_unless!((true | false == true));
fail_unless!((true | true == true));
fail_unless!((false ^ false == false));
fail_unless!((true ^ false == true));
fail_unless!((true ^ true == false));
}
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;
fail_unless!((ch10 + ch4 == 14 as char));
fail_unless!((ch10 - ch4 == 6 as char));
fail_unless!((ch10 * ch4 == 40 as char));
fail_unless!((ch10 / ch4 == ch2));
fail_unless!((ch10 % ch4 == ch2));
fail_unless!((ch10 >> ch2 == ch2));
fail_unless!((ch10 << ch4 == 160 as char));
fail_unless!((ch10 | ch4 == 14 as char));
fail_unless!((ch10 & ch2 == ch2));
fail_unless!((ch10 ^ ch2 == 8 as char));
}
fn test_box() {
fail_unless!((@10 == @10));
}
fn test_ptr() {
unsafe {
let p1: *u8 = ::core::cast::reinterpret_cast(&0);
let p2: *u8 = ::core::cast::reinterpret_cast(&0);
let p3: *u8 = ::core::cast::reinterpret_cast(&1);
2012-02-05 18:50:54 -06:00
fail_unless!(p1 == p2);
fail_unless!(p1 != p3);
fail_unless!(p1 < p3);
fail_unless!(p1 <= p3);
fail_unless!(p3 > p1);
fail_unless!(p3 >= p3);
fail_unless!(p1 <= p2);
fail_unless!(p1 >= p2);
}
}
mod test {
#[abi = "cdecl"]
#[nolink]
pub extern {
pub fn rust_get_sched_id() -> libc::intptr_t;
pub fn get_task_id() -> libc::intptr_t;
}
}
#[deriving_eq]
2012-08-15 20:46:55 -05:00
struct p {
x: int,
y: int,
2012-09-05 17:58:43 -05:00
}
fn p(x: int, y: int) -> p {
p {
x: x,
y: y
}
}
fn test_class() {
let mut q = p(1, 2);
let mut r = p(1, 2);
unsafe {
2012-08-22 19:24:52 -05:00
error!("q = %x, r = %x",
(::core::cast::reinterpret_cast::<*p, uint>(&ptr::addr_of(&q))),
(::core::cast::reinterpret_cast::<*p, uint>(&ptr::addr_of(&r))));
}
fail_unless!((q == r));
r.y = 17;
fail_unless!((r.y != q.y));
fail_unless!((r.y == 17));
fail_unless!((q != r));
}
pub fn main() {
2011-07-27 07:19:39 -05:00
test_nil();
test_bool();
test_char();
test_box();
test_ptr();
test_class();
}