From b8e87aae6dca78fe0f8dbffd9d6a34921d9913f4 Mon Sep 17 00:00:00 2001 From: isidor Date: Thu, 1 Oct 2020 17:35:54 +0200 Subject: [PATCH] fixes #107860 --- .../contrib/debug/browser/debugActionViewItems.ts | 9 ++++++--- src/vs/workbench/contrib/debug/browser/debugToolBar.ts | 2 +- src/vs/workbench/contrib/debug/browser/debugViewlet.ts | 2 +- src/vs/workbench/contrib/debug/browser/repl.ts | 2 +- 4 files changed, 9 insertions(+), 6 deletions(-) diff --git a/src/vs/workbench/contrib/debug/browser/debugActionViewItems.ts b/src/vs/workbench/contrib/debug/browser/debugActionViewItems.ts index ec89f5b46193f..97d2519b2970e 100644 --- a/src/vs/workbench/contrib/debug/browser/debugActionViewItems.ts +++ b/src/vs/workbench/contrib/debug/browser/debugActionViewItems.ts @@ -234,6 +234,7 @@ export class StartDebugActionViewItem implements IActionViewItem { export class FocusSessionActionViewItem extends SelectActionViewItem { constructor( action: IAction, + session: IDebugSession | undefined, @IDebugService protected readonly debugService: IDebugService, @IThemeService themeService: IThemeService, @IContextViewService contextViewService: IContextViewService, @@ -262,15 +263,17 @@ export class FocusSessionActionViewItem extends SelectActionViewItem { }); this._register(this.debugService.onDidEndSession(() => this.update())); - this.update(); + this.update(session); } protected getActionContext(_: string, index: number): any { return this.getSessions()[index]; } - private update() { - const session = this.getSelectedSession(); + private update(session?: IDebugSession) { + if (!session) { + session = this.getSelectedSession(); + } const sessions = this.getSessions(); const names = sessions.map(s => { const label = s.getLabel(); diff --git a/src/vs/workbench/contrib/debug/browser/debugToolBar.ts b/src/vs/workbench/contrib/debug/browser/debugToolBar.ts index 5dcee2af03364..93635f7ff1ae0 100644 --- a/src/vs/workbench/contrib/debug/browser/debugToolBar.ts +++ b/src/vs/workbench/contrib/debug/browser/debugToolBar.ts @@ -75,7 +75,7 @@ export class DebugToolBar extends Themable implements IWorkbenchContribution { orientation: ActionsOrientation.HORIZONTAL, actionViewItemProvider: (action: IAction) => { if (action.id === FocusSessionAction.ID) { - return this.instantiationService.createInstance(FocusSessionActionViewItem, action); + return this.instantiationService.createInstance(FocusSessionActionViewItem, action, undefined); } else if (action instanceof MenuItemAction) { return this.instantiationService.createInstance(MenuEntryActionViewItem, action); } else if (action instanceof SubmenuItemAction) { diff --git a/src/vs/workbench/contrib/debug/browser/debugViewlet.ts b/src/vs/workbench/contrib/debug/browser/debugViewlet.ts index 1d805139611c0..f13479c4ec5b2 100644 --- a/src/vs/workbench/contrib/debug/browser/debugViewlet.ts +++ b/src/vs/workbench/contrib/debug/browser/debugViewlet.ts @@ -171,7 +171,7 @@ export class DebugViewPaneContainer extends ViewPaneContainer { return this.startDebugActionViewItem; } if (action.id === FocusSessionAction.ID) { - return new FocusSessionActionViewItem(action, this.debugService, this.themeService, this.contextViewService, this.configurationService); + return new FocusSessionActionViewItem(action, undefined, this.debugService, this.themeService, this.contextViewService, this.configurationService); } if (action instanceof MenuItemAction) { return this.instantiationService.createInstance(MenuEntryActionViewItem, action); diff --git a/src/vs/workbench/contrib/debug/browser/repl.ts b/src/vs/workbench/contrib/debug/browser/repl.ts index 7fe44b35aaf80..b25915d28d5bc 100644 --- a/src/vs/workbench/contrib/debug/browser/repl.ts +++ b/src/vs/workbench/contrib/debug/browser/repl.ts @@ -459,7 +459,7 @@ export class Repl extends ViewPane implements IHistoryNavigationWidget { getActionViewItem(action: IAction): IActionViewItem | undefined { if (action.id === SelectReplAction.ID) { - return this.instantiationService.createInstance(SelectReplActionViewItem, this.selectReplAction); + return this.instantiationService.createInstance(SelectReplActionViewItem, this.selectReplAction, this.tree.getInput()); } else if (action.id === FILTER_ACTION_ID) { this.filterActionViewItem = this.instantiationService.createInstance(ReplFilterActionViewItem, action, localize('workbench.debug.filter.placeholder', "Filter (e.g. text, !exclude)"), this.filterState); return this.filterActionViewItem;