auto merge of #9693 : sfackler/rust/newtype-removal, r=alexcrichton

UnboundedPipeStream is still a newtype since process::set_stdio needs to
look into its internals.

Closes #9667
This commit is contained in:
bors 2013-10-02 20:41:29 -07:00
commit b637798a5a
6 changed files with 49 additions and 31 deletions

View File

@ -17,8 +17,9 @@ use libc::{c_int, FILE};
#[allow(non_camel_case_types)] #[allow(non_camel_case_types)]
pub type fd_t = c_int; pub type fd_t = c_int;
// Make this a newtype so we can't do I/O on arbitrary integers pub struct FileDesc {
pub struct FileDesc(fd_t); priv fd: fd_t
}
impl FileDesc { impl FileDesc {
/// Create a `FileDesc` from an open C file descriptor. /// Create a `FileDesc` from an open C file descriptor.
@ -46,7 +47,9 @@ impl Seek for FileDesc {
fn seek(&mut self, _pos: i64, _style: SeekStyle) { fail2!() } fn seek(&mut self, _pos: i64, _style: SeekStyle) { fail2!() }
} }
pub struct CFile(*FILE); pub struct CFile {
priv file: *FILE
}
impl CFile { impl CFile {
/// Create a `CFile` from an open `FILE` pointer. /// Create a `CFile` from an open `FILE` pointer.

View File

@ -20,11 +20,13 @@ use rt::rtio::{IoFactory, IoFactoryObject,
RtioTcpStream, RtioTcpStreamObject}; RtioTcpStream, RtioTcpStreamObject};
use rt::local::Local; use rt::local::Local;
pub struct TcpStream(~RtioTcpStreamObject); pub struct TcpStream {
priv obj: ~RtioTcpStreamObject
}
impl TcpStream { impl TcpStream {
fn new(s: ~RtioTcpStreamObject) -> TcpStream { fn new(s: ~RtioTcpStreamObject) -> TcpStream {
TcpStream(s) TcpStream { obj: s }
} }
pub fn connect(addr: SocketAddr) -> Option<TcpStream> { pub fn connect(addr: SocketAddr) -> Option<TcpStream> {
@ -46,7 +48,7 @@ impl TcpStream {
} }
pub fn peer_name(&mut self) -> Option<SocketAddr> { pub fn peer_name(&mut self) -> Option<SocketAddr> {
match (**self).peer_name() { match self.obj.peer_name() {
Ok(pn) => Some(pn), Ok(pn) => Some(pn),
Err(ioerr) => { Err(ioerr) => {
rtdebug!("failed to get peer name: {:?}", ioerr); rtdebug!("failed to get peer name: {:?}", ioerr);
@ -57,7 +59,7 @@ impl TcpStream {
} }
pub fn socket_name(&mut self) -> Option<SocketAddr> { pub fn socket_name(&mut self) -> Option<SocketAddr> {
match (**self).socket_name() { match self.obj.socket_name() {
Ok(sn) => Some(sn), Ok(sn) => Some(sn),
Err(ioerr) => { Err(ioerr) => {
rtdebug!("failed to get socket name: {:?}", ioerr); rtdebug!("failed to get socket name: {:?}", ioerr);
@ -70,7 +72,7 @@ impl TcpStream {
impl Reader for TcpStream { impl Reader for TcpStream {
fn read(&mut self, buf: &mut [u8]) -> Option<uint> { fn read(&mut self, buf: &mut [u8]) -> Option<uint> {
match (**self).read(buf) { match self.obj.read(buf) {
Ok(read) => Some(read), Ok(read) => Some(read),
Err(ioerr) => { Err(ioerr) => {
// EOF is indicated by returning None // EOF is indicated by returning None
@ -87,7 +89,7 @@ impl Reader for TcpStream {
impl Writer for TcpStream { impl Writer for TcpStream {
fn write(&mut self, buf: &[u8]) { fn write(&mut self, buf: &[u8]) {
match (**self).write(buf) { match self.obj.write(buf) {
Ok(_) => (), Ok(_) => (),
Err(ioerr) => io_error::cond.raise(ioerr), Err(ioerr) => io_error::cond.raise(ioerr),
} }
@ -96,7 +98,9 @@ impl Writer for TcpStream {
fn flush(&mut self) { /* no-op */ } fn flush(&mut self) { /* no-op */ }
} }
pub struct TcpListener(~RtioTcpListenerObject); pub struct TcpListener {
priv obj: ~RtioTcpListenerObject
}
impl TcpListener { impl TcpListener {
pub fn bind(addr: SocketAddr) -> Option<TcpListener> { pub fn bind(addr: SocketAddr) -> Option<TcpListener> {
@ -105,7 +109,7 @@ impl TcpListener {
(*io).tcp_bind(addr) (*io).tcp_bind(addr)
}; };
match listener { match listener {
Ok(l) => Some(TcpListener(l)), Ok(l) => Some(TcpListener { obj: l }),
Err(ioerr) => { Err(ioerr) => {
io_error::cond.raise(ioerr); io_error::cond.raise(ioerr);
return None; return None;
@ -114,7 +118,7 @@ impl TcpListener {
} }
pub fn socket_name(&mut self) -> Option<SocketAddr> { pub fn socket_name(&mut self) -> Option<SocketAddr> {
match (**self).socket_name() { match self.obj.socket_name() {
Ok(sn) => Some(sn), Ok(sn) => Some(sn),
Err(ioerr) => { Err(ioerr) => {
rtdebug!("failed to get socket name: {:?}", ioerr); rtdebug!("failed to get socket name: {:?}", ioerr);
@ -127,8 +131,8 @@ impl TcpListener {
impl Listener<TcpStream, TcpAcceptor> for TcpListener { impl Listener<TcpStream, TcpAcceptor> for TcpListener {
fn listen(self) -> Option<TcpAcceptor> { fn listen(self) -> Option<TcpAcceptor> {
match (**self).listen() { match self.obj.listen() {
Ok(acceptor) => Some(TcpAcceptor(acceptor)), Ok(acceptor) => Some(TcpAcceptor { obj: acceptor }),
Err(ioerr) => { Err(ioerr) => {
io_error::cond.raise(ioerr); io_error::cond.raise(ioerr);
None None
@ -137,11 +141,13 @@ impl Listener<TcpStream, TcpAcceptor> for TcpListener {
} }
} }
pub struct TcpAcceptor(~RtioTcpAcceptorObject); pub struct TcpAcceptor {
priv obj: ~RtioTcpAcceptorObject
}
impl Acceptor<TcpStream> for TcpAcceptor { impl Acceptor<TcpStream> for TcpAcceptor {
fn accept(&mut self) -> Option<TcpStream> { fn accept(&mut self) -> Option<TcpStream> {
match (**self).accept() { match self.obj.accept() {
Ok(s) => Some(TcpStream::new(s)), Ok(s) => Some(TcpStream::new(s)),
Err(ioerr) => { Err(ioerr) => {
io_error::cond.raise(ioerr); io_error::cond.raise(ioerr);

View File

@ -16,7 +16,9 @@ use rt::io::{io_error, read_error, EndOfFile};
use rt::rtio::{RtioSocket, RtioUdpSocketObject, RtioUdpSocket, IoFactory, IoFactoryObject}; use rt::rtio::{RtioSocket, RtioUdpSocketObject, RtioUdpSocket, IoFactory, IoFactoryObject};
use rt::local::Local; use rt::local::Local;
pub struct UdpSocket(~RtioUdpSocketObject); pub struct UdpSocket {
priv obj: ~RtioUdpSocketObject
}
impl UdpSocket { impl UdpSocket {
pub fn bind(addr: SocketAddr) -> Option<UdpSocket> { pub fn bind(addr: SocketAddr) -> Option<UdpSocket> {
@ -25,7 +27,7 @@ impl UdpSocket {
(*factory).udp_bind(addr) (*factory).udp_bind(addr)
}; };
match socket { match socket {
Ok(s) => Some(UdpSocket(s)), Ok(s) => Some(UdpSocket { obj: s }),
Err(ioerr) => { Err(ioerr) => {
io_error::cond.raise(ioerr); io_error::cond.raise(ioerr);
None None
@ -34,7 +36,7 @@ impl UdpSocket {
} }
pub fn recvfrom(&mut self, buf: &mut [u8]) -> Option<(uint, SocketAddr)> { pub fn recvfrom(&mut self, buf: &mut [u8]) -> Option<(uint, SocketAddr)> {
match (**self).recvfrom(buf) { match self.obj.recvfrom(buf) {
Ok((nread, src)) => Some((nread, src)), Ok((nread, src)) => Some((nread, src)),
Err(ioerr) => { Err(ioerr) => {
// EOF is indicated by returning None // EOF is indicated by returning None
@ -47,7 +49,7 @@ impl UdpSocket {
} }
pub fn sendto(&mut self, buf: &[u8], dst: SocketAddr) { pub fn sendto(&mut self, buf: &[u8], dst: SocketAddr) {
match (**self).sendto(buf, dst) { match self.obj.sendto(buf, dst) {
Ok(_) => (), Ok(_) => (),
Err(ioerr) => io_error::cond.raise(ioerr), Err(ioerr) => io_error::cond.raise(ioerr),
} }
@ -58,7 +60,7 @@ impl UdpSocket {
} }
pub fn socket_name(&mut self) -> Option<SocketAddr> { pub fn socket_name(&mut self) -> Option<SocketAddr> {
match (***self).socket_name() { match self.obj.socket_name() {
Ok(sn) => Some(sn), Ok(sn) => Some(sn),
Err(ioerr) => { Err(ioerr) => {
rtdebug!("failed to get socket name: {:?}", ioerr); rtdebug!("failed to get socket name: {:?}", ioerr);
@ -70,8 +72,8 @@ impl UdpSocket {
} }
pub struct UdpStream { pub struct UdpStream {
socket: UdpSocket, priv socket: UdpSocket,
connectedTo: SocketAddr priv connectedTo: SocketAddr
} }
impl UdpStream { impl UdpStream {

View File

@ -20,7 +20,12 @@ use rt::local::Local;
use rt::rtio::{RtioPipe, RtioPipeObject, IoFactoryObject, IoFactory}; use rt::rtio::{RtioPipe, RtioPipeObject, IoFactoryObject, IoFactory};
use rt::rtio::RtioUnboundPipeObject; use rt::rtio::RtioUnboundPipeObject;
pub struct PipeStream(RtioPipeObject); pub struct PipeStream {
priv obj: RtioPipeObject
}
// This should not be a newtype, but rt::uv::process::set_stdio needs to reach
// into the internals of this :(
pub struct UnboundPipeStream(~RtioUnboundPipeObject); pub struct UnboundPipeStream(~RtioUnboundPipeObject);
impl PipeStream { impl PipeStream {
@ -41,13 +46,13 @@ impl PipeStream {
} }
pub fn bind(inner: RtioPipeObject) -> PipeStream { pub fn bind(inner: RtioPipeObject) -> PipeStream {
PipeStream(inner) PipeStream { obj: inner }
} }
} }
impl Reader for PipeStream { impl Reader for PipeStream {
fn read(&mut self, buf: &mut [u8]) -> Option<uint> { fn read(&mut self, buf: &mut [u8]) -> Option<uint> {
match (**self).read(buf) { match self.obj.read(buf) {
Ok(read) => Some(read), Ok(read) => Some(read),
Err(ioerr) => { Err(ioerr) => {
// EOF is indicated by returning None // EOF is indicated by returning None
@ -64,7 +69,7 @@ impl Reader for PipeStream {
impl Writer for PipeStream { impl Writer for PipeStream {
fn write(&mut self, buf: &[u8]) { fn write(&mut self, buf: &[u8]) {
match (**self).write(buf) { match self.obj.write(buf) {
Ok(_) => (), Ok(_) => (),
Err(ioerr) => { Err(ioerr) => {
io_error::cond.raise(ioerr); io_error::cond.raise(ioerr);

View File

@ -15,7 +15,9 @@ use rt::rtio::{IoFactory, IoFactoryObject,
RtioTimer, RtioTimerObject}; RtioTimer, RtioTimerObject};
use rt::local::Local; use rt::local::Local;
pub struct Timer(~RtioTimerObject); pub struct Timer {
priv obj: ~RtioTimerObject
}
/// Sleep the current task for `msecs` milliseconds. /// Sleep the current task for `msecs` milliseconds.
pub fn sleep(msecs: u64) { pub fn sleep(msecs: u64) {
@ -34,7 +36,7 @@ impl Timer {
(*io).timer_init() (*io).timer_init()
}; };
match timer { match timer {
Ok(t) => Some(Timer(t)), Ok(t) => Some(Timer { obj: t }),
Err(ioerr) => { Err(ioerr) => {
rtdebug!("Timer::init: failed to init: {:?}", ioerr); rtdebug!("Timer::init: failed to init: {:?}", ioerr);
io_error::cond.raise(ioerr); io_error::cond.raise(ioerr);
@ -44,7 +46,7 @@ impl Timer {
} }
pub fn sleep(&mut self, msecs: u64) { pub fn sleep(&mut self, msecs: u64) {
(**self).sleep(msecs); self.obj.sleep(msecs);
} }
} }

View File

@ -84,7 +84,7 @@ fn read_all(input: &mut Reader) -> ~str {
let mut buf = [0, ..1024]; let mut buf = [0, ..1024];
loop { loop {
match input.read(buf) { match input.read(buf) {
None | Some(0) => { break } None => { break }
Some(n) => { ret = ret + str::from_utf8(buf.slice_to(n)); } Some(n) => { ret = ret + str::from_utf8(buf.slice_to(n)); }
} }
} }