rust/src/test/run-pass/conditional-compile.rs

88 lines
1.6 KiB
Rust
Raw Normal View History

#[cfg(bogus)]
2011-07-27 14:19:39 +02:00
const b: bool = false;
2011-07-27 14:19:39 +02:00
const b: bool = true;
#[cfg(bogus)]
native "rust" mod rustrt {
2011-07-27 14:19:39 +02:00
// This symbol doesn't exist and would be a link error if this
// module was translated
fn bogus();
}
2011-07-27 14:19:39 +02:00
native "rust" mod rustrt { }
#[cfg(bogus)]
type t = int;
type t = bool;
#[cfg(bogus)]
2011-07-27 14:19:39 +02:00
tag tg { foo; }
2011-07-27 14:19:39 +02:00
tag tg { bar; }
#[cfg(bogus)]
obj o() {
2011-07-27 14:19:39 +02:00
fn f() { ret bogus; }
}
2011-07-27 14:19:39 +02:00
obj o() { }
#[cfg(bogus)]
2011-07-27 14:19:39 +02:00
resource r(i: int) { }
2011-07-27 14:19:39 +02:00
resource r(i: int) { }
#[cfg(bogus)]
mod m {
2011-07-27 14:19:39 +02:00
// This needs to parse but would fail in typeck. Since it's not in
// the current config it should not be typechecked.
fn bogus() { ret 0; }
}
mod m {
2011-07-27 14:19:39 +02:00
// Submodules have slightly different code paths than the top-level
// module, so let's make sure this jazz works here as well
#[cfg(bogus)]
fn f() { }
2011-07-27 14:19:39 +02:00
fn f() { }
}
// Since the bogus configuration isn't defined main will just be
// parsed, but nothing further will be done with it
#[cfg(bogus)]
fn main() { fail }
fn main() {
2011-07-27 14:19:39 +02:00
// Exercise some of the configured items in ways that wouldn't be possible
// if they had the bogus definition
assert (b);
let x: t = true;
let y: tg = bar;
2011-07-27 14:19:39 +02:00
test_in_fn_ctxt();
}
fn test_in_fn_ctxt() {
2011-07-27 14:19:39 +02:00
#[cfg(bogus)]
fn f() { fail }
fn f() { }
f();
#[cfg(bogus)]
const i: int = 0;
const i: int = 1;
assert (i == 1);
}
mod test_native_items {
2011-07-27 14:19:39 +02:00
native "rust" mod rustrt {
#[cfg(bogus)]
fn vec_from_buf_shared<T>(ptr: *T, count: uint) -> [T];
fn vec_from_buf_shared<T>(ptr: *T, count: uint) -> [T];
2011-07-27 14:19:39 +02:00
}
}