Skip to content

Commit d2a1378

Browse files
committed
core::rt: Add MessageQueue type
This is the queue used to send messages to Schedulers
1 parent ee06ed2 commit d2a1378

File tree

2 files changed

+48
-1
lines changed

2 files changed

+48
-1
lines changed

src/libcore/rt/message_queue.rs

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
use container::Container;
12+
use kinds::Owned;
13+
use vec::OwnedVector;
14+
use cell::Cell;
15+
use option::*;
16+
use unstable::sync::{Exclusive, exclusive};
17+
18+
pub struct MessageQueue<T> {
19+
// XXX: Another mystery bug fixed by boxing this lock
20+
priv queue: ~Exclusive<~[T]>
21+
}
22+
23+
impl<T: Owned> MessageQueue<T> {
24+
pub fn new() -> MessageQueue<T> {
25+
MessageQueue {
26+
queue: ~exclusive(~[])
27+
}
28+
}
29+
30+
pub fn push(&mut self, value: T) {
31+
let value = Cell(value);
32+
self.queue.with(|q| q.push(value.take()) );
33+
}
34+
35+
pub fn pop(&mut self) -> Option<T> {
36+
do self.queue.with |q| {
37+
if !q.is_empty() {
38+
Some(q.shift())
39+
} else {
40+
None
41+
}
42+
}
43+
}
44+
}

src/libcore/rt/mod.rs

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -91,9 +91,12 @@ pub mod uv;
9191
/// Bindings to pthread/windows thread-local storage.
9292
pub mod thread_local_storage;
9393

94-
/// A parallel work-stealing dequeue.
94+
/// A parallel work-stealing deque.
9595
mod work_queue;
9696

97+
/// A parallel queue.
98+
mod message_queue;
99+
97100
/// Stack segments and caching.
98101
mod stack;
99102

0 commit comments

Comments
 (0)