// 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 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. //! Implementations of I/O traits for the IoResult type //! //! I/O constructors return option types to allow errors to be handled. //! These implementations allow e.g. `IoResult` to be used //! as a `Reader` without unwrapping the result first. use clone::Clone; use result::Result::{Ok, Err}; use super::{Reader, Writer, Listener, Acceptor, Seek, SeekStyle, IoResult}; impl Writer for IoResult { fn write(&mut self, buf: &[u8]) -> IoResult<()> { match *self { Ok(ref mut writer) => writer.write(buf), Err(ref e) => Err((*e).clone()) } } fn flush(&mut self) -> IoResult<()> { match *self { Ok(ref mut writer) => writer.flush(), Err(ref e) => Err(e.clone()), } } } impl Reader for IoResult { fn read(&mut self, buf: &mut [u8]) -> IoResult { match *self { Ok(ref mut reader) => reader.read(buf), Err(ref e) => Err(e.clone()), } } } impl Seek for IoResult { fn tell(&self) -> IoResult { match *self { Ok(ref seeker) => seeker.tell(), Err(ref e) => Err(e.clone()), } } fn seek(&mut self, pos: i64, style: SeekStyle) -> IoResult<()> { match *self { Ok(ref mut seeker) => seeker.seek(pos, style), Err(ref e) => Err(e.clone()) } } } impl, L: Listener> Listener for IoResult { fn listen(self) -> IoResult { match self { Ok(listener) => listener.listen(), Err(e) => Err(e), } } } impl> Acceptor for IoResult { fn accept(&mut self) -> IoResult { match *self { Ok(ref mut acceptor) => acceptor.accept(), Err(ref e) => Err(e.clone()), } } } #[cfg(test)] mod test { use prelude::v1::*; use super::super::mem::*; use io; #[test] fn test_option_writer() { let mut writer: io::IoResult> = Ok(Vec::new()); writer.write(&[0, 1, 2]).unwrap(); writer.flush().unwrap(); assert_eq!(writer.unwrap(), vec!(0, 1, 2)); } #[test] fn test_option_writer_error() { let mut writer: io::IoResult> = Err(io::standard_error(io::EndOfFile)); match writer.write(&[0, 0, 0]) { Ok(..) => panic!(), Err(e) => assert_eq!(e.kind, io::EndOfFile), } match writer.flush() { Ok(..) => panic!(), Err(e) => assert_eq!(e.kind, io::EndOfFile), } } #[test] fn test_option_reader() { let mut reader: io::IoResult = Ok(MemReader::new(vec!(0, 1, 2, 3))); let mut buf = [0, 0]; reader.read(&mut buf).unwrap(); let b: &[_] = &[0, 1]; assert_eq!(buf.as_slice(), b); } #[test] fn test_option_reader_error() { let mut reader: io::IoResult = Err(io::standard_error(io::EndOfFile)); let mut buf = []; match reader.read(&mut buf) { Ok(..) => panic!(), Err(e) => assert_eq!(e.kind, io::EndOfFile), } } }