mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 05:11:03 +00:00
b6d6258762
- Bug 1182537 - Use channel->ascynOpen2 in dom/security/nsCORSListenerProxy (r=sicking) (5c4b779a12) - Bug 1155758 - Make about:serviceworkers work in B2G. r=fabrice (195eca3894) - Bug 1162920 - JavaScript error at aboutServiceWorkers.js when updating the service worker. r=fabrice (2d3a831a8c) - Bug 1155153 - [e10s] about:serviceworkers should work in e10s mode. Update B2G implementation. r=baku (0d1c2999c1) - Bug 1171915 - about:serviceworkers in b2g should use originAttributes when calling ServiceWorkerManager. r=baku,fabrice (faa3725da9) - Bug 1179161 - originAttributes does not have such isInBrowser member (follow-up bug 1171915). r=ferjm (a217140ae5) - Bug 1171917 - Improve about:serviceworkers tests on b2g. r=ferjm (5fd9d2f478) - Bug 1179557 - Add userContextId to originAttributes with tests. r=bholley, r=tanvi (8ddf96d921) - Bug 1179557 - Add getters for userContextId. r=bholley, r=tanvi (ebec5f7c7e) - Bug 1174110 - The service worker still remains registered when uninstalling the service-worker-enabled application. r=fabrice (c1c93b1250) - Bug 1144689 - Allow setting manually a fetch time and modified time for cache entries. r=fabrice (8e9dd47425) - Bug 1150199 - Langpacks should not have to be privileged r=ferjm (d41af25648) - Bug 1111961 - Developer mode support r=ferjm,pauljt (9b523402ac) - Bug 1168300 - notify clear-cookiejar-data. r=sicking (7d88bff29d) - Bug 1136434 - RequestSync API should delete all the timers when a task is unregistered, r=ehsan (5f92977920) - Bug 1151082 - RequestSyncAPI - avoid infinite loop when processing pending messages, r=ehsan (b5afcd55e8) - Bug 1165787 - Use origin in RequestSyncService.jsm. r=ehsan (b6fad2bd68) - Bug 1182347 - Migrate existing code away from .cookieJar. r=sicking,r=allstars.chh (304cbfd660) - Bug 1118946 - API to provide localized properties r=ferjm,sicking (a28aecaf19) - Bug 1077168 - Cancel in-flight Webapp install jobs from windows that change location. r=myk. (d55dc8ff6d) - Bug 1150660 - Fix sendAsyncMessage() uses to not trigger warnings in dom/apps r=fabrice (b087adcc23) - Bug 1169344 - Allow server apps to restrict access to their IAC ports. r=ferjm (82c8570555) - Bug 1068400 - Fix devtools when morphing non-e10s tab into e10s one. r=jryans (55be5ccdf5) - Bug 1145049 - Prevent caching tab actors in child processes. r=jryans (1a3ee9f278) - Bug 1145049 - Stop leaking tab actors and root actor on disconnect. r=jryans (26f259b441) - Bug 1181930 - Refactoring: move the message broadcaster out of Webapps.jsm r=ferjm (b1f8bb8b6d) - Bu 1115619 - Use a preference to guarantee app permission loading to permissions.sqlite. r=fabrice (5689c459d7) - Bug 1191579 - Remove useless getAll() implementation in Webapps.jsm (74f0d6874a)
116 lines
3.8 KiB
JavaScript
116 lines
3.8 KiB
JavaScript
/* 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/. */
|
|
|
|
"use strict";
|
|
|
|
try {
|
|
|
|
let chromeGlobal = this;
|
|
|
|
// Encapsulate in its own scope to allows loading this frame script
|
|
// more than once.
|
|
(function () {
|
|
let Cu = Components.utils;
|
|
let { devtools } = Cu.import("resource://gre/modules/devtools/Loader.jsm", {});
|
|
const DevToolsUtils = devtools.require("devtools/toolkit/DevToolsUtils.js");
|
|
const { dumpn } = DevToolsUtils;
|
|
const { DebuggerServer, ActorPool } = Cu.import("resource://gre/modules/devtools/dbg-server.jsm", {});
|
|
|
|
if (!DebuggerServer.initialized) {
|
|
DebuggerServer.init();
|
|
|
|
// message manager helpers provided for actor module parent/child message exchange
|
|
DebuggerServer.parentMessageManager = {
|
|
sendSyncMessage: sendSyncMessage,
|
|
addMessageListener: addMessageListener
|
|
};
|
|
}
|
|
|
|
// In case of apps being loaded in parent process, DebuggerServer is already
|
|
// initialized, but child specific actors are not registered.
|
|
// Otherwise, for apps in child process, we need to load actors the first
|
|
// time we load child.js
|
|
DebuggerServer.addChildActors();
|
|
|
|
let connections = new Map();
|
|
|
|
let onConnect = DevToolsUtils.makeInfallible(function (msg) {
|
|
removeMessageListener("debug:connect", onConnect);
|
|
|
|
let mm = msg.target;
|
|
let prefix = msg.data.prefix;
|
|
|
|
let conn = DebuggerServer.connectToParent(prefix, mm);
|
|
connections.set(prefix, conn);
|
|
|
|
let actor = new DebuggerServer.ContentActor(conn, chromeGlobal, prefix);
|
|
let actorPool = new ActorPool(conn);
|
|
actorPool.addActor(actor);
|
|
conn.addActorPool(actorPool);
|
|
|
|
sendAsyncMessage("debug:actor", {actor: actor.form(), prefix: prefix});
|
|
});
|
|
|
|
addMessageListener("debug:connect", onConnect);
|
|
|
|
// Allows executing module setup helper from the parent process.
|
|
// See also: DebuggerServer.setupInChild()
|
|
let onSetupInChild = DevToolsUtils.makeInfallible(msg => {
|
|
let { module, setupChild, args } = msg.data;
|
|
let m, fn;
|
|
|
|
try {
|
|
m = devtools.require(module);
|
|
|
|
if (!(setupChild in m)) {
|
|
dumpn("ERROR: module '" + module + "' does not export '" +
|
|
setupChild + "'");
|
|
return false;
|
|
}
|
|
|
|
m[setupChild].apply(m, args);
|
|
|
|
return true;
|
|
} catch(e) {
|
|
let error_msg = "exception during actor module setup running in the child process: ";
|
|
DevToolsUtils.reportException(error_msg + e);
|
|
dumpn("ERROR: " + error_msg + " \n\t module: '" + module +
|
|
"' \n\t setupChild: '" + setupChild + "'\n" +
|
|
DevToolsUtils.safeErrorString(e));
|
|
return false;
|
|
}
|
|
});
|
|
|
|
addMessageListener("debug:setup-in-child", onSetupInChild);
|
|
|
|
let onDisconnect = DevToolsUtils.makeInfallible(function (msg) {
|
|
removeMessageListener("debug:disconnect", onDisconnect);
|
|
|
|
// Call DebuggerServerConnection.close to destroy all child actors
|
|
// (It should end up calling DebuggerServerConnection.onClosed
|
|
// that would actually cleanup all actor pools)
|
|
let prefix = msg.data.prefix;
|
|
let conn = connections.get(prefix);
|
|
if (conn) {
|
|
conn.close();
|
|
connections.delete(prefix);
|
|
}
|
|
});
|
|
addMessageListener("debug:disconnect", onDisconnect);
|
|
|
|
let onInspect = DevToolsUtils.makeInfallible(function(msg) {
|
|
// Store the node to be inspected in a global variable
|
|
// (gInspectingNode). Later we'll fetch this variable again using
|
|
// the findInspectingNode request over the remote debugging
|
|
// protocol.
|
|
let inspector = devtools.require("devtools/server/actors/inspector");
|
|
inspector.setInspectingNode(msg.objects.node);
|
|
});
|
|
addMessageListener("debug:inspect", onInspect);
|
|
})();
|
|
|
|
} catch(e) {
|
|
dump("Exception in app child process: " + e + "\n");
|
|
}
|