mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
31546e1e24
--HG-- rename : dom/filehandle/FileHandle.cpp => dom/filehandle/MutableFile.cpp rename : dom/filehandle/FileHandle.h => dom/filehandle/MutableFile.h rename : dom/filehandle/test/test_lockedfile_lifetimes.html => dom/filehandle/test/test_filehandle_lifetimes.html rename : dom/filehandle/test/test_lockedfile_lifetimes_nested.html => dom/filehandle/test/test_filehandle_lifetimes_nested.html rename : dom/filehandle/test/test_lockedfile_ordering.html => dom/filehandle/test/test_filehandle_ordering.html rename : dom/filehandle/test/test_overlapping_lockedfiles.html => dom/filehandle/test/test_overlapping_filehandles.html rename : dom/filehandle/test/test_readonly_lockedfiles.html => dom/filehandle/test/test_readonly_filehandles.html rename : dom/indexedDB/IDBFileHandle.cpp => dom/indexedDB/IDBMutableFile.cpp rename : dom/indexedDB/IDBFileHandle.h => dom/indexedDB/IDBMutableFile.h rename : dom/webidl/IDBFileHandle.webidl => dom/webidl/IDBMutableFile.webidl rename : dom/webidl/FileHandle.webidl => dom/webidl/MutableFile.webidl
152 lines
3.6 KiB
C++
152 lines
3.6 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 "FileRequest.h"
|
|
|
|
#include "FileHandle.h"
|
|
#include "FileHelper.h"
|
|
#include "js/RootingAPI.h"
|
|
#include "jsapi.h"
|
|
#include "MainThreadUtils.h"
|
|
#include "mozilla/dom/FileRequestBinding.h"
|
|
#include "mozilla/EventDispatcher.h"
|
|
#include "nsCOMPtr.h"
|
|
#include "nsCxPusher.h"
|
|
#include "nsDebug.h"
|
|
#include "nsError.h"
|
|
#include "nsIDOMEvent.h"
|
|
#include "mozilla/dom/ProgressEvent.h"
|
|
#include "nsIScriptContext.h"
|
|
#include "nsLiteralString.h"
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
|
|
FileRequest::FileRequest(nsPIDOMWindow* aWindow)
|
|
: DOMRequest(aWindow), mWrapAsDOMRequest(false)
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
}
|
|
|
|
FileRequest::~FileRequest()
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
}
|
|
|
|
// static
|
|
already_AddRefed<FileRequest>
|
|
FileRequest::Create(nsPIDOMWindow* aOwner, FileHandle* aFileHandle,
|
|
bool aWrapAsDOMRequest)
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
nsRefPtr<FileRequest> request = new FileRequest(aOwner);
|
|
request->mFileHandle = aFileHandle;
|
|
request->mWrapAsDOMRequest = aWrapAsDOMRequest;
|
|
|
|
return request.forget();
|
|
}
|
|
|
|
nsresult
|
|
FileRequest::PreHandleEvent(EventChainPreVisitor& aVisitor)
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
aVisitor.mCanHandle = true;
|
|
aVisitor.mParentTarget = mFileHandle;
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
FileRequest::NotifyHelperCompleted(FileHelper* aFileHelper)
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
nsresult rv = aFileHelper->mResultCode;
|
|
|
|
// If the request failed then fire error event and return.
|
|
if (NS_FAILED(rv)) {
|
|
FireError(rv);
|
|
return NS_OK;
|
|
}
|
|
|
|
// Otherwise we need to get the result from the helper.
|
|
nsIScriptContext* sc = GetContextForEventHandlers(&rv);
|
|
NS_ENSURE_STATE(sc);
|
|
|
|
AutoJSContext cx;
|
|
NS_ASSERTION(cx, "Failed to get a context!");
|
|
|
|
JS::Rooted<JS::Value> result(cx);
|
|
|
|
JS::Rooted<JSObject*> global(cx, sc->GetWindowProxy());
|
|
NS_ASSERTION(global, "Failed to get global object!");
|
|
|
|
JSAutoCompartment ac(cx, global);
|
|
|
|
rv = aFileHelper->GetSuccessResult(cx, &result);
|
|
if (NS_FAILED(rv)) {
|
|
NS_WARNING("GetSuccessResult failed!");
|
|
}
|
|
|
|
if (NS_SUCCEEDED(rv)) {
|
|
FireSuccess(result);
|
|
}
|
|
else {
|
|
FireError(rv);
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMPL_CYCLE_COLLECTION_INHERITED(FileRequest, DOMRequest,
|
|
mFileHandle)
|
|
|
|
NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION_INHERITED(FileRequest)
|
|
NS_INTERFACE_MAP_END_INHERITING(DOMRequest)
|
|
|
|
NS_IMPL_ADDREF_INHERITED(FileRequest, DOMRequest)
|
|
NS_IMPL_RELEASE_INHERITED(FileRequest, DOMRequest)
|
|
|
|
// virtual
|
|
JSObject*
|
|
FileRequest::WrapObject(JSContext* aCx)
|
|
{
|
|
if (mWrapAsDOMRequest) {
|
|
return DOMRequest::WrapObject(aCx);
|
|
}
|
|
return FileRequestBinding::Wrap(aCx, this);
|
|
}
|
|
|
|
FileHandle*
|
|
FileRequest::GetFileHandle() const
|
|
{
|
|
MOZ_ASSERT(NS_IsMainThread(), "Wrong thread!");
|
|
return mFileHandle;
|
|
}
|
|
|
|
void
|
|
FileRequest::FireProgressEvent(uint64_t aLoaded, uint64_t aTotal)
|
|
{
|
|
if (NS_FAILED(CheckInnerWindowCorrectness())) {
|
|
return;
|
|
}
|
|
|
|
ProgressEventInit init;
|
|
init.mBubbles = false;
|
|
init.mCancelable = false;
|
|
init.mLengthComputable = false;
|
|
init.mLoaded = aLoaded;
|
|
init.mTotal = aTotal;
|
|
|
|
nsRefPtr<ProgressEvent> event =
|
|
ProgressEvent::Constructor(this, NS_LITERAL_STRING("progress"), init);
|
|
DispatchTrustedEvent(event);
|
|
}
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|