mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-25 14:13:38 +00:00
auto merge of #8500 : graydon/rust/2013-08-13-self-rollup, r=thestinger
close #8424 r=brson close #8173 r=brson close #8209 r=strcat
This commit is contained in:
commit
2ec9b8ce2f
@ -26,6 +26,7 @@ use std::os;
|
|||||||
use std::str;
|
use std::str;
|
||||||
use std::task::{spawn_sched, SingleThreaded};
|
use std::task::{spawn_sched, SingleThreaded};
|
||||||
use std::vec;
|
use std::vec;
|
||||||
|
use std::unstable::running_on_valgrind;
|
||||||
|
|
||||||
use extra::test::MetricMap;
|
use extra::test::MetricMap;
|
||||||
|
|
||||||
@ -38,11 +39,21 @@ pub fn run(config: config, testfile: ~str) {
|
|||||||
// that destroys parallelism if we let normal schedulers block.
|
// that destroys parallelism if we let normal schedulers block.
|
||||||
// It should be possible to remove this spawn once std::run is
|
// It should be possible to remove this spawn once std::run is
|
||||||
// rewritten to be non-blocking.
|
// rewritten to be non-blocking.
|
||||||
do spawn_sched(SingleThreaded) {
|
//
|
||||||
|
// We do _not_ create another thread if we're running on V because
|
||||||
|
// it serializes all threads anyways.
|
||||||
|
if running_on_valgrind() {
|
||||||
let config = config.take();
|
let config = config.take();
|
||||||
let testfile = testfile.take();
|
let testfile = testfile.take();
|
||||||
let mut _mm = MetricMap::new();
|
let mut _mm = MetricMap::new();
|
||||||
run_metrics(config, testfile, &mut _mm);
|
run_metrics(config, testfile, &mut _mm);
|
||||||
|
} else {
|
||||||
|
do spawn_sched(SingleThreaded) {
|
||||||
|
let config = config.take();
|
||||||
|
let testfile = testfile.take();
|
||||||
|
let mut _mm = MetricMap::new();
|
||||||
|
run_metrics(config, testfile, &mut _mm);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -727,6 +727,7 @@ mod test {
|
|||||||
use rt::test::*;
|
use rt::test::*;
|
||||||
use cell::Cell;
|
use cell::Cell;
|
||||||
use iter::Times;
|
use iter::Times;
|
||||||
|
use rt::util;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn oneshot_single_thread_close_port_first() {
|
fn oneshot_single_thread_close_port_first() {
|
||||||
@ -875,6 +876,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn oneshot_multi_thread_close_stress() {
|
fn oneshot_multi_thread_close_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do stress_factor().times {
|
do stress_factor().times {
|
||||||
do run_in_newsched_task {
|
do run_in_newsched_task {
|
||||||
let (port, chan) = oneshot::<int>();
|
let (port, chan) = oneshot::<int>();
|
||||||
@ -890,6 +892,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn oneshot_multi_thread_send_close_stress() {
|
fn oneshot_multi_thread_send_close_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do stress_factor().times {
|
do stress_factor().times {
|
||||||
do run_in_newsched_task {
|
do run_in_newsched_task {
|
||||||
let (port, chan) = oneshot::<int>();
|
let (port, chan) = oneshot::<int>();
|
||||||
@ -910,6 +913,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn oneshot_multi_thread_recv_close_stress() {
|
fn oneshot_multi_thread_recv_close_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do stress_factor().times {
|
do stress_factor().times {
|
||||||
do run_in_newsched_task {
|
do run_in_newsched_task {
|
||||||
let (port, chan) = oneshot::<int>();
|
let (port, chan) = oneshot::<int>();
|
||||||
@ -936,6 +940,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn oneshot_multi_thread_send_recv_stress() {
|
fn oneshot_multi_thread_send_recv_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do stress_factor().times {
|
do stress_factor().times {
|
||||||
do run_in_newsched_task {
|
do run_in_newsched_task {
|
||||||
let (port, chan) = oneshot::<~int>();
|
let (port, chan) = oneshot::<~int>();
|
||||||
@ -955,6 +960,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn stream_send_recv_stress() {
|
fn stream_send_recv_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do stress_factor().times {
|
do stress_factor().times {
|
||||||
do run_in_mt_newsched_task {
|
do run_in_mt_newsched_task {
|
||||||
let (port, chan) = stream::<~int>();
|
let (port, chan) = stream::<~int>();
|
||||||
@ -999,6 +1005,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn shared_chan_stress() {
|
fn shared_chan_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do run_in_mt_newsched_task {
|
do run_in_mt_newsched_task {
|
||||||
let (port, chan) = stream();
|
let (port, chan) = stream();
|
||||||
let chan = SharedChan::new(chan);
|
let chan = SharedChan::new(chan);
|
||||||
@ -1018,6 +1025,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn shared_port_stress() {
|
fn shared_port_stress() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
do run_in_mt_newsched_task {
|
do run_in_mt_newsched_task {
|
||||||
// XXX: Removing these type annotations causes an ICE
|
// XXX: Removing these type annotations causes an ICE
|
||||||
let (end_port, end_chan) = stream::<()>();
|
let (end_port, end_chan) = stream::<()>();
|
||||||
@ -1098,6 +1106,8 @@ mod test {
|
|||||||
use rand;
|
use rand;
|
||||||
use rand::RngUtil;
|
use rand::RngUtil;
|
||||||
|
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
|
|
||||||
do run_in_mt_newsched_task {
|
do run_in_mt_newsched_task {
|
||||||
let (end_port, end_chan) = stream::<()>();
|
let (end_port, end_chan) = stream::<()>();
|
||||||
let end_chan = SharedChan::new(end_chan);
|
let end_chan = SharedChan::new(end_chan);
|
||||||
|
@ -819,6 +819,7 @@ mod test {
|
|||||||
use cell::Cell;
|
use cell::Cell;
|
||||||
use rt::thread::Thread;
|
use rt::thread::Thread;
|
||||||
use rt::task::{Task, Sched};
|
use rt::task::{Task, Sched};
|
||||||
|
use rt::util;
|
||||||
use option::{Some};
|
use option::{Some};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
@ -1040,6 +1041,7 @@ mod test {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_stress_schedule_task_states() {
|
fn test_stress_schedule_task_states() {
|
||||||
|
if util::limit_thread_creation_due_to_osx_and_valgrind() { return; }
|
||||||
let n = stress_factor() * 120;
|
let n = stress_factor() * 120;
|
||||||
for _ in range(0, n as int) {
|
for _ in range(0, n as int) {
|
||||||
test_schedule_home_states();
|
test_schedule_home_states();
|
||||||
|
@ -18,7 +18,7 @@ use iterator::{Iterator, range};
|
|||||||
use super::io::net::ip::{SocketAddr, Ipv4Addr, Ipv6Addr};
|
use super::io::net::ip::{SocketAddr, Ipv4Addr, Ipv6Addr};
|
||||||
use vec::{OwnedVector, MutableVector, ImmutableVector};
|
use vec::{OwnedVector, MutableVector, ImmutableVector};
|
||||||
use rt::sched::Scheduler;
|
use rt::sched::Scheduler;
|
||||||
use unstable::run_in_bare_thread;
|
use unstable::{run_in_bare_thread};
|
||||||
use rt::thread::Thread;
|
use rt::thread::Thread;
|
||||||
use rt::task::Task;
|
use rt::task::Task;
|
||||||
use rt::uv::uvio::UvEventLoop;
|
use rt::uv::uvio::UvEventLoop;
|
||||||
@ -162,10 +162,14 @@ pub fn run_in_mt_newsched_task(f: ~fn()) {
|
|||||||
let nthreads = match os::getenv("RUST_RT_TEST_THREADS") {
|
let nthreads = match os::getenv("RUST_RT_TEST_THREADS") {
|
||||||
Some(nstr) => FromStr::from_str(nstr).unwrap(),
|
Some(nstr) => FromStr::from_str(nstr).unwrap(),
|
||||||
None => {
|
None => {
|
||||||
// Using more threads than cores in test code
|
if util::limit_thread_creation_due_to_osx_and_valgrind() {
|
||||||
// to force the OS to preempt them frequently.
|
1
|
||||||
// Assuming that this help stress test concurrent types.
|
} else {
|
||||||
util::num_cpus() * 2
|
// Using more threads than cores in test code
|
||||||
|
// to force the OS to preempt them frequently.
|
||||||
|
// Assuming that this help stress test concurrent types.
|
||||||
|
util::num_cpus() * 2
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -15,6 +15,9 @@ use option::{Some, None};
|
|||||||
use os;
|
use os;
|
||||||
use str::StrSlice;
|
use str::StrSlice;
|
||||||
|
|
||||||
|
#[cfg(target_os="macos")]
|
||||||
|
use unstable::running_on_valgrind;
|
||||||
|
|
||||||
/// Get the number of cores available
|
/// Get the number of cores available
|
||||||
pub fn num_cpus() -> uint {
|
pub fn num_cpus() -> uint {
|
||||||
#[fixed_stack_segment]; #[inline(never)];
|
#[fixed_stack_segment]; #[inline(never)];
|
||||||
@ -28,12 +31,35 @@ pub fn num_cpus() -> uint {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Valgrind has a fixed-sized array (size around 2000) of segment descriptors wired into it; this
|
||||||
|
/// is a hard limit and requires rebuilding valgrind if you want to go beyond it. Normally this is
|
||||||
|
/// not a problem, but in some tests, we produce a lot of threads casually. Making lots of threads
|
||||||
|
/// alone might not be a problem _either_, except on OSX, the segments produced for new threads
|
||||||
|
/// _take a while_ to get reclaimed by the OS. Combined with the fact that libuv schedulers fork off
|
||||||
|
/// a separate thread for polling fsevents on OSX, we get a perfect storm of creating "too many
|
||||||
|
/// mappings" for valgrind to handle when running certain stress tests in the runtime.
|
||||||
|
#[cfg(target_os="macos")]
|
||||||
|
pub fn limit_thread_creation_due_to_osx_and_valgrind() -> bool {
|
||||||
|
running_on_valgrind()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(target_os="macos"))]
|
||||||
|
pub fn limit_thread_creation_due_to_osx_and_valgrind() -> bool {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
/// Get's the number of scheduler threads requested by the environment
|
/// Get's the number of scheduler threads requested by the environment
|
||||||
/// either `RUST_THREADS` or `num_cpus`.
|
/// either `RUST_THREADS` or `num_cpus`.
|
||||||
pub fn default_sched_threads() -> uint {
|
pub fn default_sched_threads() -> uint {
|
||||||
match os::getenv("RUST_THREADS") {
|
match os::getenv("RUST_THREADS") {
|
||||||
Some(nstr) => FromStr::from_str(nstr).unwrap(),
|
Some(nstr) => FromStr::from_str(nstr).unwrap(),
|
||||||
None => num_cpus()
|
None => {
|
||||||
|
if limit_thread_creation_due_to_osx_and_valgrind() {
|
||||||
|
1
|
||||||
|
} else {
|
||||||
|
num_cpus()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -955,6 +955,7 @@ mod tests {
|
|||||||
use path::Path;
|
use path::Path;
|
||||||
use run;
|
use run;
|
||||||
use str;
|
use str;
|
||||||
|
use unstable::running_on_valgrind;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[cfg(windows)]
|
#[cfg(windows)]
|
||||||
@ -1365,13 +1366,4 @@ mod tests {
|
|||||||
|
|
||||||
assert!(output.contains("RUN_TEST_NEW_ENV=123"));
|
assert!(output.contains("RUN_TEST_NEW_ENV=123"));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn running_on_valgrind() -> bool {
|
|
||||||
#[fixed_stack_segment]; #[inline(never)];
|
|
||||||
unsafe { rust_running_on_valgrind() != 0 }
|
|
||||||
}
|
|
||||||
|
|
||||||
extern {
|
|
||||||
fn rust_running_on_valgrind() -> uintptr_t;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ use comm::{GenericChan, GenericPort};
|
|||||||
use comm;
|
use comm;
|
||||||
use prelude::*;
|
use prelude::*;
|
||||||
use task;
|
use task;
|
||||||
|
use libc::uintptr_t;
|
||||||
|
|
||||||
pub mod dynamic_lib;
|
pub mod dynamic_lib;
|
||||||
|
|
||||||
@ -118,3 +119,17 @@ pub fn change_dir_locked(p: &Path, action: &fn()) -> bool {
|
|||||||
fn rust_drop_change_dir_lock();
|
fn rust_drop_change_dir_lock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// Dynamically inquire about whether we're running under V.
|
||||||
|
/// You should usually not use this unless your test definitely
|
||||||
|
/// can't run correctly un-altered. Valgrind is there to help
|
||||||
|
/// you notice weirdness in normal, un-doctored code paths!
|
||||||
|
pub fn running_on_valgrind() -> bool {
|
||||||
|
#[fixed_stack_segment]; #[inline(never)];
|
||||||
|
unsafe { rust_running_on_valgrind() != 0 }
|
||||||
|
}
|
||||||
|
|
||||||
|
extern {
|
||||||
|
fn rust_running_on_valgrind() -> uintptr_t;
|
||||||
|
}
|
||||||
|
19
src/test/auxiliary/xc_conditions.rs
Normal file
19
src/test/auxiliary/xc_conditions.rs
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
#[crate_type="lib"];
|
||||||
|
|
||||||
|
condition! {
|
||||||
|
pub oops: int -> int;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn trouble() -> int {
|
||||||
|
oops::cond.raise(1)
|
||||||
|
}
|
15
src/test/auxiliary/xc_conditions_2.rs
Normal file
15
src/test/auxiliary/xc_conditions_2.rs
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
#[crate_type="lib"];
|
||||||
|
|
||||||
|
condition! {
|
||||||
|
pub oops: int -> int;
|
||||||
|
}
|
21
src/test/auxiliary/xc_conditions_3.rs
Normal file
21
src/test/auxiliary/xc_conditions_3.rs
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
#[crate_type="lib"];
|
||||||
|
|
||||||
|
condition! {
|
||||||
|
pub oops: int -> int;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn guard(k: extern fn() -> int, x: int) -> int {
|
||||||
|
do oops::cond.trap(|i| i*x).inside {
|
||||||
|
k()
|
||||||
|
}
|
||||||
|
}
|
29
src/test/auxiliary/xc_conditions_4.rs
Normal file
29
src/test/auxiliary/xc_conditions_4.rs
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
#[crate_type="lib"];
|
||||||
|
|
||||||
|
#[deriving(Eq)]
|
||||||
|
pub enum Color {
|
||||||
|
Red, Green, Blue
|
||||||
|
}
|
||||||
|
|
||||||
|
condition! {
|
||||||
|
pub oops: (int,float,~str) -> ::Color;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait Thunk<T> {
|
||||||
|
fn call(self) -> T;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn callback<T,TH:Thunk<T>>(t:TH) -> T {
|
||||||
|
t.call()
|
||||||
|
}
|
||||||
|
|
@ -8,7 +8,6 @@
|
|||||||
// option. This file may not be copied, modified, or distributed
|
// option. This file may not be copied, modified, or distributed
|
||||||
// except according to those terms.
|
// except according to those terms.
|
||||||
|
|
||||||
// xfail-win32
|
|
||||||
// Passing enums by value
|
// Passing enums by value
|
||||||
|
|
||||||
pub enum void { }
|
pub enum void { }
|
||||||
|
12
src/test/run-pass/issue-4929.rs
Normal file
12
src/test/run-pass/issue-4929.rs
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
// Copyright 2013 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 make_adder(x: int) -> @fn(int) -> int { |y| x + y }
|
||||||
|
pub fn main() { }
|
40
src/test/run-pass/xc_conditions_client.rs
Normal file
40
src/test/run-pass/xc_conditions_client.rs
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
// xfail-fast
|
||||||
|
// aux-build:xc_conditions.rs
|
||||||
|
|
||||||
|
extern mod xc_conditions;
|
||||||
|
use xc_conditions::oops;
|
||||||
|
use xc_conditions::trouble;
|
||||||
|
|
||||||
|
// Tests of cross-crate conditions; the condition is
|
||||||
|
// defined in lib, and we test various combinations
|
||||||
|
// of `trap` and `raise` in the client or the lib where
|
||||||
|
// the condition was defined. Also in test #4 we use
|
||||||
|
// more complex features (generics, traits) in
|
||||||
|
// combination with the condition.
|
||||||
|
//
|
||||||
|
// trap raise
|
||||||
|
// ------------
|
||||||
|
// xc_conditions : client lib
|
||||||
|
// xc_conditions_2: client client
|
||||||
|
// xc_conditions_3: lib client
|
||||||
|
// xc_conditions_4: client client (with traits)
|
||||||
|
//
|
||||||
|
// the trap=lib, raise=lib case isn't tested since
|
||||||
|
// there's no cross-crate-ness to test in that case.
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
do oops::cond.trap(|_i| 12345).inside {
|
||||||
|
let x = trouble();
|
||||||
|
assert_eq!(x,12345);
|
||||||
|
}
|
||||||
|
}
|
21
src/test/run-pass/xc_conditions_client_2.rs
Normal file
21
src/test/run-pass/xc_conditions_client_2.rs
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
// xfail-fast
|
||||||
|
// aux-build:xc_conditions_2.rs
|
||||||
|
|
||||||
|
extern mod xc_conditions_2;
|
||||||
|
use xcc = xc_conditions_2;
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
do xcc::oops::cond.trap(|_| 1).inside {
|
||||||
|
xcc::oops::cond.raise(1);
|
||||||
|
}
|
||||||
|
}
|
38
src/test/run-pass/xc_conditions_client_3.rs
Normal file
38
src/test/run-pass/xc_conditions_client_3.rs
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
// xfail-fast
|
||||||
|
// aux-build:xc_conditions_3.rs
|
||||||
|
|
||||||
|
extern mod xc_conditions_3;
|
||||||
|
use xcc = xc_conditions_3;
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
assert_eq!(xcc::guard(a, 1), 40);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn a() -> int {
|
||||||
|
assert_eq!(xcc::oops::cond.raise(7), 7);
|
||||||
|
xcc::guard(b, 2)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn b() -> int {
|
||||||
|
assert_eq!(xcc::oops::cond.raise(8), 16);
|
||||||
|
xcc::guard(c, 3)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn c() -> int {
|
||||||
|
assert_eq!(xcc::oops::cond.raise(9), 27);
|
||||||
|
xcc::guard(d, 4)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn d() -> int {
|
||||||
|
xcc::oops::cond.raise(10)
|
||||||
|
}
|
32
src/test/run-pass/xc_conditions_client_4.rs
Normal file
32
src/test/run-pass/xc_conditions_client_4.rs
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
// 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.
|
||||||
|
|
||||||
|
// xfail-fast
|
||||||
|
// aux-build:xc_conditions_4.rs
|
||||||
|
|
||||||
|
extern mod xc_conditions_4;
|
||||||
|
use xcc = xc_conditions_4;
|
||||||
|
|
||||||
|
struct SThunk {
|
||||||
|
x: int
|
||||||
|
}
|
||||||
|
|
||||||
|
impl xcc::Thunk<xcc::Color> for SThunk {
|
||||||
|
fn call(self) -> xcc::Color {
|
||||||
|
xcc::oops::cond.raise((self.x, 1.23, ~"oh no"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
do xcc::oops::cond.trap(|_| xcc::Red).inside {
|
||||||
|
let t = SThunk { x : 10 };
|
||||||
|
assert_eq!(xcc::callback(t), xcc::Red)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user