mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 23:06:52 +00:00
b3d6afc844
- bits of Bug 571294 - Part 1: Implement selection events (8af4ef3f65) - Bug 1208885 - Remove mozGenericWordUtils; r=smaug (b1a529f772) - fix nsRefPtr/RefPtr (c56979e04d) - Bug 1243657 spellchecker should check if IME composition works as deleting whole text r=ehsan (8b4d4825b9) - Bug 1137544 - New scripts to upgrade en-US.dic to the latest upstream version; r=ehsan (47150b3549) - Bug 1137544 - Upgrade en-US.dic dictionary to upstream version 2015.02.15; r=ehsan (057540f06b) - Bug 1137544 - Generate 5-mozilla-added and 5-mozilla-removed to aid in submitting changes upstream; r=ehsan (f0d6332df3) - Bug 1137544 - Update the en-US dictionary based on the SCOWL 2015.04.24 wordlist using the new scripts (e87b0a0285) - minor test alignment (f3e976adf2) - Bug 1162823 - Do not treat non-Latin words as misspelled; r=ekanan (c298db7251) - Bug 1160730 - Add composited, compositing and compositeness to the en-US dictionary. r=ehsan (7d62babbdb) - Bug 1167912 - Add eldritch to the en-US dictionary. r=ehsan (4d1e08e03b) - Bug 1168802 - Update the en-US dictionary to SCOWL 2015.05.18 (3daa6d0831) - Bug 1183765 - Add crappiness to our en-US dictionary. r=ehsan (54ccd28fa2) - Bug 1192054 - Add subsumption to the en-US dictionary. r=ehsan (8c5aaa92bc) - Bug 1199540 - Update the en-US dictionary to SCOWL 2015.08.24 (cb21d0092d) - Bug 1200508 - Add dialogs to the en-US dictionary. r=ehsan (1e69b4d574) - Bug 1202600 - Add Fukushima to the en-US dictionary. r=ehsan (6ffca1c47b) - Bug 1213765 - Add preliminarily to the en-US dictionary. r=ehsan (cb12d4979b) - Bug 1228174 - Add validator to the en-US dictionary. r=ehsan (b356d7f5cb) - Bug 1199532 - Add disassembly, disassembler to the en-US dictionary. r=ehsan (979bb4f997) - Bug 1235506 - Correct 353 entries in the en-US dictionary. r=ehsan (efb2f4a890) - Bug 1238031 - Fix make-new-dict to use a custom en_US dictionary that adds common variants and accented words. r=ehsan (39464a234f) - Bug 301712 - Remove uncommon proper names, remove unneeded words. r=ehsan (a6ece3925f) - Bug 1240916 - Part 2: Update the en-US dictionary to SCOWL 2016.01.19 (bb059318e5) - Bug 1250430 - Remove SrcDir loader support from devtools. r=jryans (0e77cbd85f) - Bug 1209699 - Add a 'Push' button for service workers in about:debugging. r=jdescottes (a59c681ad1) - Bug 1247203 - Remove useless call to main(). r=jryans (e89b21e72c) - Bug 1247203 - Do not hardcode main module path in Loader.jsm. r=jryans (01d4ca73cc) - Bug 1255266 - create sandbox with system principal. r=jryans,khuey. (0ac3a41816) - Bug 1240804 - Use common instance of Promise.jsm for test harness promise rejection handling. r=ochameau (5f5383e721) - Bug 1248603 - Factor out menu and shortcut creation to dedicated module. r=jryans (2e19c46dba) - Bug 1248603 - Remove support of the appmenu from devtools. r=jryans (3f25c2b181) - Bug 1248603 - Toggle developer toolbar via the menuitem in tests. r=jryans (01d9940116) - bits of Bug 1248603 - Toggle developer toolbar (e062489e6b) - Bug 1248601 - Register the Developer Toolbar dynamically. r=jwalker (d5e63b9e4b) - missing bit of 878412 - Use F12 to open the Toolbox (43c193a82a) - Bug 1252479 - Adding the Developer Dynamically (Bug 1248601) doesn't work in SeaMonkey because it doesn't have a "browser-bottombox" r=ochameau (49fb6e1f17) - Bug 1248601 - Fix focus race due to dynamic XUL insertion. r=jwalker (35831fd629) - Bug 1257178 - Prevent "this._input is undefined" exception when developer toolbar is hidden early. r=jwalker (a8c308acd2) - Bug 1250120 - Change name to Responsive Design Mode in Tools -> Web Developer menu r=jryans (3575acecb2) - Bug 1239317 - Add a Service Workers entry to the Web Developer menu. r=jryans (ce975756b3) - Bug 1219804 - Show last 5 recent bookmarks in the bookmarks menu. r=mak (cfad5e41b2) - Bug 1259398 - Make devtools file-watcher module more generic to watch any directory. r=jlongster (4d37fbf76e) - Bug 1236452 - Fix DOMHelpers.onceDOMReady against already loaded documents. r=jryans (7abfab41c0) - Bug 1259241 - Update demangling library to 1.0.1 to fix a memory leak. r=fitzgen (77450e478c) - Bug 1261092 - Simplify gcli initialization/destruction codepaths. r=jryans,jwalker (b8648df9f1) - Bug 1258309 - Pull ViewHelpers.Prefs into its own module, r=jsantell (2fe2251e2a) - Bug 1260711 - Fix error 'IndexSizeError: Index or size is negative or greater than the allowed amount' when using the animation inspector. r=pbro (4d2508de75) - Bug 1235698 - Increase the timeout of browser_animation_timeline_shows_time_info.js (ae143a305e) - Bug 1253493 - Part1: Show iterationStart to the tooltip. r=pbro (00d72ea7b0) - Bug 1253493 - Part2: Show iterationStart to the GUI. r=pbro (1a5c1c4a93) - Bug 1253494 part 1 - Implement endDelay representation in the animation inspector r=pbro (f5b08cd11d) - Bug 1253494 part 2 - Add tests for endDelay representation r=pbro (d9acd667d8) - Bug 1261561 - Part 1: Fix TimeScale.getAnimationDimensions() to handle multiple iterations. r=pbro (0a1e13cbc9) - Bug 1261561 - Part 2: Add a xpcshell test for TimeScale.getAnimationDimensions(). r=pbro (71a832f3db) - Bug 1168246 - part1: CSS autocomplete picks most popular prop;r=pbrosset (8c9989abd3) - Bug 1168246 - part3: ES lint fixes for inplace-editor and autocomplete-popup;r=pbrosset (66d113f0e2) - Bug 1151413 - Set async caller in DevToolsUtils.executeSoon r=ejpbruel (aa5ee4cbdb) - Bug 1234600 - executeSoon async stacks only when DEBUG_JS_MODULES enabled. r=fitzgen (5e4f771a7a) - Bug 1219028 - Remove use of non-standard Function.prototype.isGenerator from devtools/. r=fitzgen (34327590e6) - Bug 1235458 - Move a bunch of utilities from DevToolsUtils to ThreadSafeDevToolsUtils. r=jsantell (333e190b17) - Bug 1205095 - Unwrap getters in DevToolsUtils.hasSafeGetter. (r=fitzgen) (784e678e66) - Bug 1260589 - Add the ThreadSafeDevToolsUtils.flatten utility; r=jimb a=kwierso (c82b27da22) - Bug 1260938 - Add the ThreadSafeDevToolsUtils.isSet utility; r=jimb a=kwierso (9d5601a39e) - Bug 1262225 - Add actorID to worker fake parent ThreadActor. r=ejpbruel (7e6f761dba) - Bug 1239705 - Add a 'Start' button for service workers in about:debugging. r=ochameau (8bdea0c588) - Bug 1196784 - imageset will use permissions.default.image. r=jdm (9a5669f71f) - Bug 1182727 - Part 16: Fix a bug in build_tar_package (1d8f444eba) - Bug 1182727 - Part 18: Fix building clang on OSX 10.8 and older (a02e1baca5) - Bug 1182727 - Part 19: Fix another stupid mistake in build_tar_package() (87bb241693) - Bug 1261264 - Apply GCC PR64905 to fix miscompilation with -fomit-frame-pointer. r=froydnj (d746a0c878) - missing option, for safety (6fba93dff9) - Bug 1260605 - Remove hack from bug 967556. r=nalexander (9513dbcd26) - Bug 1239789 - Add secondary buffers to zxx_stream::StaticAllocator to handle reentrancy. r=glandium (74b60ffaad) - Bug 1260351 - MozGlue: Build: Add mips support. r=glandium (8a463032f6) - Bug 1249849: Ensure that we can always reach malloc_decl.h even when MOZ_REPLACE_ALLOC is not defined; r=glandium (1a8d0356ac) - Bug 1248915 - TSan: data race on global 'mozilla::net::CacheObserver::sDiskCacheCapacity'. r=honzab.moz, n.nethercote. (86769cd893) - Bug 1249157 - prefapi enums into class enums, explicit conversion, cleanup. r=bsmedberg (1843c09593) - Bug 1251393: Remove a duplicated line. r=me (c2bca1a4f4)
216 lines
7.9 KiB
JavaScript
216 lines
7.9 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";
|
|
|
|
var Cu = Components.utils;
|
|
const loaders = Cu.import("resource://gre/modules/commonjs/toolkit/loader.js", {});
|
|
const { devtools } = Cu.import("resource://devtools/shared/Loader.jsm", {});
|
|
const { joinURI } = devtools.require("devtools/shared/path");
|
|
const { assert } = devtools.require("devtools/shared/DevToolsUtils");
|
|
const Services = devtools.require("Services");
|
|
Cu.import("resource://gre/modules/AppConstants.jsm");
|
|
|
|
const BROWSER_BASED_DIRS = [
|
|
"resource://devtools/client/jsonview",
|
|
"resource://devtools/client/shared/vendor",
|
|
"resource://devtools/client/shared/components",
|
|
"resource://devtools/client/shared/redux"
|
|
];
|
|
|
|
function clearCache() {
|
|
Services.obs.notifyObservers(null, "startupcache-invalidate", null);
|
|
}
|
|
|
|
/*
|
|
* Create a loader to be used in a browser environment. This evaluates
|
|
* modules in their own environment, but sets window (the normal
|
|
* global object) as the sandbox prototype, so when a variable is not
|
|
* defined it checks `window` before throwing an error. This makes all
|
|
* browser APIs available to modules by default, like a normal browser
|
|
* environment, but modules are still evaluated in their own scope.
|
|
*
|
|
* Another very important feature of this loader is that it *only*
|
|
* deals with modules loaded from under `baseURI`. Anything loaded
|
|
* outside of that path will still be loaded from the devtools loader,
|
|
* so all system modules are still shared and cached across instances.
|
|
* An exception to this is anything under
|
|
* `devtools/client/shared/{vendor/components}`, which is where shared libraries
|
|
* and React components live that should be evaluated in a browser environment.
|
|
*
|
|
* @param string baseURI
|
|
* Base path to load modules from. If null or undefined, only
|
|
* the shared vendor/components modules are loaded with the browser
|
|
* loader.
|
|
* @param Object window
|
|
* The window instance to evaluate modules within
|
|
* @param Boolean useOnlyShared
|
|
* If true, ignores `baseURI` and only loads the shared
|
|
* BROWSER_BASED_DIRS via BrowserLoader.
|
|
* @return Object
|
|
* An object with two properties:
|
|
* - loader: the Loader instance
|
|
* - require: a function to require modules with
|
|
*/
|
|
function BrowserLoader(options) {
|
|
const browserLoaderBuilder = new BrowserLoaderBuilder(options);
|
|
return {
|
|
loader: browserLoaderBuilder.loader,
|
|
require: browserLoaderBuilder.require
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Private class used to build the Loader instance and require method returned
|
|
* by BrowserLoader(baseURI, window).
|
|
*
|
|
* @param string baseURI
|
|
* Base path to load modules from.
|
|
* @param Object window
|
|
* The window instance to evaluate modules within
|
|
* @param Boolean useOnlyShared
|
|
* If true, ignores `baseURI` and only loads the shared
|
|
* BROWSER_BASED_DIRS via BrowserLoader.
|
|
*/
|
|
function BrowserLoaderBuilder({ baseURI, window, useOnlyShared }) {
|
|
assert(!!baseURI !== !!useOnlyShared,
|
|
"Cannot use both `baseURI` and `useOnlyShared`.");
|
|
|
|
const loaderOptions = devtools.require("@loader/options");
|
|
const dynamicPaths = {};
|
|
const componentProxies = new Map();
|
|
|
|
if (AppConstants.DEBUG || AppConstants.DEBUG_JS_MODULES) {
|
|
dynamicPaths["devtools/client/shared/vendor/react"] =
|
|
"resource://devtools/client/shared/vendor/react-dev";
|
|
}
|
|
|
|
const opts = {
|
|
id: "browser-loader",
|
|
sharedGlobal: true,
|
|
sandboxPrototype: window,
|
|
paths: Object.assign({}, dynamicPaths, loaderOptions.paths),
|
|
invisibleToDebugger: loaderOptions.invisibleToDebugger,
|
|
requireHook: (id, require) => {
|
|
const uri = require.resolve(id);
|
|
const isBrowserDir = BROWSER_BASED_DIRS.filter(dir => {
|
|
return uri.startsWith(dir);
|
|
}).length > 0;
|
|
|
|
if ((useOnlyShared || !uri.startsWith(baseURI)) && !isBrowserDir) {
|
|
return devtools.require(uri);
|
|
}
|
|
|
|
return require(uri);
|
|
},
|
|
globals: {
|
|
// Allow modules to use the window's console to ensure logs appear in a
|
|
// tab toolbox, if one exists, instead of just the browser console.
|
|
console: window.console,
|
|
// Make sure `define` function exists. This allows defining some modules
|
|
// in AMD format while retaining CommonJS compatibility through this hook.
|
|
// JSON Viewer needs modules in AMD format, as it currently uses RequireJS
|
|
// from a content document and can't access our usual loaders. So, any
|
|
// modules shared with the JSON Viewer should include a define wrapper:
|
|
//
|
|
// // Make this available to both AMD and CJS environments
|
|
// define(function(require, exports, module) {
|
|
// ... code ...
|
|
// });
|
|
//
|
|
// Bug 1248830 will work out a better plan here for our content module
|
|
// loading needs, especially as we head towards devtools.html.
|
|
define(factory) {
|
|
factory(this.require, this.exports, this.module);
|
|
},
|
|
// Allow modules to use the DevToolsLoader lazy loading helpers.
|
|
loader: {
|
|
lazyGetter: devtools.lazyGetter,
|
|
lazyImporter: devtools.lazyImporter,
|
|
lazyServiceGetter: devtools.lazyServiceGetter,
|
|
lazyRequireGetter: this.lazyRequireGetter.bind(this),
|
|
},
|
|
}
|
|
};
|
|
|
|
if (Services.prefs.getBoolPref("devtools.loader.hotreload")) {
|
|
opts.loadModuleHook = (module, require) => {
|
|
const { uri, exports } = module;
|
|
|
|
if (exports.prototype &&
|
|
exports.prototype.isReactComponent) {
|
|
const { createProxy, getForceUpdate } =
|
|
require("devtools/client/shared/vendor/react-proxy");
|
|
const React = require("devtools/client/shared/vendor/react");
|
|
|
|
if (!componentProxies.get(uri)) {
|
|
const proxy = createProxy(exports);
|
|
componentProxies.set(uri, proxy);
|
|
module.exports = proxy.get();
|
|
}
|
|
else {
|
|
const proxy = componentProxies.get(uri);
|
|
const instances = proxy.update(exports);
|
|
instances.forEach(getForceUpdate(React));
|
|
module.exports = proxy.get();
|
|
}
|
|
}
|
|
return exports;
|
|
}
|
|
const watcher = devtools.require("devtools/client/shared/devtools-file-watcher");
|
|
let onFileChanged = (_, relativePath, path) => {
|
|
this.hotReloadFile(componentProxies, "resource://devtools/" + relativePath);
|
|
};
|
|
watcher.on("file-changed", onFileChanged);
|
|
window.addEventListener("unload", () => {
|
|
watcher.off("file-changed", onFileChanged);
|
|
});
|
|
}
|
|
|
|
const mainModule = loaders.Module(baseURI, joinURI(baseURI, "main.js"));
|
|
this.loader = loaders.Loader(opts);
|
|
this.require = loaders.Require(this.loader, mainModule);
|
|
}
|
|
|
|
BrowserLoaderBuilder.prototype = {
|
|
/**
|
|
* Define a getter property on the given object that requires the given
|
|
* module. This enables delaying importing modules until the module is
|
|
* actually used.
|
|
*
|
|
* @param Object obj
|
|
* The object to define the property on.
|
|
* @param String property
|
|
* The property name.
|
|
* @param String module
|
|
* The module path.
|
|
* @param Boolean destructure
|
|
* Pass true if the property name is a member of the module's exports.
|
|
*/
|
|
lazyRequireGetter: function(obj, property, module, destructure) {
|
|
devtools.lazyGetter(obj, property, () => {
|
|
return destructure
|
|
? this.require(module)[property]
|
|
: this.require(module || property);
|
|
});
|
|
},
|
|
|
|
hotReloadFile: function(componentProxies, fileURI) {
|
|
if (fileURI.match(/\.js$/)) {
|
|
// Test for React proxy components
|
|
const proxy = componentProxies.get(fileURI);
|
|
if (proxy) {
|
|
// Remove the old module and re-require the new one; the require
|
|
// hook in the loader will take care of the rest
|
|
delete this.loader.modules[fileURI];
|
|
clearCache();
|
|
this.require(fileURI);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
this.BrowserLoader = BrowserLoader;
|
|
|
|
this.EXPORTED_SYMBOLS = ["BrowserLoader"];
|