From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- .../src/selectors/isSelectedFrameVisible.js | 40 ++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 devtools/client/debugger/src/selectors/isSelectedFrameVisible.js (limited to 'devtools/client/debugger/src/selectors/isSelectedFrameVisible.js') diff --git a/devtools/client/debugger/src/selectors/isSelectedFrameVisible.js b/devtools/client/debugger/src/selectors/isSelectedFrameVisible.js new file mode 100644 index 0000000000..bd0dc7a456 --- /dev/null +++ b/devtools/client/debugger/src/selectors/isSelectedFrameVisible.js @@ -0,0 +1,40 @@ +/* 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 . */ + +import { + originalToGeneratedId, + isOriginalId, +} from "devtools/client/shared/source-map-loader/index"; +import { getSelectedFrame, getSelectedLocation, getCurrentThread } from "."; + +function getGeneratedId(sourceId) { + if (isOriginalId(sourceId)) { + return originalToGeneratedId(sourceId); + } + + return sourceId; +} + +/* + * Checks to if the selected frame's source is currently + * selected. + */ +export function isSelectedFrameVisible(state) { + const thread = getCurrentThread(state); + const selectedLocation = getSelectedLocation(state); + const selectedFrame = getSelectedFrame(state, thread); + + if (!selectedFrame || !selectedLocation) { + return false; + } + + if (isOriginalId(selectedLocation.sourceId)) { + return selectedLocation.sourceId === selectedFrame.location.sourceId; + } + + return ( + selectedLocation.sourceId === + getGeneratedId(selectedFrame.location.sourceId) + ); +} -- cgit v1.2.3