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".
30 lines
877 B
JavaScript
30 lines
877 B
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");
|
|
|
|
exports.items = [{
|
|
name: "inspect",
|
|
description: gcli.lookup("inspectDesc"),
|
|
manual: gcli.lookup("inspectManual"),
|
|
params: [
|
|
{
|
|
name: "selector",
|
|
type: "node",
|
|
description: gcli.lookup("inspectNodeDesc"),
|
|
manual: gcli.lookup("inspectNodeManual")
|
|
}
|
|
],
|
|
exec: function(args, context) {
|
|
let target = context.environment.target;
|
|
let gDevTools = require("resource:///modules/devtools/gDevTools.jsm").gDevTools;
|
|
|
|
return gDevTools.showToolbox(target, "inspector").then(toolbox => {
|
|
toolbox.getCurrentPanel().selection.setNode(args.selector, "gcli");
|
|
});
|
|
}
|
|
}];
|