Skip to content
This repository has been archived by the owner on Apr 10, 2024. It is now read-only.

Commit

Permalink
Bug 757284: Restore Blob.mozSlice. r=sicking a=akeybl
Browse files Browse the repository at this point in the history
  • Loading branch information
khuey committed Jun 4, 2012
1 parent 73587e8 commit 2eb4e98
Show file tree
Hide file tree
Showing 5 changed files with 27 additions and 0 deletions.
2 changes: 2 additions & 0 deletions content/base/public/nsDOMFile.h
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ class nsIBlobBuilder;
nsresult NS_NewBlobBuilder(nsISupports* *aSupports);

class nsDOMFileBase : public nsIDOMFile,
public nsIDOMBlob_GECKO_13,
public nsIXHRSendable,
public nsIMutable
{
Expand Down Expand Up @@ -116,6 +117,7 @@ class nsDOMFileBase : public nsIDOMFile,
NS_DECL_ISUPPORTS
NS_DECL_NSIDOMBLOB
NS_DECL_NSIDOMFILE
NS_DECL_NSIDOMBLOB_GECKO_13
NS_DECL_NSIXHRSENDABLE
NS_DECL_NSIMUTABLE

Expand Down
8 changes: 8 additions & 0 deletions content/base/public/nsIDOMFile.idl
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,14 @@ interface nsIDOMBlob : nsISupports
[notxpcom] FileInfo getFileInfo(in FileManager aFileManager);
};

[scriptable, builtinclass, uuid(96a9f6f5-2353-47a3-9bf5-4b1e0fe11c08)]
interface nsIDOMBlob_GECKO_13 : nsISupports
{
[optional_argc] nsIDOMBlob mozSlice([optional] in long long start,
[optional] in long long end,
[optional] in DOMString contentType);
};

[scriptable, builtinclass, uuid(b096ef67-7b77-47f8-8e70-5d8ee36416bf)]
interface nsIDOMFile : nsIDOMBlob
{
Expand Down
11 changes: 11 additions & 0 deletions content/base/src/nsDOMFile.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,7 @@ DOMCI_DATA(Blob, nsDOMFileBase)
NS_INTERFACE_MAP_BEGIN(nsDOMFileBase)
NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIDOMFile)
NS_INTERFACE_MAP_ENTRY(nsIDOMBlob)
NS_INTERFACE_MAP_ENTRY(nsIDOMBlob_GECKO_13)
NS_INTERFACE_MAP_ENTRY_CONDITIONAL(nsIDOMFile, mIsFile)
NS_INTERFACE_MAP_ENTRY(nsIXHRSendable)
NS_INTERFACE_MAP_ENTRY(nsIMutable)
Expand Down Expand Up @@ -262,6 +263,16 @@ nsDOMFileBase::Slice(PRInt64 aStart, PRInt64 aEnd,
return *aBlob ? NS_OK : NS_ERROR_UNEXPECTED;
}

NS_IMETHODIMP
nsDOMFileBase::MozSlice(PRInt64 aStart, PRInt64 aEnd,
const nsAString& aContentType, PRUint8 optional_argc,
nsIDOMBlob **aBlob)
{
MOZ_ASSERT(NS_IsMainThread());

return Slice(aStart, aEnd, aContentType, optional_argc, aBlob);
}

NS_IMETHODIMP
nsDOMFileBase::GetInternalStream(nsIInputStream **aStream)
{
Expand Down
4 changes: 4 additions & 0 deletions content/base/test/fileutils.js
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,10 @@ function testSlice(file, size, type, contents, fileType) {
var slice = file.slice(0, size);
ok(slice instanceof Blob, fileType + " fullsize slice is a Blob");
ok(!(slice instanceof File), fileType + " fullsize slice is not a File");

var slice = file.mozSlice(0, size);
ok(slice instanceof Blob, fileType + " fullsize slice is a Blob");
ok(!(slice instanceof File), fileType + " fullsize slice is not a File");

slice = file.slice(0, 1234);
ok(slice instanceof Blob, fileType + " sized slice is a Blob");
Expand Down
2 changes: 2 additions & 0 deletions dom/base/nsDOMClassInfo.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3980,10 +3980,12 @@ nsDOMClassInfo::Init()

DOM_CLASSINFO_MAP_BEGIN(Blob, nsIDOMBlob)
DOM_CLASSINFO_MAP_ENTRY(nsIDOMBlob)
DOM_CLASSINFO_MAP_ENTRY(nsIDOMBlob_GECKO_13)
DOM_CLASSINFO_MAP_END

DOM_CLASSINFO_MAP_BEGIN(File, nsIDOMFile)
DOM_CLASSINFO_MAP_ENTRY(nsIDOMBlob)
DOM_CLASSINFO_MAP_ENTRY(nsIDOMBlob_GECKO_13)
DOM_CLASSINFO_MAP_ENTRY(nsIDOMFile)
DOM_CLASSINFO_MAP_END

Expand Down

0 comments on commit 2eb4e98

Please sign in to comment.