From b0231fd684c8acca4a7d26a127b298ffb3d3a51c Mon Sep 17 00:00:00 2001 From: Alex Ross Date: Tue, 6 Oct 2020 19:09:20 +0200 Subject: [PATCH] Fix bad dispose in automatic port forwarding (#108195) Fixes #107243 --- .../workbench/contrib/remote/browser/remote.ts | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/src/vs/workbench/contrib/remote/browser/remote.ts b/src/vs/workbench/contrib/remote/browser/remote.ts index 92c3efc52c427..98573a206f149 100644 --- a/src/vs/workbench/contrib/remote/browser/remote.ts +++ b/src/vs/workbench/contrib/remote/browser/remote.ts @@ -841,7 +841,7 @@ class RemoteAgentConnectionStatusListener implements IWorkbenchContribution { } class AutomaticPortForwarding extends Disposable implements IWorkbenchContribution { - private contextServiceListener: IDisposable; + private contextServiceListener?: IDisposable; constructor( @ITerminalService private readonly terminalService: ITerminalService, @@ -855,12 +855,13 @@ class AutomaticPortForwarding extends Disposable implements IWorkbenchContributi super(); if (this.environmentService.configuration.remoteAuthority) { this.startUrlFinder(); + } else { + this.contextServiceListener = this._register(this.contextKeyService.onDidChangeContext(e => { + if (e.affectsSome(new Set(forwardedPortsViewEnabled.keys()))) { + this.startUrlFinder(); + } + })); } - this.contextServiceListener = this._register(this.contextKeyService.onDidChangeContext(e => { - if (e.affectsSome(new Set(forwardedPortsViewEnabled.keys()))) { - this.startUrlFinder(); - } - })); } private isStarted = false; @@ -868,7 +869,9 @@ class AutomaticPortForwarding extends Disposable implements IWorkbenchContributi if (!this.isStarted && !forwardedPortsViewEnabled.getValue(this.contextKeyService)) { return; } - this.contextServiceListener.dispose(); + if (this.contextServiceListener) { + this.contextServiceListener.dispose(); + } this.isStarted = true; const urlFinder = this._register(new UrlFinder(this.terminalService)); this._register(urlFinder.onDidMatchLocalUrl(async (localUrl) => {