Skip to content

Commit

Permalink
std: Rebase better errors on master
Browse files Browse the repository at this point in the history
  • Loading branch information
alexcrichton committed Jun 13, 2014
1 parent 298412a commit 03ec8e5
Showing 1 changed file with 11 additions and 7 deletions.
18 changes: 11 additions & 7 deletions src/libstd/io/fs.rs
Original file line number Diff line number Diff line change
Expand Up @@ -52,13 +52,15 @@ fs::unlink(&path);
use c_str::ToCStr;
use clone::Clone;
use collections::Collection;
use io::standard_error;
use io::{FilePermission, Write, UnstableFileStat, Open, FileAccess, FileMode};
use io::{IoResult, IoError, FileStat, SeekStyle, Seek, Writer, Reader};
use io::{Read, Truncate, SeekCur, SeekSet, ReadWrite, SeekEnd, Append};
use io;
use io::UpdateIoError;
use io;
use iter::Iterator;
use kinds::Send;
use libc;
use option::{Some, None, Option};
use owned::Box;
use path::{Path, GenericPath};
Expand All @@ -67,6 +69,7 @@ use result::{Err, Ok};
use rt::rtio::LocalIo;
use rt::rtio;
use slice::ImmutableVector;
use string::String;
use vec::Vec;

/// Unconstrained file access type that exposes read and write operations
Expand Down Expand Up @@ -128,18 +131,18 @@ impl File {
pub fn open_mode(path: &Path,
mode: FileMode,
access: FileAccess) -> IoResult<File> {
let mode = match mode {
let rtio_mode = match mode {
Open => rtio::Open,
Append => rtio::Append,
Truncate => rtio::Truncate,
};
let access = match access {
let rtio_access = match access {
Read => rtio::Read,
Write => rtio::Write,
ReadWrite => rtio::ReadWrite,
};
let err = LocalIo::maybe_raise(|io| {
io.fs_open(&path.to_c_str(), mode, access).map(|fd| {
io.fs_open(&path.to_c_str(), rtio_mode, rtio_access).map(|fd| {
File {
path: path.clone(),
fd: fd,
Expand Down Expand Up @@ -775,7 +778,8 @@ impl Reader for File {
e, file.path.display()))
}

let result: IoResult<int> = update_err(self.fd.read(buf), self);
let result = update_err(self.fd.read(buf)
.map_err(IoError::from_rtio_error), self);

match result {
Ok(read) => {
Expand All @@ -785,14 +789,14 @@ impl Reader for File {
_ => Ok(read as uint)
}
},
Err(e) => Err(IoError::from_rtio_error(e)),
Err(e) => Err(e)
}
}
}

impl Writer for File {
fn write(&mut self, buf: &[u8]) -> IoResult<()> {
let err = self.fd.write(buf).map_err(IoError::from_rtio_error)
let err = self.fd.write(buf).map_err(IoError::from_rtio_error);
err.update_err("couldn't write to file",
|e| format!("{}; path={}", e, self.path.display()))
}
Expand Down

0 comments on commit 03ec8e5

Please sign in to comment.