2011-07-29 19:53:02 -05:00
|
|
|
import sys;
|
2011-08-01 16:57:17 -05:00
|
|
|
import ptr;
|
|
|
|
import unsafe;
|
2011-07-29 19:53:02 -05:00
|
|
|
|
|
|
|
export _chan;
|
|
|
|
export _port;
|
|
|
|
|
|
|
|
export mk_port;
|
|
|
|
|
|
|
|
native "rust" mod rustrt {
|
2011-08-01 16:57:17 -05:00
|
|
|
type void;
|
2011-07-29 19:53:02 -05:00
|
|
|
type rust_chan;
|
|
|
|
type rust_port;
|
|
|
|
|
|
|
|
fn new_chan(po : *rust_port) -> *rust_chan;
|
|
|
|
fn del_chan(ch : *rust_chan);
|
|
|
|
fn drop_chan(ch : *rust_chan);
|
2011-08-01 16:57:17 -05:00
|
|
|
fn chan_send(ch: *rust_chan, v : *void);
|
2011-07-29 19:53:02 -05:00
|
|
|
|
|
|
|
fn new_port(unit_sz : uint) -> *rust_port;
|
|
|
|
fn del_port(po : *rust_port);
|
|
|
|
fn drop_port(po : *rust_port);
|
2011-08-02 14:29:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
native "rust-intrinsic" mod rusti {
|
|
|
|
fn recv[T](port : *rustrt::rust_port) -> T;
|
2011-07-29 19:53:02 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
resource chan_ptr(ch: *rustrt::rust_chan) {
|
|
|
|
rustrt::drop_chan(ch);
|
|
|
|
rustrt::drop_chan(ch); // FIXME: We shouldn't have to do this
|
|
|
|
// twice.
|
|
|
|
}
|
|
|
|
|
|
|
|
resource port_ptr(po: *rustrt::rust_port) {
|
|
|
|
rustrt::drop_port(po);
|
|
|
|
rustrt::del_port(po);
|
|
|
|
}
|
|
|
|
|
2011-07-29 20:52:16 -05:00
|
|
|
obj _chan[T](raw_chan : @chan_ptr) {
|
|
|
|
fn send(v : &T) {
|
2011-08-01 16:57:17 -05:00
|
|
|
rustrt::chan_send(**raw_chan,
|
|
|
|
unsafe::reinterpret_cast(ptr::addr_of(v)));
|
2011-07-29 20:52:16 -05:00
|
|
|
}
|
2011-07-29 19:53:02 -05:00
|
|
|
}
|
|
|
|
|
2011-07-29 20:52:16 -05:00
|
|
|
obj _port[T](raw_port : @port_ptr) {
|
|
|
|
fn mk_chan() -> _chan[T] {
|
|
|
|
_chan(@chan_ptr(rustrt::new_chan(**raw_port)))
|
2011-07-29 19:53:02 -05:00
|
|
|
}
|
2011-07-29 20:52:16 -05:00
|
|
|
|
2011-08-02 14:29:10 -05:00
|
|
|
fn recv() -> T {
|
|
|
|
ret rusti::recv(**raw_port)
|
2011-07-29 20:52:16 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn mk_port[T]() -> _port[T] {
|
|
|
|
_port(@port_ptr(rustrt::new_port(sys::size_of[T]())))
|
2011-07-29 19:53:02 -05:00
|
|
|
}
|