aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/net/file_loader.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/net/file_loader.rs')
-rw-r--r--src/components/net/file_loader.rs16
1 files changed, 5 insertions, 11 deletions
diff --git a/src/components/net/file_loader.rs b/src/components/net/file_loader.rs
index 4a63ac5dcf0..336df6e0193 100644
--- a/src/components/net/file_loader.rs
+++ b/src/components/net/file_loader.rs
@@ -3,7 +3,6 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
use resource_task::{ProgressMsg, Metadata, Payload, Done, LoaderTask, start_sending};
-use servo_util::io::result;
use std::io;
use std::io::File;
@@ -11,14 +10,11 @@ use servo_util::task::spawn_named;
static READ_SIZE: uint = 1024;
-fn read_all(reader: &mut io::Stream, progress_chan: &SharedChan<ProgressMsg>)
+fn read_all(reader: &mut io::Stream, progress_chan: &Chan<ProgressMsg>)
-> Result<(), ()> {
loop {
- match (result(|| {
- let data = reader.read_bytes(READ_SIZE);
- progress_chan.send(Payload(data));
- })) {
- Ok(()) => (),
+ match (reader.read_bytes(READ_SIZE)) {
+ Ok(data) => progress_chan.send(Payload(data)),
Err(e) => match e.kind {
io::EndOfFile => return Ok(()),
_ => return Err(()),
@@ -32,14 +28,12 @@ pub fn factory() -> LoaderTask {
assert!("file" == url.scheme);
let progress_chan = start_sending(start_chan, Metadata::default(url.clone()));
spawn_named("file_loader", proc() {
- // ignore_io_error causes us to get None instead of a task failure.
- let _guard = io::ignore_io_error();
match File::open_mode(&Path::new(url.path), io::Open, io::Read) {
- Some(ref mut reader) => {
+ Ok(ref mut reader) => {
let res = read_all(reader as &mut io::Stream, &progress_chan);
progress_chan.send(Done(res));
}
- None => {
+ Err(_) => {
progress_chan.send(Done(Err(())));
}
};