mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-06 00:55:37 +00:00
6c4d8f4644
--HG-- rename : dom/file/ArchiveEvent.cpp => dom/archivereader/ArchiveEvent.cpp rename : dom/file/ArchiveEvent.h => dom/archivereader/ArchiveEvent.h rename : dom/file/ArchiveReader.cpp => dom/archivereader/ArchiveReader.cpp rename : dom/file/ArchiveReader.h => dom/archivereader/ArchiveReader.h rename : dom/file/ArchiveRequest.cpp => dom/archivereader/ArchiveRequest.cpp rename : dom/file/ArchiveRequest.h => dom/archivereader/ArchiveRequest.h rename : dom/file/ArchiveZipEvent.cpp => dom/archivereader/ArchiveZipEvent.cpp rename : dom/file/ArchiveZipEvent.h => dom/archivereader/ArchiveZipEvent.h rename : dom/file/ArchiveZipFile.cpp => dom/archivereader/ArchiveZipFile.cpp rename : dom/file/ArchiveZipFile.h => dom/archivereader/ArchiveZipFile.h rename : dom/file/test/test_archivereader.html => dom/archivereader/test/test_basic.html rename : dom/file/test/test_archivereader_nonUnicode.html => dom/archivereader/test/test_nonUnicode.html rename : dom/file/test/test_archivereader_zip_in_zip.html => dom/archivereader/test/test_zip_in_zip.html rename : dom/file/test/test_bug_793311.html => dom/base/test/test_bug793311.html rename : dom/file/AsyncHelper.cpp => dom/filehandle/AsyncHelper.cpp rename : dom/file/AsyncHelper.h => dom/filehandle/AsyncHelper.h rename : dom/file/File.cpp => dom/filehandle/File.cpp rename : dom/file/File.h => dom/filehandle/File.h rename : dom/file/FileHandle.cpp => dom/filehandle/FileHandle.cpp rename : dom/file/FileHandle.h => dom/filehandle/FileHandle.h rename : dom/file/FileHelper.cpp => dom/filehandle/FileHelper.cpp rename : dom/file/FileHelper.h => dom/filehandle/FileHelper.h rename : dom/file/FileRequest.cpp => dom/filehandle/FileRequest.cpp rename : dom/file/FileRequest.h => dom/filehandle/FileRequest.h rename : dom/file/FileService.cpp => dom/filehandle/FileService.cpp rename : dom/file/FileService.h => dom/filehandle/FileService.h rename : dom/file/FileStreamWrappers.cpp => dom/filehandle/FileStreamWrappers.cpp rename : dom/file/FileStreamWrappers.h => dom/filehandle/FileStreamWrappers.h rename : dom/file/LockedFile.cpp => dom/filehandle/LockedFile.cpp rename : dom/file/LockedFile.h => dom/filehandle/LockedFile.h rename : dom/file/MemoryStreams.cpp => dom/filehandle/MemoryStreams.cpp rename : dom/file/MemoryStreams.h => dom/filehandle/MemoryStreams.h rename : dom/file/MetadataHelper.cpp => dom/filehandle/MetadataHelper.cpp rename : dom/file/MetadataHelper.h => dom/filehandle/MetadataHelper.h rename : dom/file/moz.build => dom/filehandle/moz.build rename : dom/file/nsIFileStorage.h => dom/filehandle/nsIFileStorage.h rename : dom/file/test/dummy_worker.js => dom/filehandle/test/dummy_worker.js rename : dom/file/test/helpers.js => dom/filehandle/test/helpers.js rename : dom/file/test/mochitest.ini => dom/filehandle/test/mochitest.ini rename : dom/file/test/moz.build => dom/filehandle/test/moz.build rename : dom/file/test/test_append_read_data.html => dom/filehandle/test/test_append_read_data.html rename : dom/file/test/test_getFile.html => dom/filehandle/test/test_getFile.html rename : dom/file/test/test_getFileId.html => dom/filehandle/test/test_getFileId.html rename : dom/file/test/test_location.html => dom/filehandle/test/test_location.html rename : dom/file/test/test_lockedfile_lifetimes.html => dom/filehandle/test/test_lockedfile_lifetimes.html rename : dom/file/test/test_lockedfile_lifetimes_nested.html => dom/filehandle/test/test_lockedfile_lifetimes_nested.html rename : dom/file/test/test_lockedfile_ordering.html => dom/filehandle/test/test_lockedfile_ordering.html rename : dom/file/test/test_overlapping_lockedfiles.html => dom/filehandle/test/test_overlapping_lockedfiles.html rename : dom/file/test/test_progress_events.html => dom/filehandle/test/test_progress_events.html rename : dom/file/test/test_readonly_lockedfiles.html => dom/filehandle/test/test_readonly_lockedfiles.html rename : dom/file/test/test_request_readyState.html => dom/filehandle/test/test_request_readyState.html rename : dom/file/test/test_stream_tracking.html => dom/filehandle/test/test_stream_tracking.html rename : dom/file/test/test_success_events_after_abort.html => dom/filehandle/test/test_success_events_after_abort.html rename : dom/file/test/test_truncate.html => dom/filehandle/test/test_truncate.html rename : dom/file/test/test_workers.html => dom/filehandle/test/test_workers.html rename : dom/file/test/test_write_read_data.html => dom/filehandle/test/test_write_read_data.html
278 lines
6.4 KiB
C++
278 lines
6.4 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=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/. */
|
|
|
|
#include "ArchiveRequest.h"
|
|
|
|
#include "mozilla/EventDispatcher.h"
|
|
#include "mozilla/dom/ArchiveRequestBinding.h"
|
|
#include "nsContentUtils.h"
|
|
#include "nsCxPusher.h"
|
|
|
|
using namespace mozilla;
|
|
|
|
USING_ARCHIVEREADER_NAMESPACE
|
|
|
|
/**
|
|
* Class used to make asynchronous the ArchiveRequest.
|
|
*/
|
|
class ArchiveRequestEvent : public nsRunnable
|
|
{
|
|
public:
|
|
NS_DECL_NSIRUNNABLE
|
|
|
|
ArchiveRequestEvent(ArchiveRequest* request)
|
|
: mRequest(request)
|
|
{
|
|
MOZ_COUNT_CTOR(ArchiveRequestEvent);
|
|
}
|
|
|
|
~ArchiveRequestEvent()
|
|
{
|
|
MOZ_COUNT_DTOR(ArchiveRequestEvent);
|
|
}
|
|
|
|
private: //data
|
|
nsRefPtr<ArchiveRequest> mRequest;
|
|
};
|
|
|
|
NS_IMETHODIMP
|
|
ArchiveRequestEvent::Run()
|
|
{
|
|
NS_ABORT_IF_FALSE(mRequest, "the request is not longer valid");
|
|
mRequest->Run();
|
|
return NS_OK;
|
|
}
|
|
|
|
// ArchiveRequest
|
|
|
|
ArchiveRequest::ArchiveRequest(nsPIDOMWindow* aWindow,
|
|
ArchiveReader* aReader)
|
|
: DOMRequest(aWindow),
|
|
mArchiveReader(aReader)
|
|
{
|
|
MOZ_ASSERT(aReader);
|
|
|
|
MOZ_COUNT_CTOR(ArchiveRequest);
|
|
|
|
/* An event to make this request asynchronous: */
|
|
nsRefPtr<ArchiveRequestEvent> event = new ArchiveRequestEvent(this);
|
|
NS_DispatchToCurrentThread(event);
|
|
}
|
|
|
|
ArchiveRequest::~ArchiveRequest()
|
|
{
|
|
MOZ_COUNT_DTOR(ArchiveRequest);
|
|
}
|
|
|
|
nsresult
|
|
ArchiveRequest::PreHandleEvent(EventChainPreVisitor& aVisitor)
|
|
{
|
|
aVisitor.mCanHandle = true;
|
|
aVisitor.mParentTarget = nullptr;
|
|
return NS_OK;
|
|
}
|
|
|
|
/* virtual */ JSObject*
|
|
ArchiveRequest::WrapObject(JSContext* aCx)
|
|
{
|
|
return ArchiveRequestBinding::Wrap(aCx, this);
|
|
}
|
|
|
|
ArchiveReader*
|
|
ArchiveRequest::Reader() const
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
return mArchiveReader;
|
|
}
|
|
|
|
// Here the request is processed:
|
|
void
|
|
ArchiveRequest::Run()
|
|
{
|
|
// Register this request to the reader.
|
|
// When the reader is ready to return data, a 'Ready()' will be called
|
|
nsresult rv = mArchiveReader->RegisterRequest(this);
|
|
if (NS_FAILED(rv)) {
|
|
FireError(rv);
|
|
}
|
|
}
|
|
|
|
void
|
|
ArchiveRequest::OpGetFilenames()
|
|
{
|
|
mOperation = GetFilenames;
|
|
}
|
|
|
|
void
|
|
ArchiveRequest::OpGetFile(const nsAString& aFilename)
|
|
{
|
|
mOperation = GetFile;
|
|
mFilename = aFilename;
|
|
}
|
|
|
|
void
|
|
ArchiveRequest::OpGetFiles()
|
|
{
|
|
mOperation = GetFiles;
|
|
}
|
|
|
|
nsresult
|
|
ArchiveRequest::ReaderReady(nsTArray<nsCOMPtr<nsIDOMFile> >& aFileList,
|
|
nsresult aStatus)
|
|
{
|
|
if (NS_FAILED(aStatus)) {
|
|
FireError(aStatus);
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult rv;
|
|
|
|
nsIScriptContext* sc = GetContextForEventHandlers(&rv);
|
|
NS_ENSURE_STATE(sc);
|
|
|
|
AutoPushJSContext cx(sc->GetNativeContext());
|
|
NS_ASSERTION(cx, "Failed to get a context!");
|
|
|
|
JS::Rooted<JSObject*> global(cx, sc->GetWindowProxy());
|
|
NS_ASSERTION(global, "Failed to get global object!");
|
|
|
|
JSAutoCompartment ac(cx, global);
|
|
|
|
JS::Rooted<JS::Value> result(cx);
|
|
switch (mOperation) {
|
|
case GetFilenames:
|
|
rv = GetFilenamesResult(cx, result.address(), aFileList);
|
|
break;
|
|
|
|
case GetFile:
|
|
rv = GetFileResult(cx, &result, aFileList);
|
|
break;
|
|
|
|
case GetFiles:
|
|
rv = GetFilesResult(cx, &result, aFileList);
|
|
break;
|
|
}
|
|
|
|
if (NS_FAILED(rv)) {
|
|
NS_WARNING("Get*Result failed!");
|
|
}
|
|
|
|
if (NS_SUCCEEDED(rv)) {
|
|
FireSuccess(result);
|
|
}
|
|
else {
|
|
FireError(rv);
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
ArchiveRequest::GetFilenamesResult(JSContext* aCx,
|
|
JS::Value* aValue,
|
|
nsTArray<nsCOMPtr<nsIDOMFile> >& aFileList)
|
|
{
|
|
JS::Rooted<JSObject*> array(aCx, JS_NewArrayObject(aCx, aFileList.Length()));
|
|
nsresult rv;
|
|
|
|
if (!array) {
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
JS::Rooted<JSString*> str(aCx);
|
|
for (uint32_t i = 0; i < aFileList.Length(); ++i) {
|
|
nsCOMPtr<nsIDOMFile> file = aFileList[i];
|
|
|
|
nsString filename;
|
|
rv = file->GetName(filename);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
str = JS_NewUCStringCopyZ(aCx, filename.get());
|
|
NS_ENSURE_TRUE(str, NS_ERROR_OUT_OF_MEMORY);
|
|
|
|
if (NS_FAILED(rv) ||
|
|
!JS_DefineElement(aCx, array, i, str, JSPROP_ENUMERATE)) {
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
}
|
|
|
|
if (!JS_FreezeObject(aCx, array)) {
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
*aValue = OBJECT_TO_JSVAL(array);
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
ArchiveRequest::GetFileResult(JSContext* aCx,
|
|
JS::MutableHandle<JS::Value> aValue,
|
|
nsTArray<nsCOMPtr<nsIDOMFile> >& aFileList)
|
|
{
|
|
for (uint32_t i = 0; i < aFileList.Length(); ++i) {
|
|
nsCOMPtr<nsIDOMFile> file = aFileList[i];
|
|
|
|
nsString filename;
|
|
nsresult rv = file->GetName(filename);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
if (filename == mFilename) {
|
|
return nsContentUtils::WrapNative(aCx, file, &NS_GET_IID(nsIDOMFile),
|
|
aValue);
|
|
}
|
|
}
|
|
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
nsresult
|
|
ArchiveRequest::GetFilesResult(JSContext* aCx,
|
|
JS::MutableHandle<JS::Value> aValue,
|
|
nsTArray<nsCOMPtr<nsIDOMFile> >& aFileList)
|
|
{
|
|
JS::Rooted<JSObject*> array(aCx, JS_NewArrayObject(aCx, aFileList.Length()));
|
|
if (!array) {
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
for (uint32_t i = 0; i < aFileList.Length(); ++i) {
|
|
nsCOMPtr<nsIDOMFile> file = aFileList[i];
|
|
|
|
JS::Rooted<JS::Value> value(aCx);
|
|
nsresult rv = nsContentUtils::WrapNative(aCx, file, &NS_GET_IID(nsIDOMFile),
|
|
&value);
|
|
if (NS_FAILED(rv) ||
|
|
!JS_DefineElement(aCx, array, i, value, JSPROP_ENUMERATE)) {
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
}
|
|
|
|
aValue.setObject(*array);
|
|
return NS_OK;
|
|
}
|
|
|
|
// static
|
|
already_AddRefed<ArchiveRequest>
|
|
ArchiveRequest::Create(nsPIDOMWindow* aOwner,
|
|
ArchiveReader* aReader)
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
nsRefPtr<ArchiveRequest> request = new ArchiveRequest(aOwner, aReader);
|
|
|
|
return request.forget();
|
|
}
|
|
|
|
NS_IMPL_CYCLE_COLLECTION_INHERITED(ArchiveRequest, DOMRequest,
|
|
mArchiveReader)
|
|
|
|
NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION_INHERITED(ArchiveRequest)
|
|
NS_INTERFACE_MAP_END_INHERITING(DOMRequest)
|
|
|
|
NS_IMPL_ADDREF_INHERITED(ArchiveRequest, DOMRequest)
|
|
NS_IMPL_RELEASE_INHERITED(ArchiveRequest, DOMRequest)
|