2017-02-16 20:26:38 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* 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/. */
|
|
|
|
|
|
|
|
#ifndef mozilla_dom_Blob_h
|
|
|
|
#define mozilla_dom_Blob_h
|
|
|
|
|
|
|
|
#include "mozilla/Attributes.h"
|
|
|
|
#include "mozilla/ErrorResult.h"
|
|
|
|
#include "mozilla/dom/BindingDeclarations.h"
|
|
|
|
#include "mozilla/dom/BlobImpl.h"
|
|
|
|
#include "nsCycleCollectionParticipant.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsIDOMBlob.h"
|
|
|
|
#include "nsIMutable.h"
|
|
|
|
#include "nsIXMLHttpRequest.h"
|
|
|
|
#include "nsWrapperCache.h"
|
|
|
|
#include "nsWeakReference.h"
|
|
|
|
|
|
|
|
class nsIInputStream;
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace dom {
|
|
|
|
|
|
|
|
struct BlobPropertyBag;
|
|
|
|
class File;
|
|
|
|
class OwningArrayBufferViewOrArrayBufferOrBlobOrUSVString;
|
|
|
|
|
|
|
|
class Blob : public nsIDOMBlob
|
|
|
|
, public nsIXHRSendable
|
|
|
|
, public nsIMutable
|
|
|
|
, public nsSupportsWeakReference
|
|
|
|
, public nsWrapperCache
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
NS_DECL_NSIDOMBLOB
|
|
|
|
NS_DECL_NSIXHRSENDABLE
|
|
|
|
NS_DECL_NSIMUTABLE
|
|
|
|
|
|
|
|
NS_DECL_CYCLE_COLLECTING_ISUPPORTS
|
|
|
|
NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS_AMBIGUOUS(Blob, nsIDOMBlob)
|
|
|
|
|
|
|
|
typedef OwningArrayBufferViewOrArrayBufferOrBlobOrUSVString BlobPart;
|
|
|
|
|
|
|
|
// This creates a Blob or a File based on the type of BlobImpl.
|
|
|
|
static Blob*
|
|
|
|
Create(nsISupports* aParent, BlobImpl* aImpl);
|
|
|
|
|
|
|
|
static already_AddRefed<Blob>
|
|
|
|
CreateStringBlob(nsISupports* aParent, const nsACString& aData,
|
|
|
|
const nsAString& aContentType);
|
|
|
|
|
|
|
|
// The returned Blob takes ownership of aMemoryBuffer. aMemoryBuffer will be
|
|
|
|
// freed by free so it must be allocated by malloc or something
|
|
|
|
// compatible with it.
|
|
|
|
static already_AddRefed<Blob>
|
|
|
|
CreateMemoryBlob(nsISupports* aParent, void* aMemoryBuffer, uint64_t aLength,
|
|
|
|
const nsAString& aContentType);
|
|
|
|
|
|
|
|
static already_AddRefed<Blob>
|
|
|
|
CreateTemporaryBlob(nsISupports* aParent, PRFileDesc* aFD,
|
|
|
|
uint64_t aStartPos, uint64_t aLength,
|
|
|
|
const nsAString& aContentType);
|
|
|
|
|
|
|
|
BlobImpl* Impl() const
|
|
|
|
{
|
|
|
|
return mImpl;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool IsFile() const;
|
|
|
|
|
|
|
|
const nsTArray<RefPtr<BlobImpl>>* GetSubBlobImpls() const;
|
|
|
|
|
|
|
|
// This method returns null if this Blob is not a File; it returns
|
|
|
|
// the same object in case this Blob already implements the File interface;
|
|
|
|
// otherwise it returns a new File object with the same BlobImpl.
|
|
|
|
already_AddRefed<File> ToFile();
|
|
|
|
|
|
|
|
// This method creates a new File object with the given name and the same
|
|
|
|
// BlobImpl.
|
|
|
|
already_AddRefed<File> ToFile(const nsAString& aName,
|
|
|
|
ErrorResult& aRv) const;
|
|
|
|
|
|
|
|
already_AddRefed<Blob>
|
|
|
|
CreateSlice(uint64_t aStart, uint64_t aLength, const nsAString& aContentType,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
|
|
|
void
|
|
|
|
GetInternalStream(nsIInputStream** aStream, ErrorResult& aRv);
|
|
|
|
|
|
|
|
int64_t
|
|
|
|
GetFileId();
|
|
|
|
|
|
|
|
// A utility function that enforces the spec constraints on the type of a
|
|
|
|
// blob: no codepoints outside the ASCII range (otherwise type becomes empty)
|
|
|
|
// and lowercase ASCII only. We can't just use our existing nsContentUtils
|
|
|
|
// ASCII-related helpers because we need the "outside ASCII range" check, and
|
|
|
|
// we can't use NS_IsAscii because its definition of "ASCII" (chars all <=
|
|
|
|
// 0x7E) differs from the file API definition (which excludes control chars).
|
|
|
|
static void
|
|
|
|
MakeValidBlobType(nsAString& aType);
|
|
|
|
|
|
|
|
// WebIDL methods
|
|
|
|
nsISupports* GetParentObject() const
|
|
|
|
{
|
|
|
|
return mParent;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
IsMemoryFile() const;
|
|
|
|
|
|
|
|
// Blob constructor
|
|
|
|
static already_AddRefed<Blob>
|
|
|
|
Constructor(const GlobalObject& aGlobal,
|
|
|
|
const Optional<Sequence<BlobPart>>& aData,
|
|
|
|
const BlobPropertyBag& aBag,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
|
|
|
virtual JSObject* WrapObject(JSContext* aCx,
|
|
|
|
JS::Handle<JSObject*> aGivenProto) override;
|
|
|
|
|
|
|
|
uint64_t GetSize(ErrorResult& aRv);
|
|
|
|
|
|
|
|
void GetType(nsAString& aType);
|
|
|
|
|
|
|
|
already_AddRefed<Blob> Slice(const Optional<int64_t>& aStart,
|
|
|
|
const Optional<int64_t>& aEnd,
|
|
|
|
const nsAString& aContentType,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
2017-09-12 12:46:51 +03:00
|
|
|
size_t GetAllocationSize() const;
|
|
|
|
|
2017-02-16 20:26:38 +03:00
|
|
|
protected:
|
|
|
|
// File constructor should never be used directly. Use Blob::Create instead.
|
|
|
|
Blob(nsISupports* aParent, BlobImpl* aImpl);
|
|
|
|
virtual ~Blob();
|
|
|
|
|
|
|
|
virtual bool HasFileInterface() const { return false; }
|
|
|
|
|
|
|
|
// The member is the real backend implementation of this File/Blob.
|
|
|
|
// It's thread-safe and not CC-able and it's the only element that is moved
|
|
|
|
// between threads.
|
|
|
|
// Note: we should not store any other state in this class!
|
|
|
|
RefPtr<BlobImpl> mImpl;
|
|
|
|
|
|
|
|
private:
|
|
|
|
nsCOMPtr<nsISupports> mParent;
|
|
|
|
};
|
|
|
|
|
2017-09-12 12:46:51 +03:00
|
|
|
// Override BindingJSObjectMallocBytes for blobs to tell the JS GC how much
|
|
|
|
// memory is held live by the binding object.
|
2017-09-13 13:21:12 +03:00
|
|
|
size_t BindingJSObjectMallocBytes(Blob* aBlob);
|
2017-09-12 12:46:51 +03:00
|
|
|
|
2017-02-16 20:26:38 +03:00
|
|
|
} // namespace dom
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif // mozilla_dom_Blob_h
|