7001: Add support for downloading aarch64-apple-darwin binaries r=matklad a=lnicola

There's also a slight behavior change here: we no longer download our 64-binaries on 32-bit Darwin and Linux. We still do that on Windows, as I don't know how to detect 32-bit Node on 64 Windows.

But some people install the 32-bit Code by mistake, I doubt 32-bit Windows is that popular in the Rust crowd.

Co-authored-by: Laurențiu Nicola <lnicola@dend.ro>
This commit is contained in:
bors[bot] 2020-12-22 16:38:12 +00:00 committed by GitHub
commit 94f661c62a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -287,12 +287,14 @@ async function getServer(config: Config, state: PersistentState): Promise<string
if (config.package.releaseTag === null) return "rust-analyzer"; if (config.package.releaseTag === null) return "rust-analyzer";
let platform: string | undefined; let platform: string | undefined;
if (process.arch === "x64" || process.arch === "ia32") { if ((process.arch === "x64" || process.arch === "ia32") && process.platform === "win32") {
if (process.platform === "linux") platform = "linux"; platform = "x86_64-pc-windows-msvc";
if (process.platform === "darwin") platform = "mac"; } else if (process.arch === "x64" && process.platform === "linux") {
if (process.platform === "win32") platform = "windows"; platform = "x86_64-unknown-linux-gnu";
} else if (process.arch === "x64" && process.platform === "darwin") {
platform = "x86_64-apple-darwin";
} else if (process.arch === "arm64" && process.platform === "darwin") { } else if (process.arch === "arm64" && process.platform === "darwin") {
platform = "mac"; platform = "aarch64-apple-darwin";
} }
if (platform === undefined) { if (platform === undefined) {
vscode.window.showErrorMessage( vscode.window.showErrorMessage(
@ -305,7 +307,7 @@ async function getServer(config: Config, state: PersistentState): Promise<string
); );
return undefined; return undefined;
} }
const ext = platform === "windows" ? ".exe" : ""; const ext = platform.indexOf("-windows-") !== -1 ? ".exe" : "";
const dest = path.join(config.globalStoragePath, `rust-analyzer-${platform}${ext}`); const dest = path.join(config.globalStoragePath, `rust-analyzer-${platform}${ext}`);
const exists = await fs.stat(dest).then(() => true, () => false); const exists = await fs.stat(dest).then(() => true, () => false);
if (!exists) { if (!exists) {