From 8522b4aece58826b1c3809b1da2976a46f70aeef Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lauren=C8=9Biu=20Nicola?= Date: Mon, 13 Sep 2021 14:46:29 +0300 Subject: [PATCH] Add workaround for rename error reporting --- editors/code/src/net.ts | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/editors/code/src/net.ts b/editors/code/src/net.ts index fbd9434d90..ddab32d020 100644 --- a/editors/code/src/net.ts +++ b/editors/code/src/net.ts @@ -124,9 +124,12 @@ export async function download(opts: DownloadOpts) { log.info(`Renamed old server binary ${opts.dest.fsPath} to ${oldServerPath.fsPath}`); } catch (err) { const fsErr = err as vscode.FileSystemError; - // This is supposed to return `FileNotFound`, alas... - if (!fsErr.code || fsErr.code !== "FileNotFound" && fsErr.code !== "EntryNotFound") { - log.error(`Cannot rename existing server instance: ${err}`); + + // This is supposed to return `FileNotFound` (spelled as `EntryNotFound`) + // but instead `code` is `Unknown` and `name` is `EntryNotFound (FileSystemError) (FileSystemError)`. + // https://github.com/rust-analyzer/rust-analyzer/pull/10222 + if (!fsErr.code || fsErr.code !== "EntryNotFound" && fsErr.name.indexOf("EntryNotFound") === -1) { + log.error(`Cannot rename existing server instance: ${err}"`); } } try {