servo: Merge #10873 - Fixes related to File API (from izgzhen:blob); r=Manishearth

Fixing problems I met when trying to resolve https://github.com/servo/servo/issues/10851, but most of changes here are simple fixes.

Source-Repo: https://github.com/servo/servo
Source-Revision: 14926529c9f38a014140d75ca06cc46d1a2b72ba
This commit is contained in:
Zhen Zhang 2016-05-01 22:13:20 -07:00
Родитель b7d39d1471
Коммит 58515a4e9d
3 изменённых файлов: 15 добавлений и 6 удалений

Просмотреть файл

@ -66,6 +66,10 @@ impl DataSlice {
&self.bytes[self.bytes_start..self.bytes_end]
}
pub fn get_all_bytes(&self) -> Arc<Vec<u8>> {
self.bytes.clone()
}
pub fn size(&self) -> u64 {
(self.bytes_end as u64) - (self.bytes_start as u64)
}

Просмотреть файл

@ -18,14 +18,15 @@ pub struct File {
}
impl File {
fn new_inherited(_file_bits: &Blob, name: DOMString) -> File {
fn new_inherited(file_bits: &Blob, name: DOMString) -> File {
// TODO: FilePropertyBag
let mut bytes = Vec::new();
bytes.extend_from_slice(file_bits.get_data().get_all_bytes().as_slice());
File {
//TODO: get type from the underlying filesystem instead of "".to_string()
blob: Blob::new_inherited(Arc::new(Vec::new()), None, None, ""),
blob: Blob::new_inherited(Arc::new(bytes), None, None, ""),
name: name,
}
// XXXManishearth Once Blob is able to store data
// the relevant subfields of file_bits should be copied over
}
pub fn new(global: GlobalRef, file_bits: &Blob, name: DOMString) -> Root<File> {

Просмотреть файл

@ -40,7 +40,11 @@ impl FileListMethods for FileList {
// https://w3c.github.io/FileAPI/#dfn-item
fn Item(&self, index: u32) -> Option<Root<File>> {
Some(Root::from_ref(&*(self.list[index as usize])))
if (index as usize) < self.list.len() {
Some(Root::from_ref(&*(self.list[index as usize])))
} else {
None
}
}
// check-tidy: no specs after this line