-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add auto-refresh capabilities for memory inspector windows (#115)
* Extend Auto Refresh capabilities with 'After Delay' and 'On Focus' - Rework 'refreshOnStop' boolean setting to 'autoRefresh' enumerable -- On Stop (previously: 'on' for 'refreshOnStop' -- On Focus (previously: always implicit on view state change) -- After Delay (new) -- Off (previously: 'off' for 'refreshOnStop') - On Stop -- Rework global setting to be local for each Memory Inspector -- Listen to debug session stopped event and propagate to view - On Focus -- Rework implicit refresh update to option in setting -- Listen to view state changes and propagate to view - After Delay -- New option to explicitly define a delay when re-fetching the memory -- Minimum: 500ms, default: 500, input step size: 250ms Refactoring: - Split debug session tracking into dedicated class with session events -- Convert debug events into session events with additional data - Split context tracking from memory provider into dedicated class - Move manifest to common for default values and avoid duplication -- Align 'Min' with 'Minimal' value from manifest Minor: - Add title toolbar item for C/C++ file to access open memory inspector - Improve debugging experience by using inline source maps - Align creation of option enums to use const objects - Additionally guard 'body' on debug responses for safety - Avoid functional React state update where unnecessary Fixes #91 * PR Feedback - Improve wording in setting descriptions - Move shared types into common area instead of using type imports - Fix 'fetchMemory' not returning the correct promise * PR Feedback: Separate refresh options and remove 'On Focus' Also remove the show memory inspector toolbar item for C/C++ files * Apply further PR Feedback - Improve settings descriptions in package.json - Get rid of obsolete ViewState and view state-related code - Properly return provider result for contributed trackers - Make 'fireSessionEvent' public as we access it from other classes - Avoid auto-focusing the delay input field if we change options
- Loading branch information
1 parent
78f313c
commit e44ca7f
Showing
26 changed files
with
570 additions
and
290 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
/******************************************************************************** | ||
* Copyright (C) 2024 EclipseSource and others. | ||
* | ||
* This program and the accompanying materials are made available under the | ||
* terms of the Eclipse Public License v. 2.0 which is available at | ||
* http://www.eclipse.org/legal/epl-2.0. | ||
* | ||
* This Source Code may also be made available under the following Secondary | ||
* Licenses when the conditions for such availability set forth in the Eclipse | ||
* Public License v. 2.0 are satisfied: GNU General Public License, version 2 | ||
* with the GNU Classpath Exception which is available at | ||
* https://www.gnu.org/software/classpath/license.html. | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 | ||
********************************************************************************/ | ||
import { WebviewIdMessageParticipant } from 'vscode-messenger-common'; | ||
import { Endianness, GroupsPerRowOption, PeriodicRefresh, RefreshOnStop } from './manifest'; | ||
import { Radix } from './memory-range'; | ||
|
||
/** The memory display configuration that can be specified for the memory widget. */ | ||
export interface MemoryDisplayConfiguration { | ||
bytesPerMau: number; | ||
mausPerGroup: number; | ||
groupsPerRow: GroupsPerRowOption; | ||
endianness: Endianness; | ||
scrollingBehavior: ScrollingBehavior; | ||
addressPadding: AddressPadding; | ||
addressRadix: Radix; | ||
showRadixPrefix: boolean; | ||
refreshOnStop: RefreshOnStop; | ||
periodicRefresh: PeriodicRefresh; | ||
periodicRefreshInterval: number; | ||
} | ||
|
||
export type ScrollingBehavior = 'Paginate' | 'Grow' | 'Auto-Append'; | ||
|
||
export type AddressPadding = 'Minimal' | number; | ||
|
||
export interface ColumnVisibilityStatus { | ||
visibleColumns: string[]; | ||
} | ||
|
||
/** All settings related to memory view that can be specified for the webview from the extension "main". */ | ||
export interface MemoryViewSettings extends ColumnVisibilityStatus, MemoryDisplayConfiguration { | ||
title: string | ||
messageParticipant: WebviewIdMessageParticipant; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/******************************************************************************** | ||
* Copyright (C) 2022 Ericsson, Arm and others. | ||
* | ||
* This program and the accompanying materials are made available under the | ||
* terms of the Eclipse Public License v. 2.0 which is available at | ||
* http://www.eclipse.org/legal/epl-2.0. | ||
* | ||
* This Source Code may also be made available under the following Secondary | ||
* Licenses when the conditions for such availability set forth in the Eclipse | ||
* Public License v. 2.0 are satisfied: GNU General Public License, version 2 | ||
* with the GNU Classpath Exception which is available at | ||
* https://www.gnu.org/software/classpath/license.html. | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 | ||
********************************************************************************/ | ||
|
||
import * as vscode from 'vscode'; | ||
import * as manifest from '../common/manifest'; | ||
import { isSessionEvent, SessionEvent, SessionTracker } from './session-tracker'; | ||
|
||
export class ContextTracker { | ||
public static ReadKey = `${manifest.PACKAGE_NAME}.canRead`; | ||
public static WriteKey = `${manifest.PACKAGE_NAME}.canWrite`; | ||
|
||
constructor(protected sessionTracker: SessionTracker) { | ||
this.sessionTracker.onSessionEvent(event => this.onSessionEvent(event)); | ||
} | ||
|
||
onSessionEvent(event: SessionEvent): void { | ||
if (isSessionEvent('active', event)) { | ||
vscode.commands.executeCommand('setContext', ContextTracker.ReadKey, !!event.session?.debugCapabilities?.supportsReadMemoryRequest); | ||
vscode.commands.executeCommand('setContext', ContextTracker.WriteKey, !!event.session?.debugCapabilities?.supportsWriteMemoryRequest); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.