2018-11-30 22:52:05 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2018-11-30 18:39:55 +03:00
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
2017-05-03 03:17:52 +03:00
|
|
|
/* 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 "mozilla/ScriptPreloader.h"
|
|
|
|
#include "ScriptPreloader-inl.h"
|
|
|
|
#include "mozilla/loader/ScriptCacheActors.h"
|
|
|
|
|
|
|
|
#include "mozilla/dom/ContentParent.h"
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace loader {
|
|
|
|
|
|
|
|
void ScriptCacheChild::Init(const Maybe<FileDescriptor>& cacheFile,
|
|
|
|
bool wantCacheData) {
|
|
|
|
mWantCacheData = wantCacheData;
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2017-05-03 03:17:52 +03:00
|
|
|
auto& cache = ScriptPreloader::GetChildSingleton();
|
|
|
|
Unused << cache.InitCache(cacheFile, this);
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2017-05-03 03:17:52 +03:00
|
|
|
if (!wantCacheData) {
|
|
|
|
// If the parent process isn't expecting any cache data from us, we're
|
|
|
|
// done.
|
|
|
|
Send__delete__(this, AutoTArray<ScriptData, 0>());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Finalize the script cache for the content process, and send back data about
|
|
|
|
// any scripts executed up to this point.
|
2017-05-14 08:43:08 +03:00
|
|
|
void ScriptCacheChild::SendScriptsAndFinalize(
|
|
|
|
ScriptPreloader::ScriptHash& scripts) {
|
2017-05-03 03:17:52 +03:00
|
|
|
MOZ_ASSERT(mWantCacheData);
|
|
|
|
|
|
|
|
AutoSafeJSAPI jsapi;
|
|
|
|
|
2017-05-14 08:43:08 +03:00
|
|
|
auto matcher = ScriptPreloader::Match<ScriptPreloader::ScriptStatus::Saved>();
|
|
|
|
|
2017-05-03 03:17:52 +03:00
|
|
|
nsTArray<ScriptData> dataArray;
|
2017-05-14 08:43:08 +03:00
|
|
|
for (auto& script : IterHash(scripts, matcher)) {
|
2017-05-03 03:17:52 +03:00
|
|
|
if (!script->mSize && !script->XDREncode(jsapi.cx())) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto data = dataArray.AppendElement();
|
|
|
|
|
|
|
|
data->url() = script->mURL;
|
|
|
|
data->cachePath() = script->mCachePath;
|
2017-05-14 00:08:42 +03:00
|
|
|
data->loadTime() = script->mLoadTime;
|
2017-05-03 03:17:52 +03:00
|
|
|
|
|
|
|
if (script->HasBuffer()) {
|
|
|
|
auto& xdrData = script->Buffer();
|
|
|
|
data->xdrData().AppendElements(xdrData.begin(), xdrData.length());
|
|
|
|
script->FreeData();
|
|
|
|
}
|
2018-11-30 13:46:48 +03:00
|
|
|
}
|
2017-05-03 03:17:52 +03:00
|
|
|
|
|
|
|
Send__delete__(this, dataArray);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ScriptCacheChild::ActorDestroy(ActorDestroyReason aWhy) {
|
|
|
|
auto& cache = ScriptPreloader::GetChildSingleton();
|
|
|
|
cache.mChildActor = nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
IPCResult ScriptCacheParent::Recv__delete__(nsTArray<ScriptData>&& scripts) {
|
|
|
|
if (!mWantCacheData && scripts.Length()) {
|
|
|
|
return IPC_FAIL(this, "UnexpectedScriptData");
|
2018-11-30 13:46:48 +03:00
|
|
|
}
|
2017-05-03 03:17:52 +03:00
|
|
|
|
|
|
|
// We don't want any more data from the process at this point.
|
|
|
|
mWantCacheData = false;
|
|
|
|
|
|
|
|
// Merge the child's script data with the parent's.
|
|
|
|
auto parent = static_cast<dom::ContentParent*>(Manager());
|
|
|
|
auto processType =
|
|
|
|
ScriptPreloader::GetChildProcessType(parent->GetRemoteType());
|
|
|
|
|
|
|
|
auto& cache = ScriptPreloader::GetChildSingleton();
|
|
|
|
for (auto& script : scripts) {
|
|
|
|
cache.NoteScript(script.url(), script.cachePath(), processType,
|
2018-05-30 22:15:35 +03:00
|
|
|
std::move(script.xdrData()), script.loadTime());
|
2017-05-03 03:17:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return IPC_OK();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ScriptCacheParent::ActorDestroy(ActorDestroyReason aWhy) {}
|
|
|
|
|
|
|
|
} // namespace loader
|
|
|
|
} // namespace mozilla
|