From b8cb53e11b375bedddfcbc444b0c3bc20c64feda Mon Sep 17 00:00:00 2001 From: "J. Ryan Stinnett" Date: Fri, 25 Jun 2021 13:10:08 +0100 Subject: [PATCH] Fix Windows target arch in native build --- hak/matrix-seshat/build.js | 4 ++-- scripts/hak/hakEnv.js | 4 ++++ 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/hak/matrix-seshat/build.js b/hak/matrix-seshat/build.js index d37c783..f776a15 100644 --- a/hak/matrix-seshat/build.js +++ b/hak/matrix-seshat/build.js @@ -34,7 +34,7 @@ async function buildOpenSslWin(hakEnv, moduleInfo) { const version = moduleInfo.cfg.dependencies.openssl; const openSslDir = path.join(moduleInfo.moduleDotHakDir, `openssl-${version}`); - const openSslArch = hakEnv.arch === 'x64' ? 'VC-WIN64A' : 'VC-WIN32'; + const openSslArch = hakEnv.getTargetArch() === 'x64' ? 'VC-WIN64A' : 'VC-WIN32'; console.log("Building openssl in " + openSslDir); await new Promise((resolve, reject) => { @@ -275,7 +275,7 @@ async function buildMatrixSeshat(hakEnv, moduleInfo) { // the build scripts since they run on the host, but vcvarsall.bat sets the c // compiler in the path to be the one for the target, so we just use the matching // toolchain for the target architecture which makes everything happy. - env.RUSTUP_TOOLCHAIN = hakEnv.arch == 'x64' ? 'stable-x86_64-pc-windows-msvc' : 'stable-i686-pc-windows-msvc'; + env.RUSTUP_TOOLCHAIN = `stable-${hakEnv.getTargetId()}`; } if (!hakEnv.isHost()) { diff --git a/scripts/hak/hakEnv.js b/scripts/hak/hakEnv.js index 5a91bbe..bd09689 100644 --- a/scripts/hak/hakEnv.js +++ b/scripts/hak/hakEnv.js @@ -96,6 +96,10 @@ module.exports = class HakEnv { return this.target.platform === 'linux'; } + getTargetArch() { + return this.target.arch; + } + isHost() { return isHostId(this.target.id); }