fune/toolkit/actors/ControllersChild.jsm
Ian Moody 011b59d595 Bug 1536556 - Replace raw thrown Cr.ERRORs with Components.Exception. r=mossop,remote-protocol-reviewers,marionette-reviewers,whimboo,necko-reviewers,geckoview-reviewers,valentin,agi
Raw Cr.ERROR don't get stack information, same as throwing JS literals instead
of `new Error()`s.

This was done automatically with a new eslint rule that will be introduced in
the next commit.  One instance of a raw Cr.ERROR was not replaced since it is
used in a test that specifically checks the preservation of raw Cr values in
XPCJS.  The rule will be disabled for that instance.

Differential Revision: https://phabricator.services.mozilla.com/D28073
2020-05-05 17:41:36 +00:00

35 lines
1.2 KiB
JavaScript

/* vim: set ts=2 sw=2 sts=2 et tw=80: */
/* 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 EXPORTED_SYMBOLS = ["ControllersChild"];
class ControllersChild extends JSWindowActorChild {
receiveMessage(message) {
switch (message.name) {
case "ControllerCommands:Do":
if (this.docShell && this.docShell.isCommandEnabled(message.data)) {
this.docShell.doCommand(message.data);
}
break;
case "ControllerCommands:DoWithParams":
var data = message.data;
if (this.docShell && this.docShell.isCommandEnabled(data.cmd)) {
var params = Cu.createCommandParams();
for (var name in data.params) {
var value = data.params[name];
if (value.type == "long") {
params.setLongValue(name, parseInt(value.value));
} else {
throw Components.Exception("", Cr.NS_ERROR_NOT_IMPLEMENTED);
}
}
this.docShell.doCommandWithParams(data.cmd, params);
}
break;
}
}
}