mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
3dafb8d491
- Bug 1162293 - Part 1: Remove instances of #ifdef PR_LOGGING. r=froydnj (20456f454)
- Bug 1162293 - Part 2: Fix string leak in logging code. r=froydnj (2b7552940)
- Bug 1162748 - Remove instances of #ifdef PR_LOGGING in graphics. r=froydnj (1ec0e8140)
- Bug 1156632 - Remove unused forward class declarations - patch 1 - dom/base, r=ehsan (eba98c427)
- Bug 1149420 - Make the IndexedDB permissions prompt work in e10s. r=bent/mfinkle (fc977c048)
- Bug 1156632 - Remove unused forward class declarations - patch 2 - dom/media, dom/indexedDB, dom/svg, r=ehsan (011caf393)
- Bug 1156632 - Remove unused forward class declarations - patch 3 - dom/{events,xbl,xslt,xul} and others, r=ehsan (72051c70b)
- Bug 1148005; Update WebVR APIs based on latest spec changes; r=baku (15b0a712f)
- Bug 1156632 - Remove unused forward class declarations - patch 4 - netwerk image and dom, r=ehsan (5ee4f1679)
- Bug 1139972 - IPC Proxy for charAt, r=tbsaunde (95d3626ec)
- Bug 1139887 - IPC Proxy for caretOffset, r=tbsaunde (c44893cd5)
- Bug 1141228 - include GfxMessageUtils.h in PDocAccessible.ipdl, r=tbsaunde (773e741f9)
- goannaCoordType -> geckoCoordType (b6ede7903)
- Bug 1145292 - IPC Proxy for ImageAccessible, r=tbsaunde (ca37ce753)
- bug 1128751 - handle unbinding and rebinding of documents in content processes r=davidb (0ad3331ab)
- Bug 1145366 - IPC Proxy for HyperLink, r=tbsaunde (87bc696f5)
- Bug 1146615 - IPC Proxy for HyperText, r=tbsaunde (de5322207)
- Bug 1146665 - IPC Proxy for TableCell, r=tbsaunde (895e24eee)
- Bug 1147079 - IPC Proxy for Table, r=tbsaunde (6e54178fe)
- Bug 1147168 - IPC Proxy for Selection, r=tbsaunde (40b8fa16e)
- Bug 1147518 - IPC Proxy for Action, r=davidb (12d5a235f)
- Bug 1147551 - IPC Proxy for min/cur/max values, r=davidb (3728abc54)
- Bug 1148025 - IPC Proxy for 'Component', r=tbsaunde (38bea1f4a)
- Bug 1148083 - IPC Proxy for Document, r=davidb (a7d53936d)
- Bug 1132854 - Make nsIntSize a typedef of gfx::IntSize. r=Bas, roc (09d0ae0d9)
- goannaRole -> geckoRole (421bdcd36)
- bug 1138436 - start on proxying IAccessible2 r=surkov, r=davidb (b2be8ba44)
- bug 1151402 - proxy most of IAccessibleText and IAccessibleEditableText r=davidb (dff7da028)
- Bug 1162740 - Part 1: Remove instances of #ifdef PR_LOGGING in rdf. r=froydnj (e398edb14)
- Bug 1162740 - Part 2: Wrap expensive calls in PR_LOG_TEST. r=froydnj (d873be4f4)
- Bug 1067054 - Remove generic SQLITE_ERROR warning & suppress warning if transaction exists. r=mak (cdc03b034)
- Bug 1137287 - Part 1: Shift some code from InterceptedChannelContent to HttpChannelChild. r=mayhemer (6141690a1)
- Bug 1136969 - Add a check that OnStartRequest is called just once during the lifetime of a channel. r=mcmanus (3b6aa0560)
- Bug 1053650 - Part 1: Add attribute 'networkInterfaceId' to XMLHttpRequest. r=bz Bug 1053650 - Part 2: Populate networkInterfaceId to SocketTransport r=mcmanus Bug 1053650 - Part 3: Make use of gonk-specific per-interface DNS lookup. r=mcmanus Bug 1053650 follow-up: Mark GetNetworkInterfaceId/SetNetworkInterfaceId as override (e308fc405)
244 lines
9.4 KiB
C++
244 lines
9.4 KiB
C++
/* -*- Mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; tab-width: 40 -*- */
|
|
/* 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/. */
|
|
|
|
#ifndef mozilla_dom_FileSystemTaskBase_h
|
|
#define mozilla_dom_FileSystemTaskBase_h
|
|
|
|
#include "mozilla/ErrorResult.h"
|
|
#include "mozilla/dom/FileSystemRequestParent.h"
|
|
#include "mozilla/dom/PFileSystemRequestChild.h"
|
|
|
|
class nsIDOMFile;
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
|
|
class BlobParent;
|
|
class FileSystemBase;
|
|
class FileSystemParams;
|
|
|
|
/*
|
|
* The base class to implement a Task class.
|
|
* The task is used to handle the OOP (out of process) operations.
|
|
* The file system operations can only be performed in the parent process. When
|
|
* performing such a parent-process-only operation, a task will delivered the
|
|
* operation to the parent process if needed.
|
|
*
|
|
* The following diagram illustrates the how a API call from the content page
|
|
* starts a task and gets call back results.
|
|
*
|
|
* The left block is the call sequence inside the child process, while the
|
|
* right block is the call sequence inside the parent process.
|
|
*
|
|
* There are two types of API call. One is from the content page of the child
|
|
* process and we mark the steps as (1) to (8). The other is from the content
|
|
* page of the parent process and we mark the steps as (1') to (4').
|
|
*
|
|
* Page Page
|
|
* | |
|
|
* | (1) | (1')
|
|
* ______|________________ | _____________________|_____________
|
|
* | | | | | | |
|
|
* | | Task in | | | Task in | |
|
|
* | | Child Process | | | Parent Process | |
|
|
* | V | IPC | V |
|
|
* [new FileSystemTaskBase()] | | [new FileSystemTaskBase()] |
|
|
* | | | | | | |
|
|
* | | (2) | | | (2') |
|
|
* | V | (3) | | |
|
|
* | [GetRequestParams]------------->[new FileSystemTaskBase(...)] |
|
|
* | | | | | |
|
|
* | | | | | (4) | |
|
|
* | | | | | V |
|
|
* | | | | -----------> [Work] |
|
|
* | | IPC | | |
|
|
* | | | | (5) | (3') |
|
|
* | | | | V |
|
|
* | | | | --------[HandleResult] |
|
|
* | | | | | | |
|
|
* | | | | (6) | |
|
|
* | | (7) | V | |
|
|
* | [SetRequestResult]<-------------[GetRequestResult] | |
|
|
* | | | | | (4') |
|
|
* | | (8) | | | | |
|
|
* | V | | | V |
|
|
* |[HandlerCallback] | IPC | [HandlerCallback] |
|
|
* |_______|_______________| | |_________________________|_________|
|
|
* | | |
|
|
* V V
|
|
* Page Page
|
|
*
|
|
* 1. From child process page
|
|
* Child:
|
|
* (1) Call FileSystem API from content page with JS. Create a task and run.
|
|
* The base constructor [FileSystemTaskBase()] of the task should be called.
|
|
* (2) Forward the task to the parent process through the IPC and call
|
|
* [GetRequestParams] to prepare the parameters of the IPC.
|
|
* Parent:
|
|
* (3) The parent process receives IPC and handle it in
|
|
* FileystemRequestParent.
|
|
* Get the IPC parameters and create a task to run the IPC task. The base
|
|
* constructor [FileSystemTaskBase(aParam, aParent)] of the task should be
|
|
* called to set the task as an IPC task.
|
|
* (4) The task operation will be performed in the member function of [Work].
|
|
* A worker thread will be created to run that function. If error occurs
|
|
* during the operation, call [SetError] to record the error and then abort.
|
|
* (5) After finishing the task operation, call [HandleResult] to send the
|
|
* result back to the child process though the IPC.
|
|
* (6) Call [GetRequestResult] request result to prepare the parameters of the
|
|
* IPC. Because the formats of the error result for different task are the
|
|
* same, FileSystemTaskBase can handle the error message without interfering.
|
|
* Each task only needs to implement its specific success result preparation
|
|
* function -[GetSuccessRequestResult].
|
|
* Child:
|
|
* (7) The child process receives IPC and calls [SetRequestResult] to get the
|
|
* task result. Each task needs to implement its specific success result
|
|
* parsing function [SetSuccessRequestResult] to get the success result.
|
|
* (8) Call [HandlerCallback] to send the task result to the content page.
|
|
* 2. From parent process page
|
|
* We don't need to send the task parameters and result to other process. So
|
|
* there are less steps, but their functions are the same. The correspondence
|
|
* between the two types of steps is:
|
|
* (1') = (1),
|
|
* (2') = (4),
|
|
* (3') = (5),
|
|
* (4') = (8).
|
|
*/
|
|
class FileSystemTaskBase
|
|
: public nsRunnable
|
|
, public PFileSystemRequestChild
|
|
{
|
|
public:
|
|
/*
|
|
* Start the task. If the task is running the child process, it will be
|
|
* forwarded to parent process by IPC, or else, creates a worker thread to
|
|
* do the task work.
|
|
*/
|
|
void
|
|
Start();
|
|
|
|
/*
|
|
* The error codes are defined in xpcom/base/ErrorList.h and their
|
|
* corresponding error name and message are defined in dom/base/domerr.msg.
|
|
*/
|
|
void
|
|
SetError(const nsresult& aErrorCode);
|
|
|
|
FileSystemBase*
|
|
GetFileSystem() const;
|
|
|
|
/*
|
|
* Get the type of permission access required to perform this task.
|
|
*/
|
|
virtual void
|
|
GetPermissionAccessType(nsCString& aAccess) const = 0;
|
|
|
|
NS_DECL_NSIRUNNABLE
|
|
protected:
|
|
/*
|
|
* To create a task to handle the page content request.
|
|
*/
|
|
explicit FileSystemTaskBase(FileSystemBase* aFileSystem);
|
|
|
|
/*
|
|
* To create a parent process task delivered from the child process through
|
|
* IPC.
|
|
*/
|
|
FileSystemTaskBase(FileSystemBase* aFileSystem,
|
|
const FileSystemParams& aParam,
|
|
FileSystemRequestParent* aParent);
|
|
|
|
virtual
|
|
~FileSystemTaskBase();
|
|
|
|
/*
|
|
* The function to perform task operation. It will be run on the worker
|
|
* thread of the parent process.
|
|
* Overrides this function to define the task operation for individual task.
|
|
*/
|
|
virtual nsresult
|
|
Work() = 0;
|
|
|
|
/*
|
|
* After the task is completed, this function will be called to pass the task
|
|
* result to the content page.
|
|
* Override this function to handle the call back to the content page.
|
|
*/
|
|
virtual void
|
|
HandlerCallback() = 0;
|
|
|
|
/*
|
|
* Wrap the task parameter to FileSystemParams for sending it through IPC.
|
|
* It will be called when we need to forward a task from the child process to
|
|
* the prarent process.
|
|
* @param filesystem The string representation of the file system.
|
|
*/
|
|
virtual FileSystemParams
|
|
GetRequestParams(const nsString& aFileSystem) const = 0;
|
|
|
|
/*
|
|
* Wrap the task success result to FileSystemResponseValue for sending it
|
|
* through IPC.
|
|
* It will be called when the task is completed successfully and we need to
|
|
* send the task success result back to the child process.
|
|
*/
|
|
virtual FileSystemResponseValue
|
|
GetSuccessRequestResult() const = 0;
|
|
|
|
/*
|
|
* Unwrap the IPC message to get the task success result.
|
|
* It will be called when the task is completed successfully and an IPC
|
|
* message is received in the child process and we want to get the task
|
|
* success result.
|
|
*/
|
|
virtual void
|
|
SetSuccessRequestResult(const FileSystemResponseValue& aValue) = 0;
|
|
|
|
bool
|
|
HasError() const { return mErrorValue != NS_OK; }
|
|
|
|
// Overrides PFileSystemRequestChild
|
|
virtual bool
|
|
Recv__delete__(const FileSystemResponseValue& value) override;
|
|
|
|
BlobParent*
|
|
GetBlobParent(nsIDOMFile* aFile) const;
|
|
|
|
nsresult mErrorValue;
|
|
|
|
nsRefPtr<FileSystemBase> mFileSystem;
|
|
nsRefPtr<FileSystemRequestParent> mRequestParent;
|
|
private:
|
|
/*
|
|
* After finishing the task operation, handle the task result.
|
|
* If it is an IPC task, send back the IPC result. Or else, send the result
|
|
* to the content page.
|
|
*/
|
|
void
|
|
HandleResult();
|
|
|
|
/*
|
|
* Wrap the task result to FileSystemResponseValue for sending it through IPC.
|
|
* It will be called when the task is completed and we need to
|
|
* send the task result back to the child process.
|
|
*/
|
|
FileSystemResponseValue
|
|
GetRequestResult() const;
|
|
|
|
/*
|
|
* Unwrap the IPC message to get the task result.
|
|
* It will be called when the task is completed and an IPC message is received
|
|
* in the child process and we want to get the task result.
|
|
*/
|
|
void
|
|
SetRequestResult(const FileSystemResponseValue& aValue);
|
|
};
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|
|
|
|
#endif // mozilla_dom_FileSystemTaskBase_h
|