format code in tests/ui/threads-sendsync
This commit is contained in:
parent
4074d4902d
commit
70ba8c1820
54 changed files with 315 additions and 247 deletions
|
@ -7,7 +7,7 @@ use std::thread;
|
|||
|
||||
struct Pair {
|
||||
a: isize,
|
||||
b: isize
|
||||
b: isize,
|
||||
}
|
||||
|
||||
pub fn main() {
|
||||
|
@ -16,5 +16,6 @@ pub fn main() {
|
|||
thread::spawn(move || {
|
||||
assert_eq!(z.a, 10);
|
||||
assert_eq!(z.b, 12);
|
||||
}).join();
|
||||
})
|
||||
.join();
|
||||
}
|
||||
|
|
|
@ -2,12 +2,12 @@
|
|||
#![allow(unused_must_use)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
pub fn main() {
|
||||
let (tx, rx) = channel();
|
||||
let t = thread::spawn(move || { child(&tx) });
|
||||
let t = thread::spawn(move || child(&tx));
|
||||
let y = rx.recv().unwrap();
|
||||
println!("received");
|
||||
println!("{}", y);
|
||||
|
|
|
@ -2,14 +2,15 @@
|
|||
//@ needs-threads
|
||||
//@ ignore-sgx no processes
|
||||
|
||||
use std::thread;
|
||||
use std::env;
|
||||
use std::process::Command;
|
||||
use std::{env, thread};
|
||||
|
||||
struct Handle(i32);
|
||||
|
||||
impl Drop for Handle {
|
||||
fn drop(&mut self) { panic!(); }
|
||||
fn drop(&mut self) {
|
||||
panic!();
|
||||
}
|
||||
}
|
||||
|
||||
thread_local!(static HANDLE: Handle = Handle(0));
|
||||
|
@ -19,14 +20,15 @@ fn main() {
|
|||
if args.len() == 1 {
|
||||
let out = Command::new(&args[0]).arg("test").output().unwrap();
|
||||
let stderr = std::str::from_utf8(&out.stderr).unwrap();
|
||||
assert!(stderr.contains("explicit panic"),
|
||||
"bad failure message:\n{}\n", stderr);
|
||||
assert!(stderr.contains("explicit panic"), "bad failure message:\n{}\n", stderr);
|
||||
} else {
|
||||
// TLS dtors are not always run on process exit
|
||||
thread::spawn(|| {
|
||||
HANDLE.with(|h| {
|
||||
println!("{}", h.0);
|
||||
});
|
||||
}).join().unwrap();
|
||||
})
|
||||
.join()
|
||||
.unwrap();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -19,5 +19,7 @@ fn main() {
|
|||
thread::spawn(|| {
|
||||
FOO.with(|_| {});
|
||||
println!("test1");
|
||||
}).join().unwrap();
|
||||
})
|
||||
.join()
|
||||
.unwrap();
|
||||
}
|
||||
|
|
|
@ -11,5 +11,8 @@ pub fn main() {
|
|||
|
||||
thread::spawn(move || {
|
||||
println!("{}", rx.recv().unwrap());
|
||||
}).join().ok().unwrap();
|
||||
})
|
||||
.join()
|
||||
.ok()
|
||||
.unwrap();
|
||||
}
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
//@ run-pass
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Receiver};
|
||||
use std::thread;
|
||||
|
||||
fn periodical(n: isize) -> Receiver<bool> {
|
||||
let (chan, port) = channel();
|
||||
|
@ -16,7 +16,7 @@ fn periodical(n: isize) -> Receiver<bool> {
|
|||
}
|
||||
match chan.send(true) {
|
||||
Ok(()) => {}
|
||||
Err(..) => break
|
||||
Err(..) => break,
|
||||
}
|
||||
}
|
||||
});
|
||||
|
@ -47,7 +47,7 @@ fn main() {
|
|||
(_, true, true) => println!("FizzBuzz"),
|
||||
(_, true, false) => println!("Fizz"),
|
||||
(_, false, true) => println!("Buzz"),
|
||||
(i, false, false) => println!("{}", i)
|
||||
(i, false, false) => println!("{}", i),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
#![allow(deprecated)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::sync::mpsc::{TryRecvError, channel};
|
||||
use std::sync::mpsc::{channel, TryRecvError};
|
||||
use std::thread;
|
||||
|
||||
pub fn main() {
|
||||
|
@ -16,7 +16,7 @@ pub fn main() {
|
|||
match rx.try_recv() {
|
||||
Ok(()) => break,
|
||||
Err(TryRecvError::Empty) => {}
|
||||
Err(TryRecvError::Disconnected) => unreachable!()
|
||||
Err(TryRecvError::Disconnected) => unreachable!(),
|
||||
}
|
||||
}
|
||||
t.join();
|
||||
|
|
|
@ -2,18 +2,12 @@
|
|||
//@ compile-flags:--test
|
||||
//@ needs-threads
|
||||
|
||||
use std::sync::mpsc::channel;
|
||||
use std::sync::mpsc::TryRecvError;
|
||||
use std::sync::mpsc::RecvError;
|
||||
use std::sync::mpsc::RecvTimeoutError;
|
||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||
use std::sync::mpsc::{channel, RecvError, RecvTimeoutError, TryRecvError};
|
||||
use std::sync::Arc;
|
||||
use std::sync::atomic::AtomicUsize;
|
||||
use std::sync::atomic::Ordering;
|
||||
|
||||
use std::thread;
|
||||
use std::time::Duration;
|
||||
|
||||
|
||||
/// Simple thread synchronization utility
|
||||
struct Barrier {
|
||||
// Not using mutex/condvar for precision
|
||||
|
@ -42,7 +36,6 @@ impl Barrier {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
fn shared_close_sender_does_not_lose_messages_iter() {
|
||||
let (tb, rb) = Barrier::new2();
|
||||
|
||||
|
@ -71,7 +64,6 @@ fn shared_close_sender_does_not_lose_messages() {
|
|||
});
|
||||
}
|
||||
|
||||
|
||||
// https://github.com/rust-lang/rust/issues/39364
|
||||
fn concurrent_recv_timeout_and_upgrade_iter() {
|
||||
// 1 us
|
||||
|
@ -85,8 +77,8 @@ fn concurrent_recv_timeout_and_upgrade_iter() {
|
|||
match rx.recv_timeout(sleep) {
|
||||
Ok(_) => {
|
||||
break;
|
||||
},
|
||||
Err(_) => {},
|
||||
}
|
||||
Err(_) => {}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
@ -105,7 +97,6 @@ fn concurrent_recv_timeout_and_upgrade() {
|
|||
});
|
||||
}
|
||||
|
||||
|
||||
fn concurrent_writes_iter() {
|
||||
const THREADS: usize = 4;
|
||||
const PER_THR: usize = 100;
|
||||
|
|
|
@ -1,12 +1,13 @@
|
|||
//@ run-pass
|
||||
#![allow(unused_imports)]
|
||||
use std::thread;
|
||||
use std::sync::Mutex;
|
||||
use std::thread;
|
||||
|
||||
fn par_for<I, F>(iter: I, f: F)
|
||||
where I: Iterator,
|
||||
where
|
||||
I: Iterator,
|
||||
I::Item: Send,
|
||||
F: Fn(I::Item) + Sync
|
||||
F: Fn(I::Item) + Sync,
|
||||
{
|
||||
for item in iter {
|
||||
f(item)
|
||||
|
@ -15,9 +16,7 @@ fn par_for<I, F>(iter: I, f: F)
|
|||
|
||||
fn sum(x: &[i32]) {
|
||||
let sum_lengths = Mutex::new(0);
|
||||
par_for(x.windows(4), |x| {
|
||||
*sum_lengths.lock().unwrap() += x.len()
|
||||
});
|
||||
par_for(x.windows(4), |x| *sum_lengths.lock().unwrap() += x.len());
|
||||
|
||||
assert_eq!(*sum_lengths.lock().unwrap(), (x.len() - 3) * 4);
|
||||
}
|
||||
|
@ -26,9 +25,7 @@ fn main() {
|
|||
let mut elements = [0; 20];
|
||||
|
||||
// iterators over references into this stack frame
|
||||
par_for(elements.iter_mut().enumerate(), |(i, x)| {
|
||||
*x = i as i32
|
||||
});
|
||||
par_for(elements.iter_mut().enumerate(), |(i, x)| *x = i as i32);
|
||||
|
||||
sum(&elements)
|
||||
}
|
||||
|
|
|
@ -6,8 +6,8 @@
|
|||
//@ pretty-expanded FIXME #23616
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::channel;
|
||||
use std::thread;
|
||||
|
||||
struct test {
|
||||
f: isize,
|
||||
|
@ -18,9 +18,7 @@ impl Drop for test {
|
|||
}
|
||||
|
||||
fn test(f: isize) -> test {
|
||||
test {
|
||||
f: f
|
||||
}
|
||||
test { f: f }
|
||||
}
|
||||
|
||||
pub fn main() {
|
||||
|
|
|
@ -9,7 +9,7 @@ use std::sync::mpsc::{channel, Sender};
|
|||
// tests that ctrl's type gets inferred properly
|
||||
struct Command<K, V> {
|
||||
key: K,
|
||||
val: V
|
||||
val: V,
|
||||
}
|
||||
|
||||
fn cache_server<K: Send + 'static, V: Send + 'static>(mut tx: Sender<Sender<Command<K, V>>>) {
|
||||
|
|
|
@ -1,9 +1,7 @@
|
|||
//@ run-pass
|
||||
use std::collections::HashMap;
|
||||
use std::borrow::Cow;
|
||||
|
||||
use std::borrow::Cow::Borrowed as B;
|
||||
use std::borrow::Cow::Owned as O;
|
||||
use std::borrow::Cow::{Borrowed as B, Owned as O};
|
||||
use std::collections::HashMap;
|
||||
|
||||
type SendStr = Cow<'static, str>;
|
||||
|
||||
|
|
|
@ -1,8 +1,7 @@
|
|||
//@ run-pass
|
||||
use std::collections::BTreeMap;
|
||||
use std::borrow::Cow;
|
||||
|
||||
use std::borrow::Cow::{Owned as O, Borrowed as B};
|
||||
use std::borrow::Cow::{Borrowed as B, Owned as O};
|
||||
use std::collections::BTreeMap;
|
||||
|
||||
type SendStr = Cow<'static, str>;
|
||||
|
||||
|
@ -51,8 +50,8 @@ fn main() {
|
|||
assert_eq!(map.get(&O("def".to_string())), Some(&d));
|
||||
|
||||
assert!(map.remove(&B("foo")).is_some());
|
||||
assert_eq!(map.into_iter().map(|(k, v)| format!("{}{}", k, v))
|
||||
.collect::<Vec<String>>()
|
||||
.concat(),
|
||||
"abc50bcd51cde52def53".to_string());
|
||||
assert_eq!(
|
||||
map.into_iter().map(|(k, v)| format!("{}{}", k, v)).collect::<Vec<String>>().concat(),
|
||||
"abc50bcd51cde52def53".to_string()
|
||||
);
|
||||
}
|
||||
|
|
|
@ -16,10 +16,7 @@ struct foo {
|
|||
}
|
||||
|
||||
fn foo(i: isize, j: char) -> foo {
|
||||
foo {
|
||||
i: i,
|
||||
j: j
|
||||
}
|
||||
foo { i: i, j: j }
|
||||
}
|
||||
|
||||
pub fn main() {
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
//@ run-pass
|
||||
|
||||
|
||||
fn test<F>(f: F) -> usize where F: FnOnce(usize) -> usize {
|
||||
fn test<F>(f: F) -> usize
|
||||
where
|
||||
F: FnOnce(usize) -> usize,
|
||||
{
|
||||
return f(22);
|
||||
}
|
||||
|
||||
|
|
|
@ -3,7 +3,9 @@
|
|||
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { test05(); }
|
||||
pub fn main() {
|
||||
test05();
|
||||
}
|
||||
|
||||
fn test05_start<F: FnOnce(isize)>(f: F) {
|
||||
f(22);
|
||||
|
@ -17,5 +19,8 @@ fn test05() {
|
|||
};
|
||||
thread::spawn(move || {
|
||||
test05_start(fn_to_send);
|
||||
}).join().ok().unwrap();
|
||||
})
|
||||
.join()
|
||||
.ok()
|
||||
.unwrap();
|
||||
}
|
||||
|
|
|
@ -9,8 +9,8 @@
|
|||
Arnold.
|
||||
*/
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
type ctx = Sender<isize>;
|
||||
|
||||
|
|
|
@ -7,4 +7,7 @@ pub fn main() {
|
|||
thread::spawn(move || child(10)).join().ok().unwrap();
|
||||
}
|
||||
|
||||
fn child(i: isize) { println!("{}", i); assert_eq!(i, 10); }
|
||||
fn child(i: isize) {
|
||||
println!("{}", i);
|
||||
assert_eq!(i, 10);
|
||||
}
|
||||
|
|
|
@ -6,8 +6,16 @@
|
|||
|
||||
use std::net::ToSocketAddrs;
|
||||
|
||||
fn is_sync<T>(_: T) where T: Sync {}
|
||||
fn is_send<T>(_: T) where T: Send {}
|
||||
fn is_sync<T>(_: T)
|
||||
where
|
||||
T: Sync,
|
||||
{
|
||||
}
|
||||
fn is_send<T>(_: T)
|
||||
where
|
||||
T: Send,
|
||||
{
|
||||
}
|
||||
|
||||
macro_rules! all_sync_send {
|
||||
($ctor:expr, $($iter:ident),+) => ({
|
||||
|
|
|
@ -3,18 +3,20 @@
|
|||
#![allow(warnings)]
|
||||
#![feature(drain, collections_bound, btree_range)]
|
||||
|
||||
use std::collections::BinaryHeap;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::collections::LinkedList;
|
||||
use std::collections::VecDeque;
|
||||
use std::collections::HashMap;
|
||||
use std::collections::HashSet;
|
||||
|
||||
use std::collections::{BTreeMap, BTreeSet, BinaryHeap, HashMap, HashSet, LinkedList, VecDeque};
|
||||
use std::mem;
|
||||
use std::ops::Bound::Included;
|
||||
|
||||
fn is_sync<T>(_: T) where T: Sync {}
|
||||
fn is_send<T>(_: T) where T: Send {}
|
||||
fn is_sync<T>(_: T)
|
||||
where
|
||||
T: Sync,
|
||||
{
|
||||
}
|
||||
fn is_send<T>(_: T)
|
||||
where
|
||||
T: Send,
|
||||
{
|
||||
}
|
||||
|
||||
macro_rules! all_sync_send {
|
||||
($ctor:expr, $($iter:ident),+) => ({
|
||||
|
|
|
@ -5,8 +5,16 @@
|
|||
|
||||
use std::iter::{empty, once, repeat};
|
||||
|
||||
fn is_sync<T>(_: T) where T: Sync {}
|
||||
fn is_send<T>(_: T) where T: Send {}
|
||||
fn is_sync<T>(_: T)
|
||||
where
|
||||
T: Sync,
|
||||
{
|
||||
}
|
||||
fn is_send<T>(_: T)
|
||||
where
|
||||
T: Send,
|
||||
{
|
||||
}
|
||||
|
||||
macro_rules! all_sync_send {
|
||||
($ctor:expr, $iter:ident) => ({
|
||||
|
@ -43,12 +51,12 @@ macro_rules! all_sync_send_mutable_ref {
|
|||
}
|
||||
|
||||
macro_rules! is_sync_send {
|
||||
($ctor:expr) => ({
|
||||
($ctor:expr) => {{
|
||||
let x = $ctor;
|
||||
is_sync(x);
|
||||
let y = $ctor;
|
||||
is_send(y);
|
||||
})
|
||||
}};
|
||||
}
|
||||
|
||||
fn main() {
|
||||
|
@ -63,7 +71,8 @@ fn main() {
|
|||
|
||||
let a = [1];
|
||||
let b = [2];
|
||||
all_sync_send!(a.iter(),
|
||||
all_sync_send!(
|
||||
a.iter(),
|
||||
cloned,
|
||||
cycle,
|
||||
chain([2].iter()),
|
||||
|
@ -80,7 +89,8 @@ fn main() {
|
|||
scan(1, |_, _| Some(1)),
|
||||
flat_map(|_| b.iter()),
|
||||
fuse,
|
||||
inspect(|_| ()));
|
||||
inspect(|_| ())
|
||||
);
|
||||
|
||||
is_sync_send!((1..).step_by(2));
|
||||
is_sync_send!((1..2).step_by(2));
|
||||
|
|
|
@ -2,10 +2,12 @@
|
|||
#![allow(unused_must_use)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { test05(); }
|
||||
pub fn main() {
|
||||
test05();
|
||||
}
|
||||
|
||||
fn test05_start(tx: &Sender<isize>) {
|
||||
tx.send(10).unwrap();
|
||||
|
@ -18,7 +20,7 @@ fn test05_start(tx : &Sender<isize>) {
|
|||
|
||||
fn test05() {
|
||||
let (tx, rx) = channel();
|
||||
let t = thread::spawn(move|| { test05_start(&tx) });
|
||||
let t = thread::spawn(move || test05_start(&tx));
|
||||
let mut value: isize = rx.recv().unwrap();
|
||||
println!("{}", value);
|
||||
value = rx.recv().unwrap();
|
||||
|
|
|
@ -4,9 +4,13 @@
|
|||
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn start() { println!("Started / Finished task."); }
|
||||
fn start() {
|
||||
println!("Started / Finished task.");
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
thread::spawn(move || start()).join();
|
||||
|
|
|
@ -3,8 +3,8 @@
|
|||
#![allow(unused_mut)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
fn start(tx: &Sender<Sender<String>>) {
|
||||
let (tx2, rx) = channel();
|
||||
|
@ -22,7 +22,7 @@ fn start(tx: &Sender<Sender<String>>) {
|
|||
|
||||
pub fn main() {
|
||||
let (tx, rx) = channel();
|
||||
let child = thread::spawn(move|| { start(&tx) });
|
||||
let child = thread::spawn(move || start(&tx));
|
||||
|
||||
let mut c = rx.recv().unwrap();
|
||||
c.send("A".to_string()).unwrap();
|
||||
|
|
|
@ -13,9 +13,7 @@ fn start(tx: &Sender<Sender<isize>>) {
|
|||
|
||||
pub fn main() {
|
||||
let (tx, rx) = channel();
|
||||
let child = thread::spawn(move|| {
|
||||
start(&tx)
|
||||
});
|
||||
let child = thread::spawn(move || start(&tx));
|
||||
let _tx = rx.recv().unwrap();
|
||||
child.join();
|
||||
}
|
||||
|
|
|
@ -5,15 +5,17 @@
|
|||
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn start(_task_number: isize) { println!("Started / Finished task."); }
|
||||
fn start(_task_number: isize) {
|
||||
println!("Started / Finished task.");
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
let i: isize = 0;
|
||||
let mut result = thread::spawn(move|| {
|
||||
start(i)
|
||||
});
|
||||
let mut result = thread::spawn(move || start(i));
|
||||
|
||||
// Sleep long enough for the thread to finish.
|
||||
let mut i = 0_usize;
|
||||
|
|
|
@ -7,12 +7,15 @@ use std::thread;
|
|||
|
||||
fn start(tx: &Sender<isize>, start: isize, number_of_messages: isize) {
|
||||
let mut i: isize = 0;
|
||||
while i< number_of_messages { tx.send(start + i).unwrap(); i += 1; }
|
||||
while i < number_of_messages {
|
||||
tx.send(start + i).unwrap();
|
||||
i += 1;
|
||||
}
|
||||
}
|
||||
|
||||
pub fn main() {
|
||||
println!("Check that we don't deadlock.");
|
||||
let (tx, rx) = channel();
|
||||
let _ = thread::spawn(move|| { start(&tx, 0, 10) }).join();
|
||||
let _ = thread::spawn(move || start(&tx, 0, 10)).join();
|
||||
println!("Joined task");
|
||||
}
|
||||
|
|
|
@ -13,7 +13,10 @@ pub fn main() {
|
|||
while (i > 0) {
|
||||
println!("{}", i);
|
||||
let tx = tx.clone();
|
||||
thread::spawn({let i = i; move|| { child(i, &tx) }});
|
||||
thread::spawn({
|
||||
let i = i;
|
||||
move || child(i, &tx)
|
||||
});
|
||||
i = i - 1;
|
||||
}
|
||||
|
||||
|
|
|
@ -20,9 +20,7 @@ pub fn main() {
|
|||
// the child's point of view the receiver may die. We should
|
||||
// drop messages on the floor in this case, and not crash!
|
||||
let (tx, rx) = channel();
|
||||
let t = thread::spawn(move|| {
|
||||
start(&tx, 10)
|
||||
});
|
||||
let t = thread::spawn(move || start(&tx, 10));
|
||||
rx.recv();
|
||||
t.join();
|
||||
}
|
||||
|
|
|
@ -3,12 +3,16 @@
|
|||
#![allow(unused_parens)]
|
||||
#![allow(non_camel_case_types)]
|
||||
|
||||
use std::sync::mpsc::channel;
|
||||
use std::cmp;
|
||||
use std::sync::mpsc::channel;
|
||||
|
||||
// Tests of ports and channels on various types
|
||||
fn test_rec() {
|
||||
struct R {val0: isize, val1: u8, val2: char}
|
||||
struct R {
|
||||
val0: isize,
|
||||
val1: u8,
|
||||
val2: char,
|
||||
}
|
||||
|
||||
let (tx, rx) = channel();
|
||||
let r0: R = R { val0: 0, val1: 1, val2: '2' };
|
||||
|
@ -45,35 +49,30 @@ fn test_str() {
|
|||
enum t {
|
||||
tag1,
|
||||
tag2(isize),
|
||||
tag3(isize, u8, char)
|
||||
tag3(isize, u8, char),
|
||||
}
|
||||
|
||||
impl cmp::PartialEq for t {
|
||||
fn eq(&self, other: &t) -> bool {
|
||||
match *self {
|
||||
t::tag1 => {
|
||||
match (*other) {
|
||||
t::tag1 => match (*other) {
|
||||
t::tag1 => true,
|
||||
_ => false
|
||||
}
|
||||
}
|
||||
t::tag2(e0a) => {
|
||||
match (*other) {
|
||||
_ => false,
|
||||
},
|
||||
t::tag2(e0a) => match (*other) {
|
||||
t::tag2(e0b) => e0a == e0b,
|
||||
_ => false
|
||||
_ => false,
|
||||
},
|
||||
t::tag3(e0a, e1a, e2a) => match (*other) {
|
||||
t::tag3(e0b, e1b, e2b) => e0a == e0b && e1a == e1b && e2a == e2b,
|
||||
_ => false,
|
||||
},
|
||||
}
|
||||
}
|
||||
t::tag3(e0a, e1a, e2a) => {
|
||||
match (*other) {
|
||||
t::tag3(e0b, e1b, e2b) =>
|
||||
e0a == e0b && e1a == e1b && e2a == e2b,
|
||||
_ => false
|
||||
fn ne(&self, other: &t) -> bool {
|
||||
!(*self).eq(other)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
fn ne(&self, other: &t) -> bool { !(*self).eq(other) }
|
||||
}
|
||||
|
||||
fn test_tag() {
|
||||
let (tx, rx) = channel();
|
||||
|
|
|
@ -9,8 +9,7 @@
|
|||
|
||||
use std::thread;
|
||||
|
||||
fn f() {
|
||||
}
|
||||
fn f() {}
|
||||
|
||||
pub fn main() {
|
||||
thread::spawn(move || f()).join();
|
||||
|
|
|
@ -2,10 +2,13 @@
|
|||
#![allow(unused_must_use)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { println!("===== WITHOUT THREADS ====="); test00(); }
|
||||
pub fn main() {
|
||||
println!("===== WITHOUT THREADS =====");
|
||||
test00();
|
||||
}
|
||||
|
||||
fn test00_start(ch: &Sender<isize>, message: isize, count: isize) {
|
||||
println!("Starting test00_start");
|
||||
|
@ -34,9 +37,7 @@ fn test00() {
|
|||
let tx = tx.clone();
|
||||
results.push(thread::spawn({
|
||||
let i = i;
|
||||
move|| {
|
||||
test00_start(&tx, i, number_of_messages)
|
||||
}
|
||||
move || test00_start(&tx, i, number_of_messages)
|
||||
}));
|
||||
i = i + 1;
|
||||
}
|
||||
|
@ -53,7 +54,9 @@ fn test00() {
|
|||
}
|
||||
|
||||
// Join spawned threads...
|
||||
for r in results { r.join(); }
|
||||
for r in results {
|
||||
r.join();
|
||||
}
|
||||
|
||||
println!("Completed: Final number is: ");
|
||||
println!("{}", sum);
|
||||
|
|
|
@ -3,7 +3,9 @@
|
|||
|
||||
use std::sync::mpsc::channel;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
let mut r: isize = 0;
|
||||
|
|
|
@ -2,7 +2,9 @@
|
|||
|
||||
use std::sync::mpsc::channel;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
let _r: isize = 0;
|
||||
|
@ -10,8 +12,14 @@ fn test00() {
|
|||
let (tx, rx) = channel();
|
||||
let number_of_messages: isize = 1000;
|
||||
let mut i: isize = 0;
|
||||
while i < number_of_messages { tx.send(i + 0).unwrap(); i += 1; }
|
||||
while i < number_of_messages {
|
||||
tx.send(i + 0).unwrap();
|
||||
i += 1;
|
||||
}
|
||||
i = 0;
|
||||
while i < number_of_messages { sum += rx.recv().unwrap(); i += 1; }
|
||||
while i < number_of_messages {
|
||||
sum += rx.recv().unwrap();
|
||||
i += 1;
|
||||
}
|
||||
assert_eq!(sum, number_of_messages * (number_of_messages - 1) / 2);
|
||||
}
|
||||
|
|
|
@ -4,7 +4,9 @@
|
|||
|
||||
use std::sync::mpsc::channel;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
let mut r: isize = 0;
|
||||
|
@ -38,5 +40,4 @@ fn test00() {
|
|||
assert_eq!(sum, 1998000);
|
||||
// assert (sum == 4 * ((number_of_messages *
|
||||
// (number_of_messages - 1)) / 2));
|
||||
|
||||
}
|
||||
|
|
|
@ -6,12 +6,16 @@
|
|||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn test00_start(c: &Sender<isize>, start: isize,
|
||||
number_of_messages: isize) {
|
||||
fn test00_start(c: &Sender<isize>, start: isize, number_of_messages: isize) {
|
||||
let mut i: isize = 0;
|
||||
while i < number_of_messages { c.send(start + i).unwrap(); i += 1; }
|
||||
while i < number_of_messages {
|
||||
c.send(start + i).unwrap();
|
||||
i += 1;
|
||||
}
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
|
|
|
@ -2,14 +2,19 @@
|
|||
#![allow(unused_must_use)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::{channel, Sender};
|
||||
use std::thread;
|
||||
|
||||
pub fn main() { test00(); }
|
||||
pub fn main() {
|
||||
test00();
|
||||
}
|
||||
|
||||
fn test00_start(c: &Sender<isize>, number_of_messages: isize) {
|
||||
let mut i: isize = 0;
|
||||
while i < number_of_messages { c.send(i + 0).unwrap(); i += 1; }
|
||||
while i < number_of_messages {
|
||||
c.send(i + 0).unwrap();
|
||||
i += 1;
|
||||
}
|
||||
}
|
||||
|
||||
fn test00() {
|
||||
|
|
|
@ -9,6 +9,4 @@ pub fn main() {
|
|||
thread::spawn(move || child("Hello".to_string())).join();
|
||||
}
|
||||
|
||||
fn child(_s: String) {
|
||||
|
||||
}
|
||||
fn child(_s: String) {}
|
||||
|
|
|
@ -2,8 +2,8 @@
|
|||
#![allow(unused_must_use)]
|
||||
//@ needs-threads
|
||||
|
||||
use std::thread;
|
||||
use std::sync::mpsc::channel;
|
||||
use std::thread;
|
||||
|
||||
pub fn main() {
|
||||
let (tx, rx) = channel::<usize>();
|
||||
|
|
|
@ -4,20 +4,21 @@
|
|||
|
||||
#![feature(internal_output_capture)]
|
||||
|
||||
use std::io;
|
||||
use std::str;
|
||||
use std::sync::{Arc, Mutex};
|
||||
use std::thread;
|
||||
use std::{io, str, thread};
|
||||
|
||||
fn main() {
|
||||
let data = Arc::new(Mutex::new(Vec::new()));
|
||||
let res = thread::Builder::new().spawn({
|
||||
let res = thread::Builder::new()
|
||||
.spawn({
|
||||
let data = data.clone();
|
||||
move || {
|
||||
io::set_output_capture(Some(data));
|
||||
panic!("Hello, world!")
|
||||
}
|
||||
}).unwrap().join();
|
||||
})
|
||||
.unwrap()
|
||||
.join();
|
||||
assert!(res.is_err());
|
||||
|
||||
let output = data.lock().unwrap();
|
||||
|
|
|
@ -8,8 +8,8 @@ use std::io::prelude::*;
|
|||
use std::net::{TcpListener, TcpStream};
|
||||
use std::process;
|
||||
use std::sync::mpsc::channel;
|
||||
use std::time::Duration;
|
||||
use std::thread::{self, Builder};
|
||||
use std::time::Duration;
|
||||
|
||||
const TARGET_CNT: usize = 200;
|
||||
|
||||
|
@ -43,7 +43,7 @@ fn main() {
|
|||
Ok(mut stream) => {
|
||||
let _ = stream.write(&[1]);
|
||||
let _ = stream.read(&mut [0]);
|
||||
},
|
||||
}
|
||||
Err(..) => {}
|
||||
}
|
||||
tx.send(()).unwrap();
|
||||
|
|
|
@ -7,10 +7,16 @@ use std::thread;
|
|||
pub fn main() {
|
||||
let mut i = 10;
|
||||
while i > 0 {
|
||||
thread::spawn({let i = i; move|| child(i)}).join();
|
||||
thread::spawn({
|
||||
let i = i;
|
||||
move || child(i)
|
||||
})
|
||||
.join();
|
||||
i = i - 1;
|
||||
}
|
||||
println!("main thread exiting");
|
||||
}
|
||||
|
||||
fn child(x: isize) { println!("{}", x); }
|
||||
fn child(x: isize) {
|
||||
println!("{}", x);
|
||||
}
|
||||
|
|
|
@ -8,7 +8,9 @@ struct Foo;
|
|||
|
||||
impl Drop for Foo {
|
||||
fn drop(&mut self) {
|
||||
unsafe { HIT = true; }
|
||||
unsafe {
|
||||
HIT = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -17,6 +19,8 @@ thread_local!(static FOO: Foo = Foo);
|
|||
fn main() {
|
||||
std::thread::spawn(|| {
|
||||
FOO.with(|_| {});
|
||||
}).join().unwrap();
|
||||
})
|
||||
.join()
|
||||
.unwrap();
|
||||
assert!(unsafe { HIT });
|
||||
}
|
||||
|
|
|
@ -1,14 +1,14 @@
|
|||
//@ run-pass
|
||||
#![allow(stable_features)]
|
||||
|
||||
//@ needs-threads
|
||||
|
||||
#![feature(thread_local_try_with)]
|
||||
|
||||
use std::thread;
|
||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||
use std::thread;
|
||||
|
||||
struct Foo { cnt: usize }
|
||||
struct Foo {
|
||||
cnt: usize,
|
||||
}
|
||||
|
||||
thread_local!(static FOO: Foo = Foo::init());
|
||||
|
||||
|
@ -40,5 +40,7 @@ impl Drop for Foo {
|
|||
fn main() {
|
||||
thread::spawn(|| {
|
||||
FOO.with(|_| {});
|
||||
}).join().unwrap();
|
||||
})
|
||||
.join()
|
||||
.unwrap();
|
||||
}
|
||||
|
|
|
@ -1,8 +1,6 @@
|
|||
//@ run-pass
|
||||
#![allow(stable_features)]
|
||||
|
||||
//@ needs-threads
|
||||
|
||||
#![feature(thread_local_try_with)]
|
||||
|
||||
use std::thread;
|
||||
|
@ -16,15 +14,17 @@ thread_local!(static FOO: Foo = Foo {});
|
|||
impl Drop for Foo {
|
||||
fn drop(&mut self) {
|
||||
assert!(FOO.try_with(|_| panic!("`try_with` closure run")).is_err());
|
||||
unsafe { DROP_RUN = true; }
|
||||
unsafe {
|
||||
DROP_RUN = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
thread::spawn(|| {
|
||||
assert_eq!(FOO.try_with(|_| {
|
||||
132
|
||||
}).expect("`try_with` failed"), 132);
|
||||
}).join().unwrap();
|
||||
assert_eq!(FOO.try_with(|_| { 132 }).expect("`try_with` failed"), 132);
|
||||
})
|
||||
.join()
|
||||
.unwrap();
|
||||
assert!(unsafe { DROP_RUN });
|
||||
}
|
||||
|
|
|
@ -21,9 +21,7 @@ impl Drop for complainer {
|
|||
|
||||
fn complainer(tx: Sender<bool>) -> complainer {
|
||||
println!("Hello!");
|
||||
complainer {
|
||||
tx: tx
|
||||
}
|
||||
complainer { tx: tx }
|
||||
}
|
||||
|
||||
fn f(tx: Sender<bool>) {
|
||||
|
|
|
@ -17,5 +17,9 @@ pub fn main() {
|
|||
}
|
||||
|
||||
fn child() {
|
||||
println!("4"); thread::yield_now(); println!("5"); thread::yield_now(); println!("6");
|
||||
println!("4");
|
||||
thread::yield_now();
|
||||
println!("5");
|
||||
thread::yield_now();
|
||||
println!("6");
|
||||
}
|
||||
|
|
|
@ -13,4 +13,6 @@ pub fn main() {
|
|||
result.join();
|
||||
}
|
||||
|
||||
fn child() { println!("2"); }
|
||||
fn child() {
|
||||
println!("2");
|
||||
}
|
||||
|
|
|
@ -4,5 +4,9 @@ use std::thread;
|
|||
|
||||
pub fn main() {
|
||||
let mut i: isize = 0;
|
||||
while i < 100 { i = i + 1; println!("{}", i); thread::yield_now(); }
|
||||
while i < 100 {
|
||||
i = i + 1;
|
||||
println!("{}", i);
|
||||
thread::yield_now();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue