From 5cf35c96cf93c0d5a7f7f2f622e71f44e950cfc6 Mon Sep 17 00:00:00 2001 From: David Archibald Date: Mon, 22 Apr 2024 16:08:06 -0600 Subject: [PATCH] fix debugger attach to process when running on WSL (#267) Co-authored-by: JCMais Co-authored-by: Paula --- src/extension/common/process/rawProcessApis.ts | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/extension/common/process/rawProcessApis.ts b/src/extension/common/process/rawProcessApis.ts index 2bcd37f0..1e7a0ef4 100644 --- a/src/extension/common/process/rawProcessApis.ts +++ b/src/extension/common/process/rawProcessApis.ts @@ -11,6 +11,8 @@ import { ExecutionResult, ShellOptions, SpawnOptions, StdErrError } from './type import { noop } from '../utils/misc'; import { decodeBuffer } from './decoder'; +const PS_ERROR_SCREEN_BOGUS = /your [0-9]+x[0-9]+ screen size is bogus\. expect trouble/; + function getDefaultOptions(options: T, defaultEnv?: EnvironmentVariables): T { const defaultOptions = { ...options }; const execOptions = defaultOptions as SpawnOptions; @@ -98,7 +100,13 @@ export function plainExec( } const stderr: string | undefined = stderrBuffers.length === 0 ? undefined : decodeBuffer(stderrBuffers, encoding); - if (stderr && stderr.length > 0 && options.throwOnStdErr) { + if ( + stderr && + stderr.length > 0 && + options.throwOnStdErr && + // ignore this specific error silently; see this issue for context: https://github.com/microsoft/vscode/issues/75932 + !(PS_ERROR_SCREEN_BOGUS.test(stderr) && stderr.replace(PS_ERROR_SCREEN_BOGUS, '').trim().length === 0) + ) { deferred.reject(new StdErrError(stderr)); } else { let stdout = decodeBuffer(stdoutBuffers, encoding);