diff options
author | St.Spyder <stspyder@users.noreply.github.com> | 2016-03-12 20:35:50 +0530 |
---|---|---|
committer | St.Spyder <stspyder@users.noreply.github.com> | 2016-03-17 23:47:12 +0530 |
commit | 34726d8b9e267dcd8c35c0abb75aa6d319aa8372 (patch) | |
tree | 4c04b0d46ff7d004fb9709281fe04ea4a24be69c /components/script/dom/blob.rs | |
parent | 7a9dc577617b442ff0fe07eaa683207234c519ee (diff) | |
download | servo-34726d8b9e267dcd8c35c0abb75aa6d319aa8372.tar.gz servo-34726d8b9e267dcd8c35c0abb75aa6d319aa8372.zip |
Implementation of Blob Constructor with test changes
Diffstat (limited to 'components/script/dom/blob.rs')
-rw-r--r-- | components/script/dom/blob.rs | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/components/script/dom/blob.rs b/components/script/dom/blob.rs index dc24cbb01fc..9c23b8f6da0 100644 --- a/components/script/dom/blob.rs +++ b/components/script/dom/blob.rs @@ -4,11 +4,14 @@ use dom::bindings::codegen::Bindings::BlobBinding; use dom::bindings::codegen::Bindings::BlobBinding::BlobMethods; +use dom::bindings::codegen::UnionTypes::BlobOrString; use dom::bindings::error::Fallible; use dom::bindings::global::GlobalRef; use dom::bindings::js::Root; use dom::bindings::reflector::{Reflectable, Reflector, reflect_dom_object}; use dom::bindings::trace::JSTraceable; +use encoding::all::UTF_8; +use encoding::types::{EncoderTrap, Encoding}; use num::ToPrimitive; use std::ascii::AsciiExt; use std::borrow::ToOwned; @@ -120,16 +123,29 @@ impl Blob { // https://w3c.github.io/FileAPI/#constructorBlob pub fn Constructor_(global: GlobalRef, - blobParts: DOMString, + blobParts: Vec<BlobOrString>, blobPropertyBag: &BlobBinding::BlobPropertyBag) -> Fallible<Root<Blob>> { - // TODO: accept other blobParts types - ArrayBuffer or ArrayBufferView or Blob + + // TODO: accept other blobParts types - ArrayBuffer or ArrayBufferView + let bytes: Vec<u8> = blobParts.iter() + .flat_map(|bPart| { + match bPart { + &BlobOrString::String(ref s) => { + UTF_8.encode(s, EncoderTrap::Replace).unwrap() + }, + &BlobOrString::Blob(ref b) => { + b.get_data().get_bytes().to_vec() + }, + } + }) + .collect(); let typeString = if is_ascii_printable(&blobPropertyBag.type_) { &*blobPropertyBag.type_ } else { "" }; - Ok(Blob::new(global, blobParts.into(), &typeString.to_ascii_lowercase())) + Ok(Blob::new(global, bytes, &typeString.to_ascii_lowercase())) } pub fn get_data(&self) -> &DataSlice { |