mirror of
https://github.com/microsoft/setup-msbuild.git
synced 2024-11-22 03:21:08 +07:00
add probing for x64 msbuild binaries
This commit is contained in:
parent
0cd944e169
commit
6c2e301a93
@ -14,6 +14,10 @@ inputs:
|
|||||||
vs-prerelease:
|
vs-prerelease:
|
||||||
description: 'Enable searching for pre-release versions of Visual Studio/MSBuild'
|
description: 'Enable searching for pre-release versions of Visual Studio/MSBuild'
|
||||||
required: false
|
required: false
|
||||||
|
msbuild-architecture:
|
||||||
|
description: 'The processor architecture to prefer of msbuild. Can be either "x86" or "x64". "x64" is only available from Visual Studio version 17.0 an onwards.'
|
||||||
|
required: false
|
||||||
|
default: 'x86'
|
||||||
outputs:
|
outputs:
|
||||||
msbuildPath:
|
msbuildPath:
|
||||||
description: 'The resulting location of msbuild for your inputs'
|
description: 'The resulting location of msbuild for your inputs'
|
||||||
|
40
src/main.ts
40
src/main.ts
@ -9,6 +9,7 @@ const IS_WINDOWS = process.platform === 'win32'
|
|||||||
const VS_VERSION = core.getInput('vs-version') || 'latest'
|
const VS_VERSION = core.getInput('vs-version') || 'latest'
|
||||||
const VSWHERE_PATH = core.getInput('vswhere-path')
|
const VSWHERE_PATH = core.getInput('vswhere-path')
|
||||||
const ALLOW_PRERELEASE = core.getInput('vs-prerelease') || 'false'
|
const ALLOW_PRERELEASE = core.getInput('vs-prerelease') || 'false'
|
||||||
|
const MSBUILD_ARCH = core.getInput('msbuild-architecture') || 'x86';
|
||||||
|
|
||||||
// if a specific version of VS is requested
|
// if a specific version of VS is requested
|
||||||
let VSWHERE_EXEC = '-products * -requires Microsoft.Component.MSBuild -property installationPath -latest '
|
let VSWHERE_EXEC = '-products * -requires Microsoft.Component.MSBuild -property installationPath -latest '
|
||||||
@ -70,25 +71,38 @@ async function run(): Promise<void> {
|
|||||||
const installationPath = data.toString().trim()
|
const installationPath = data.toString().trim()
|
||||||
core.debug(`Found installation path: ${installationPath}`)
|
core.debug(`Found installation path: ${installationPath}`)
|
||||||
|
|
||||||
let toolPath = path.join(
|
// x64 only exists in one possible location, so no fallback probing
|
||||||
installationPath,
|
if(MSBUILD_ARCH === "x64") {
|
||||||
'MSBuild\\Current\\Bin\\MSBuild.exe'
|
let toolPath = path.join(
|
||||||
)
|
|
||||||
|
|
||||||
core.debug(`Checking for path: ${toolPath}`)
|
|
||||||
if (!fs.existsSync(toolPath)) {
|
|
||||||
toolPath = path.join(
|
|
||||||
installationPath,
|
installationPath,
|
||||||
'MSBuild\\15.0\\Bin\\MSBuild.exe'
|
'MSBuild\\Current\\Bin\\amd64\\MSBuild.exe'
|
||||||
)
|
);
|
||||||
|
|
||||||
core.debug(`Checking for path: ${toolPath}`)
|
core.debug(`Checking for path: ${toolPath}`)
|
||||||
if (!fs.existsSync(toolPath)) {
|
if (!fs.existsSync(toolPath)) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
foundToolPath = toolPath
|
||||||
|
} else {
|
||||||
|
let toolPath = path.join(
|
||||||
|
installationPath,
|
||||||
|
'MSBuild\\Current\\Bin\\MSBuild.exe'
|
||||||
|
)
|
||||||
|
|
||||||
foundToolPath = toolPath
|
core.debug(`Checking for path: ${toolPath}`)
|
||||||
|
if (!fs.existsSync(toolPath)) {
|
||||||
|
toolPath = path.join(
|
||||||
|
installationPath,
|
||||||
|
'MSBuild\\15.0\\Bin\\MSBuild.exe'
|
||||||
|
)
|
||||||
|
|
||||||
|
core.debug(`Checking for path: ${toolPath}`)
|
||||||
|
if (!fs.existsSync(toolPath)) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foundToolPath = toolPath
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user