BuiltinCommands.jsm was huge to avoid slowing things down by having many modules loading. To avoid splitting it up from slowing things down we want to delay loading commands. Create [add|remove]ItemsByModule to allow us to lazily add modules, and convert all command modules to use this. Then break up BuiltinCommands into a set of files, for each command, and do some refactoring to use JS files rather than JSMs and use "use strict".
100 lines
2.7 KiB
JavaScript
100 lines
2.7 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";
|
|
|
|
const gcli = require("gcli/index");
|
|
const EventEmitter = require("devtools/toolkit/event-emitter");
|
|
const { gDevTools } = require("resource:///modules/devtools/gDevTools.jsm");
|
|
|
|
const eventEmitter = new EventEmitter();
|
|
|
|
gDevTools.on("toolbox-ready", (e, toolbox) => {
|
|
if (!toolbox.target) {
|
|
return;
|
|
}
|
|
|
|
let fireChangeForTab = () => {
|
|
eventEmitter.emit("changed", toolbox.target.tab);
|
|
};
|
|
|
|
toolbox.on("split-console", fireChangeForTab);
|
|
toolbox.on("select", fireChangeForTab);
|
|
|
|
toolbox.once("destroyed", () => {
|
|
toolbox.off("split-console", fireChangeForTab);
|
|
toolbox.off("select", fireChangeForTab);
|
|
});
|
|
});
|
|
|
|
exports.items = [
|
|
{
|
|
name: 'splitconsole',
|
|
hidden: true,
|
|
buttonId: "command-button-splitconsole",
|
|
buttonClass: "command-button command-button-invertable",
|
|
tooltipText: gcli.lookup("splitconsoleTooltip"),
|
|
state: {
|
|
isChecked: function(target) {
|
|
let toolbox = gDevTools.getToolbox(target);
|
|
return toolbox && toolbox.splitConsole;
|
|
},
|
|
onChange: function(target, changeHandler) {
|
|
eventEmitter.on("changed", changeHandler);
|
|
},
|
|
offChange: function(target, changeHandler) {
|
|
eventEmitter.off("changed", changeHandler);
|
|
},
|
|
},
|
|
exec: function(args, context) {
|
|
let target = context.environment.target;
|
|
let toolbox = gDevTools.getToolbox(target);
|
|
|
|
if (!toolbox) {
|
|
return gDevTools.showToolbox(target, "inspector").then((toolbox) => {
|
|
toolbox.toggleSplitConsole();
|
|
});
|
|
} else {
|
|
toolbox.toggleSplitConsole();
|
|
}
|
|
}
|
|
},
|
|
{
|
|
name: "console",
|
|
description: gcli.lookup("consoleDesc"),
|
|
manual: gcli.lookup("consoleManual")
|
|
},
|
|
{
|
|
name: "console clear",
|
|
description: gcli.lookup("consoleclearDesc"),
|
|
exec: function(args, context) {
|
|
let toolbox = gDevTools.getToolbox(context.environment.target);
|
|
if (toolbox == null) {
|
|
return;
|
|
}
|
|
|
|
let panel = toolbox.getPanel("webconsole");
|
|
if (panel == null) {
|
|
return;
|
|
}
|
|
|
|
panel.hud.jsterm.clearOutput();
|
|
}
|
|
},
|
|
{
|
|
name: "console close",
|
|
description: gcli.lookup("consolecloseDesc"),
|
|
exec: function(args, context) {
|
|
return gDevTools.closeToolbox(context.environment.target);
|
|
}
|
|
},
|
|
{
|
|
name: "console open",
|
|
description: gcli.lookup("consoleopenDesc"),
|
|
exec: function(args, context) {
|
|
return gDevTools.showToolbox(context.environment.target, "webconsole");
|
|
}
|
|
}
|
|
];
|