diff options
author | farodin91 <farodin91@googlemail.com> | 2015-07-28 08:57:08 +0200 |
---|---|---|
committer | farodin91 <farodin91@googlemail.com> | 2015-07-29 09:54:08 +0200 |
commit | 20f99e92d81601f323660df52f31544adf38334a (patch) | |
tree | 2476c8dc17f650d2751c160c3ae0e3c1c94570d9 /components/script/dom/filereader.rs | |
parent | fff104bb41dea0ba64fdca312de7b4c0d76277c8 (diff) | |
download | servo-20f99e92d81601f323660df52f31544adf38334a.tar.gz servo-20f99e92d81601f323660df52f31544adf38334a.zip |
Adding for support Blob.{close,isClose} #6723
Diffstat (limited to 'components/script/dom/filereader.rs')
-rw-r--r-- | components/script/dom/filereader.rs | 28 |
1 files changed, 23 insertions, 5 deletions
diff --git a/components/script/dom/filereader.rs b/components/script/dom/filereader.rs index 09f6c83a99e..256b1c8b6bc 100644 --- a/components/script/dom/filereader.rs +++ b/components/script/dom/filereader.rs @@ -2,6 +2,7 @@ * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +use dom::bindings::codegen::Bindings::BlobBinding::BlobMethods; use dom::bindings::codegen::Bindings::FileReaderBinding::{self, FileReaderConstants, FileReaderMethods}; use dom::bindings::codegen::InheritTypes::{EventCast, EventTargetCast}; use dom::bindings::codegen::Bindings::EventHandlerBinding::EventHandlerNonNull; @@ -268,7 +269,6 @@ impl FileReader { Ok(Some(output)) } - } impl<'a> FileReaderMethods for &'a FileReader { @@ -287,13 +287,22 @@ impl<'a> FileReaderMethods for &'a FileReader { if self.ready_state.get() == FileReaderReadyState::Loading { return Err(InvalidState); } - //TODO STEP 2 if isClosed implemented in Blob + + // Step 2 + if blob.IsClosed() { + let global = self.global.root(); + let exception = DOMException::new(global.r(), DOMErrorName::InvalidStateError); + self.error.set(Some(JS::from_rooted(&exception))); + + self.dispatch_progress_event("error".to_owned(), 0, None); + return Ok(()); + } // Step 3 self.change_ready_state(FileReaderReadyState::Loading); let bytes = blob.read_out_buffer(); - let type_ = blob.read_out_type(); + let type_ = blob.Type(); let load_data = ReadData::new(bytes, type_, None, FileReaderFunction::ReadAsDataUrl); @@ -307,13 +316,22 @@ impl<'a> FileReaderMethods for &'a FileReader { if self.ready_state.get() == FileReaderReadyState::Loading { return Err(InvalidState); } - //TODO STEP 2 if isClosed implemented in Blob + + // Step 2 + if blob.IsClosed() { + let global = self.global.root(); + let exception = DOMException::new(global.r(), DOMErrorName::InvalidStateError); + self.error.set(Some(JS::from_rooted(&exception))); + + self.dispatch_progress_event("error".to_owned(), 0, None); + return Ok(()); + } // Step 3 self.change_ready_state(FileReaderReadyState::Loading); let bytes = blob.read_out_buffer(); - let type_ = blob.read_out_type(); + let type_ = blob.Type(); let load_data = ReadData::new(bytes, type_, label, FileReaderFunction::ReadAsText); |