fune/devtools/shared/validate-breakpoint.jsm
Alexandre Poirot 79a3ae0b0f Bug 1720512 - [devtools] Avoid storing and restoring broken breakpoints. r=jdescottes,bomsy
This is a bit surprising that broken breakpoints are stored
as the frontend seems to try to do a couple of assertions:
https://searchfox.org/mozilla-central/rev/c0fc8c4852e927b0ae75d893d35772b8c60ee06b/devtools/client/debugger/src/utils/breakpoint/index.js#84-106

But at least, now, we start using same assertions in both sides.

Differential Revision: https://phabricator.services.mozilla.com/D120002
2021-07-19 15:30:34 +00:00

49 lines
1.6 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";
// Because this function is used from WatchedDataHelpers.jsm,
// this has to be a JSM.
var EXPORTED_SYMBOLS = ["validateBreakpointLocation"];
/**
* Given a breakpoint location object, throws if the breakpoint look invalid
*/
function validateBreakpointLocation({ sourceUrl, sourceId, line, column }) {
if (!sourceUrl && !sourceId) {
throw new Error(
`Breakpoints expect to have either a sourceUrl or a sourceId.`
);
}
if (sourceUrl && typeof sourceUrl != "string") {
throw new Error(
`Breakpoints expect to have sourceUrl string, got ${typeof sourceUrl} instead.`
);
}
// sourceId may be undefined for some sources keyed by URL
if (sourceId && typeof sourceId != "string") {
throw new Error(
`Breakpoints expect to have sourceId string, got ${typeof sourceId} instead.`
);
}
if (typeof line != "number") {
throw new Error(
`Breakpoints expect to have line number, got ${typeof line} instead.`
);
}
if (typeof column != "number") {
throw new Error(
`Breakpoints expect to have column number, got ${typeof column} instead.`
);
}
}
// Allow this JSM to also be loaded as a CommonJS module
// Because this module is used from the worker thread,
// and workers can't load JSMs.
if (typeof module == "object") {
module.exports.validateBreakpointLocation = validateBreakpointLocation;
}