1 @if not defined _echo @echo off
4 set INIT_TOOLS_LOG=%~dp0init-tools.log
5 if [%PACKAGES_DIR%]==[] set PACKAGES_DIR=%~dp0packages
6 if [%TOOLRUNTIME_DIR%]==[] set TOOLRUNTIME_DIR=%~dp0Tools
7 set DOTNET_PATH=%TOOLRUNTIME_DIR%\dotnetcli\
8 if [%DOTNET_CMD%]==[] set DOTNET_CMD=%DOTNET_PATH%dotnet.exe
9 if [%BUILDTOOLS_SOURCE%]==[] set BUILDTOOLS_SOURCE=https://dotnet.myget.org/F/dotnet-buildtools/api/v3/index.json
10 set /P BUILDTOOLS_VERSION=< "%~dp0BuildToolsVersion.txt"
11 set BUILD_TOOLS_PATH=%PACKAGES_DIR%\Microsoft.DotNet.BuildTools\%BUILDTOOLS_VERSION%\lib
12 set INIT_TOOLS_RESTORE_PROJECT=%~dp0init-tools.msbuild
13 set BUILD_TOOLS_SEMAPHORE_DIR=%TOOLRUNTIME_DIR%\%BUILDTOOLS_VERSION%
14 set BUILD_TOOLS_SEMAPHORE=%BUILD_TOOLS_SEMAPHORE_DIR%\init-tools.completed
16 :: if force option is specified then clean the tool runtime and build tools package directory to force it to get recreated
18 if exist "%TOOLRUNTIME_DIR%" rmdir /S /Q "%TOOLRUNTIME_DIR%"
19 if exist "%PACKAGES_DIR%\Microsoft.DotNet.BuildTools" rmdir /S /Q "%PACKAGES_DIR%\Microsoft.DotNet.BuildTools"
22 :: If semaphore exists do nothing
23 if exist "%BUILD_TOOLS_SEMAPHORE%" (
24 echo Tools are already initialized.
28 if exist "%TOOLRUNTIME_DIR%" rmdir /S /Q "%TOOLRUNTIME_DIR%"
30 if exist "%DotNetBuildToolsDir%" (
31 echo Using tools from '%DotNetBuildToolsDir%'.
32 mklink /j "%TOOLRUNTIME_DIR%" "%DotNetBuildToolsDir%"
34 if not exist "%DOTNET_CMD%" (
35 echo ERROR: Ensure that '%DotNetBuildToolsDir%' contains the .NET Core SDK at '%DOTNET_PATH%'
39 echo Done initializing tools.
40 if NOT exist "%BUILD_TOOLS_SEMAPHORE_DIR%" mkdir "%BUILD_TOOLS_SEMAPHORE_DIR%"
41 echo Using tools from '%DotNetBuildToolsDir%'. > "%BUILD_TOOLS_SEMAPHORE%"
45 echo Running %0 > "%INIT_TOOLS_LOG%"
47 set /p DOTNET_VERSION=< "%~dp0DotnetCLIVersion.txt"
48 if exist "%DOTNET_CMD%" goto :afterdotnetrestore
50 REM Use x86 tools on arm64 and x86.
51 REM arm32 host is not currently supported, please crossbuild.
52 if /i "%PROCESSOR_ARCHITECTURE%" == "arm" (
53 echo "Error, arm32 arch not supported for build tools."
57 if /i "%PROCESSOR_ARCHITECTURE%" == "amd64" (
62 REM If this is not amd64 and not arm, then we should be running on arm64 or x86
63 REM either way we can (and should) use the x86 dotnet cli
65 REM TODO: consume native arm64 toolset, blocked by official arm64 windows cli
66 REM : release. See https://github.com/dotnet/coreclr/issues/19614 for more
70 echo "init-tools.cmd: Setting arch to %_Arch% for build tools"
74 echo Installing dotnet cli...
75 if NOT exist "%DOTNET_PATH%" mkdir "%DOTNET_PATH%"
76 set DOTNET_ZIP_NAME=dotnet-sdk-%DOTNET_VERSION%-win-%_Arch%.zip
77 set DOTNET_REMOTE_PATH=https://dotnetcli.azureedge.net/dotnet/Sdk/%DOTNET_VERSION%/%DOTNET_ZIP_NAME%
78 set DOTNET_LOCAL_PATH=%DOTNET_PATH%%DOTNET_ZIP_NAME%
79 echo Installing '%DOTNET_REMOTE_PATH%' to '%DOTNET_LOCAL_PATH%' >> "%INIT_TOOLS_LOG%"
80 powershell -NoProfile -ExecutionPolicy unrestricted -Command "$retryCount = 0; $success = $false; $proxyCredentialsRequired = $false; do { try { $wc = New-Object Net.WebClient; if ($proxyCredentialsRequired) { [Net.WebRequest]::DefaultWebProxy.Credentials = [Net.CredentialCache]::DefaultNetworkCredentials; } $wc.DownloadFile('%DOTNET_REMOTE_PATH%', '%DOTNET_LOCAL_PATH%'); $success = $true; } catch { if ($retryCount -ge 6) { throw; } else { $we = $_.Exception.InnerException -as [Net.WebException]; $proxyCredentialsRequired = ($we -ne $null -and ([Net.HttpWebResponse]$we.Response).StatusCode -eq [Net.HttpStatusCode]::ProxyAuthenticationRequired); Start-Sleep -Seconds (5 * $retryCount); $retryCount++; } } } while ($success -eq $false); Add-Type -Assembly 'System.IO.Compression.FileSystem' -ErrorVariable AddTypeErrors; if ($AddTypeErrors.Count -eq 0) { [System.IO.Compression.ZipFile]::ExtractToDirectory('%DOTNET_LOCAL_PATH%', '%DOTNET_PATH%') } else { (New-Object -com shell.application).namespace('%DOTNET_PATH%').CopyHere((new-object -com shell.application).namespace('%DOTNET_LOCAL_PATH%').Items(),16) }" >> "%INIT_TOOLS_LOG%"
81 if NOT exist "%DOTNET_LOCAL_PATH%" (
82 echo ERROR: Could not install dotnet cli correctly. 1>&2
88 if exist "%BUILD_TOOLS_PATH%" goto :afterbuildtoolsrestore
89 echo Restoring BuildTools version %BUILDTOOLS_VERSION%...
90 echo Running: "%DOTNET_CMD%" restore "%INIT_TOOLS_RESTORE_PROJECT%" --no-cache --packages "%PACKAGES_DIR%" --source "%BUILDTOOLS_SOURCE%" /p:BuildToolsPackageVersion=%BUILDTOOLS_VERSION% /p:ToolsDir=%TOOLRUNTIME_DIR% >> "%INIT_TOOLS_LOG%"
91 call "%DOTNET_CMD%" restore "%INIT_TOOLS_RESTORE_PROJECT%" --no-cache --packages "%PACKAGES_DIR%" --source "%BUILDTOOLS_SOURCE%" /p:BuildToolsPackageVersion=%BUILDTOOLS_VERSION% /p:ToolsDir=%TOOLRUNTIME_DIR% >> "%INIT_TOOLS_LOG%"
92 if NOT exist "%BUILD_TOOLS_PATH%\init-tools.cmd" (
93 echo ERROR: Could not restore build tools correctly. 1>&2
97 :afterbuildtoolsrestore
99 :: Ask init-tools to also restore ILAsm
100 set /p ILASMCOMPILER_VERSION=< "%~dp0ILAsmVersion.txt"
102 echo Initializing BuildTools...
103 echo Running: "%BUILD_TOOLS_PATH%\init-tools.cmd" "%~dp0" "%DOTNET_CMD%" "%TOOLRUNTIME_DIR%" >> "%INIT_TOOLS_LOG%"
104 call "%BUILD_TOOLS_PATH%\init-tools.cmd" "%~dp0" "%DOTNET_CMD%" "%TOOLRUNTIME_DIR%" "%PACKAGES_DIR%" >> "%INIT_TOOLS_LOG%"
105 set INIT_TOOLS_ERRORLEVEL=%ERRORLEVEL%
106 if not [%INIT_TOOLS_ERRORLEVEL%]==[0] (
107 echo ERROR: An error occured when trying to initialize the tools. 1>&2
111 :: Create semaphore file
112 echo Done initializing tools.
113 if NOT exist "%BUILD_TOOLS_SEMAPHORE_DIR%" mkdir "%BUILD_TOOLS_SEMAPHORE_DIR%"
114 echo Init-Tools.cmd completed for BuildTools Version: %BUILDTOOLS_VERSION% > "%BUILD_TOOLS_SEMAPHORE%"
118 echo Please check the detailed log that follows. 1>&2
119 type "%INIT_TOOLS_LOG%" 1>&2