mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 05:37:11 +00:00
4ac9bef80d
- Bug 936092, initial DnD support for e10s, r=enndeakin,karlt (3cde556cf) - Bug 1152066 - Remove ugly dynamic loading code now that we can assume this symbol exists. r=roc (04813dd18) - Bug 966395 - Correctly propagate the input language's direction on OSX. r=masayuki/mrbkap (14a21fa0c) - Bug 1158791 - Try harder to avoid Gtk-Critical errors in xpcshell tests. r=karlt (f6cec3b99) - Bug 1153922 - Add a SandboxOptions option for creating the sandbox in a fresh JS::Zone. r=mrbkap (f99b17726) - Bug 968520 - Always use fallible allocator with nsTArray_base::ShrinkCapacity. r=froydnj (b7cf63063) - Bug 1160027 - Move ResourceQueue implementation from header file - r=cpearce (5fabd8c8f) - Bug 1119277 - Remove the process CPU priority parameter and simplify all the associated code. r=khuey, r=dhylands (32d2b0df2) - Goanna -> Gecko (2b16bec4c) - Bug 892371 - Adjust oom_score_adj values for foreground processes according to an LRU policy. r=dhylands, r=khuey (61cdfc3db) - Bug 892371 - Add mochitests covering LRU priority adjustments for both foreground and background processes. r=khuey (46676e34f) - Bug 1164297 - tweaks to logging modules of MediaDecoderStateMachine to remove accessing to env vars. r=cpearce. (e9dc910da) - Bug 1150539: log getUserMedia constraints used in MediaManager:5. r=jesup (161853b66) - Bug 1139027 - Permit running of camera mochitests on B2G desktop. r=mikeh (8bb265db2) - Bug 1145403 - Don't open MediaManager on shutdown. r=jesup (9338eef82) - Bug 1046245 - enumerateDevices w/non-blocking e10s, nsICryptoHMAC, clear cookies, lambdas. r=keeler, florian, billm, jesup (ce9d684a0) - remove StopWebRtcLoc() to be readded in Bug 1219339 - Part2 (7a0c901fc) - Bug 1046245 - IO on STS thread + cleanup BackgroundChild on shutdown r=jesup (e85dd7716) - Bug 579517 follow-up: Remove NSPR types that crept in (35aee15a6) - Bug 1152443 - Fix broken validation which prevented reading of enumerate_devices.txt. r=jesup (4e135355b) - Bug 1143562 - use /data/b2g/mozilla/gmp as the gmp storage folder on B2G. r=cpearce. (ddc07f09a) - Bug 1143562. Part2 - only init |mStorageBaseDir| in the chrome process. r=cpearce (3039a4f44) - remove specific hack, this code is going away anyway (34aed4d6b) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 0 - Make mozIGeckoMediaPluginService::GetPluginVersionForAPI return whether we even have the plugin. r=cpearce. (e6ac61630) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 1 - split GeckoMediaPluginService into a part for chrome and a part for both content and chrome. r=jwwang. (09f8c4a83) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 2 - support asynchronous GMP API getters. r=jwwang,rjesup. (e33266976) - Bug 1143532 - Include pid in the log messages of GMPParent. r=edwin (8486ebc50) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 3 - split the GMP IPDL actors in 2 parts (and use opens to open the second in non-e10s). r=billm. (d17fa36ff) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 4 - make GetNodeId asynchronous. r=jwwang. (db7a21e4a) - Bug 1150049 - tidy up nsImageBoxFrame::Init a little bit; r=dholbert (41c258a71) - Bug 1150266 - fix IPDL thinko for never-inline method declarations; r=bent (445d3420b) - Bug 1150207 - Convert a focus() call to use SpecialPowers to avoid out-of-order focusing behaviour. r=mwargers (4d134848c) - Bug 1148641 - Guard against null parameters to SendSetTargetAPZCNotification. r=botond (8c5f4bb6d) - Bug 1096172 - Fix position reporting of bad charrefs in RCDATA. r=hsivonen. (77100d26d) - Bug 1149971 Part 2: Cet rid of kCurrentProcessId as it makes lots of static initializers. r=dvander (3efaefdba) - remove android widgets (0c2565418) - Bug 1129991 - Remove QuotaManager::SetCurrentWindow(); r=bent (7ccabf88c) - Bug 1133748 - Fix ipdl code for bridged protocols that are also opened. r=billm. (402751d09) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 5 - use bridging for GMP in e10s. r=billm. (e45a87c5f) - Bug 1057908 followup: Add missing 'override' annotation on GMPServiceParent::ActorDestroy method decl. rs=ehsan (48f53b28a) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Add nsServiceManagerUtils.h include to WMFDecoderModule.cpp. (67cddb4da) - kill android widgets better (bec243c8d)
415 lines
9.7 KiB
C++
415 lines
9.7 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 "FileStreamWrappers.h"
|
|
|
|
#include "FileHelper.h"
|
|
#include "MainThreadUtils.h"
|
|
#include "mozilla/Assertions.h"
|
|
#include "mozilla/Attributes.h"
|
|
#include "mozilla/ipc/InputStreamParams.h"
|
|
#include "MutableFile.h"
|
|
#include "nsDebug.h"
|
|
#include "nsError.h"
|
|
#include "nsIRunnable.h"
|
|
#include "nsISeekableStream.h"
|
|
#include "nsThreadUtils.h"
|
|
|
|
#ifdef DEBUG
|
|
#include "nsXULAppAPI.h"
|
|
#endif
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
|
|
namespace {
|
|
|
|
class ProgressRunnable final : public nsIRunnable
|
|
{
|
|
public:
|
|
NS_DECL_THREADSAFE_ISUPPORTS
|
|
NS_DECL_NSIRUNNABLE
|
|
|
|
ProgressRunnable(FileHelper* aFileHelper,
|
|
uint64_t aProgress,
|
|
uint64_t aProgressMax)
|
|
: mFileHelper(aFileHelper),
|
|
mProgress(aProgress),
|
|
mProgressMax(aProgressMax)
|
|
{
|
|
}
|
|
|
|
private:
|
|
~ProgressRunnable() {}
|
|
|
|
nsRefPtr<FileHelper> mFileHelper;
|
|
uint64_t mProgress;
|
|
uint64_t mProgressMax;
|
|
};
|
|
|
|
class CloseRunnable final : public nsIRunnable
|
|
{
|
|
public:
|
|
NS_DECL_THREADSAFE_ISUPPORTS
|
|
NS_DECL_NSIRUNNABLE
|
|
|
|
explicit CloseRunnable(FileHelper* aFileHelper)
|
|
: mFileHelper(aFileHelper)
|
|
{ }
|
|
|
|
private:
|
|
~CloseRunnable() {}
|
|
|
|
nsRefPtr<FileHelper> mFileHelper;
|
|
};
|
|
|
|
class DestroyRunnable final : public nsIRunnable
|
|
{
|
|
public:
|
|
NS_DECL_THREADSAFE_ISUPPORTS
|
|
NS_DECL_NSIRUNNABLE
|
|
|
|
explicit DestroyRunnable(FileHelper* aFileHelper)
|
|
: mFileHelper(aFileHelper)
|
|
{ }
|
|
|
|
private:
|
|
~DestroyRunnable() {}
|
|
|
|
nsRefPtr<FileHelper> mFileHelper;
|
|
};
|
|
|
|
} // namespace
|
|
|
|
FileStreamWrapper::FileStreamWrapper(nsISupports* aFileStream,
|
|
FileHelper* aFileHelper,
|
|
uint64_t aOffset,
|
|
uint64_t aLimit,
|
|
uint32_t aFlags)
|
|
: mFileStream(aFileStream),
|
|
mFileHelper(aFileHelper),
|
|
mOffset(aOffset),
|
|
mLimit(aLimit),
|
|
mFlags(aFlags),
|
|
mFirstTime(true)
|
|
{
|
|
NS_ASSERTION(mFileStream, "Must have a file stream!");
|
|
NS_ASSERTION(mFileHelper, "Must have a file helper!");
|
|
}
|
|
|
|
FileStreamWrapper::~FileStreamWrapper()
|
|
{
|
|
if (mFlags & NOTIFY_DESTROY) {
|
|
if (NS_IsMainThread()) {
|
|
mFileHelper->OnStreamDestroy();
|
|
}
|
|
else {
|
|
nsCOMPtr<nsIRunnable> runnable =
|
|
new DestroyRunnable(mFileHelper);
|
|
|
|
nsresult rv = NS_DispatchToMainThread(runnable);
|
|
if (NS_FAILED(rv)) {
|
|
NS_WARNING("Failed to dispatch to the main thread!");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
NS_IMPL_ISUPPORTS0(FileStreamWrapper)
|
|
|
|
FileInputStreamWrapper::FileInputStreamWrapper(nsISupports* aFileStream,
|
|
FileHelper* aFileHelper,
|
|
uint64_t aOffset,
|
|
uint64_t aLimit,
|
|
uint32_t aFlags)
|
|
: FileStreamWrapper(aFileStream, aFileHelper, aOffset, aLimit, aFlags)
|
|
{
|
|
mInputStream = do_QueryInterface(mFileStream);
|
|
NS_ASSERTION(mInputStream, "This should always succeed!");
|
|
}
|
|
|
|
NS_IMPL_ISUPPORTS_INHERITED(FileInputStreamWrapper,
|
|
FileStreamWrapper,
|
|
nsIInputStream,
|
|
nsIIPCSerializableInputStream)
|
|
|
|
NS_IMETHODIMP
|
|
FileInputStreamWrapper::Close()
|
|
{
|
|
NS_ASSERTION(!NS_IsMainThread(), "Wrong thread!");
|
|
|
|
if (mFlags & NOTIFY_CLOSE) {
|
|
nsCOMPtr<nsIRunnable> runnable = new CloseRunnable(mFileHelper);
|
|
|
|
if (NS_FAILED(NS_DispatchToMainThread(runnable))) {
|
|
NS_WARNING("Failed to dispatch to the main thread!");
|
|
}
|
|
}
|
|
|
|
mOffset = 0;
|
|
mLimit = 0;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileInputStreamWrapper::Available(uint64_t* _retval)
|
|
{
|
|
// Performing sync IO on the main thread is generally not allowed.
|
|
// However, the input stream wrapper is also used to track reads performed by
|
|
// other APIs like FileReader, XHR, etc.
|
|
// In that case nsInputStreamChannel::OpenContentStream() calls Available()
|
|
// before setting the content length property. This property is not important
|
|
// to perform reads properly, so we can just return NS_BASE_STREAM_CLOSED
|
|
// here. It causes OpenContentStream() to set the content length property to
|
|
// zero.
|
|
|
|
if (NS_IsMainThread()) {
|
|
return NS_BASE_STREAM_CLOSED;
|
|
}
|
|
|
|
return mInputStream->Available(_retval);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileInputStreamWrapper::Read(char* aBuf, uint32_t aCount, uint32_t* _retval)
|
|
{
|
|
NS_ASSERTION(!NS_IsMainThread(), "Wrong thread!");
|
|
|
|
nsresult rv;
|
|
|
|
if (mFirstTime) {
|
|
mFirstTime = false;
|
|
|
|
if (mOffset != UINT64_MAX) {
|
|
nsCOMPtr<nsISeekableStream> seekable = do_QueryInterface(mInputStream);
|
|
if (seekable) {
|
|
rv = seekable->Seek(nsISeekableStream::NS_SEEK_SET, mOffset);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
}
|
|
}
|
|
|
|
mOffset = 0;
|
|
}
|
|
|
|
uint64_t max = mLimit - mOffset;
|
|
if (max == 0) {
|
|
*_retval = 0;
|
|
return NS_OK;
|
|
}
|
|
|
|
if (aCount > max) {
|
|
aCount = max;
|
|
}
|
|
|
|
rv = mInputStream->Read(aBuf, aCount, _retval);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
mOffset += *_retval;
|
|
|
|
if (mFlags & NOTIFY_PROGRESS) {
|
|
nsCOMPtr<nsIRunnable> runnable =
|
|
new ProgressRunnable(mFileHelper, mOffset, mLimit);
|
|
|
|
rv = NS_DispatchToMainThread(runnable);
|
|
if (NS_FAILED(rv)) {
|
|
NS_WARNING("Failed to dispatch to the main thread!");
|
|
}
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileInputStreamWrapper::ReadSegments(nsWriteSegmentFun aWriter, void* aClosure,
|
|
uint32_t aCount, uint32_t* _retval)
|
|
{
|
|
return NS_ERROR_NOT_IMPLEMENTED;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileInputStreamWrapper::IsNonBlocking(bool* _retval)
|
|
{
|
|
*_retval = false;
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
FileInputStreamWrapper::Serialize(InputStreamParams& aParams,
|
|
FileDescriptorArray& /* aFDs */)
|
|
{
|
|
MOZ_ASSERT(XRE_GetProcessType() == GeckoProcessType_Default);
|
|
MOZ_ASSERT(NS_IsMainThread());
|
|
|
|
nsCOMPtr<nsIInputStream> thisStream = do_QueryObject(this);
|
|
|
|
aParams = mozilla::ipc::SameProcessInputStreamParams(
|
|
reinterpret_cast<intptr_t>(thisStream.forget().take()));
|
|
}
|
|
|
|
bool
|
|
FileInputStreamWrapper::Deserialize(const InputStreamParams& /* aParams */,
|
|
const FileDescriptorArray& /* aFDs */)
|
|
{
|
|
MOZ_CRASH("Should never get here!");
|
|
}
|
|
|
|
FileOutputStreamWrapper::FileOutputStreamWrapper(nsISupports* aFileStream,
|
|
FileHelper* aFileHelper,
|
|
uint64_t aOffset,
|
|
uint64_t aLimit,
|
|
uint32_t aFlags)
|
|
: FileStreamWrapper(aFileStream, aFileHelper, aOffset, aLimit, aFlags)
|
|
{
|
|
mOutputStream = do_QueryInterface(mFileStream);
|
|
NS_ASSERTION(mOutputStream, "This should always succeed!");
|
|
}
|
|
|
|
NS_IMPL_ISUPPORTS_INHERITED(FileOutputStreamWrapper,
|
|
FileStreamWrapper,
|
|
nsIOutputStream)
|
|
|
|
NS_IMETHODIMP
|
|
FileOutputStreamWrapper::Close()
|
|
{
|
|
NS_ASSERTION(!NS_IsMainThread(), "Wrong thread!");
|
|
|
|
nsresult rv = NS_OK;
|
|
|
|
if (mFlags & NOTIFY_CLOSE) {
|
|
nsCOMPtr<nsIRunnable> runnable = new CloseRunnable(mFileHelper);
|
|
|
|
if (NS_FAILED(NS_DispatchToMainThread(runnable))) {
|
|
NS_WARNING("Failed to dispatch to the main thread!");
|
|
}
|
|
}
|
|
|
|
mOffset = 0;
|
|
mLimit = 0;
|
|
|
|
return rv;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileOutputStreamWrapper::Write(const char* aBuf, uint32_t aCount,
|
|
uint32_t* _retval)
|
|
{
|
|
NS_ASSERTION(!NS_IsMainThread(), "Wrong thread!");
|
|
|
|
nsresult rv;
|
|
|
|
if (mFirstTime) {
|
|
mFirstTime = false;
|
|
|
|
nsCOMPtr<nsISeekableStream> seekable = do_QueryInterface(mOutputStream);
|
|
if (seekable) {
|
|
if (mOffset == UINT64_MAX) {
|
|
rv = seekable->Seek(nsISeekableStream::NS_SEEK_END, 0);
|
|
}
|
|
else {
|
|
rv = seekable->Seek(nsISeekableStream::NS_SEEK_SET, mOffset);
|
|
}
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
}
|
|
|
|
mOffset = 0;
|
|
}
|
|
|
|
uint64_t max = mLimit - mOffset;
|
|
if (max == 0) {
|
|
*_retval = 0;
|
|
return NS_OK;
|
|
}
|
|
|
|
if (aCount > max) {
|
|
aCount = max;
|
|
}
|
|
|
|
rv = mOutputStream->Write(aBuf, aCount, _retval);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
mOffset += *_retval;
|
|
|
|
if (mFlags & NOTIFY_PROGRESS) {
|
|
nsCOMPtr<nsIRunnable> runnable =
|
|
new ProgressRunnable(mFileHelper, mOffset, mLimit);
|
|
|
|
NS_DispatchToMainThread(runnable);
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileOutputStreamWrapper::Flush()
|
|
{
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileOutputStreamWrapper::WriteFrom(nsIInputStream* aFromStream,
|
|
uint32_t aCount, uint32_t* _retval)
|
|
{
|
|
return NS_ERROR_NOT_IMPLEMENTED;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileOutputStreamWrapper::WriteSegments(nsReadSegmentFun aReader,
|
|
void* aClosure, uint32_t aCount,
|
|
uint32_t* _retval)
|
|
{
|
|
return NS_ERROR_NOT_IMPLEMENTED;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
FileOutputStreamWrapper::IsNonBlocking(bool* _retval)
|
|
{
|
|
*_retval = false;
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMPL_ISUPPORTS(ProgressRunnable, nsIRunnable)
|
|
|
|
NS_IMETHODIMP
|
|
ProgressRunnable::Run()
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
mFileHelper->OnStreamProgress(mProgress, mProgressMax);
|
|
mFileHelper = nullptr;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMPL_ISUPPORTS(CloseRunnable, nsIRunnable)
|
|
|
|
NS_IMETHODIMP
|
|
CloseRunnable::Run()
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
mFileHelper->OnStreamClose();
|
|
mFileHelper = nullptr;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMPL_ISUPPORTS(DestroyRunnable, nsIRunnable)
|
|
|
|
NS_IMETHODIMP
|
|
DestroyRunnable::Run()
|
|
{
|
|
NS_ASSERTION(NS_IsMainThread(), "Wrong thread!");
|
|
|
|
mFileHelper->OnStreamDestroy();
|
|
mFileHelper = nullptr;
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|