aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2017-07-28 17:06:00 -0700
committerGitHub <noreply@github.com>2017-07-28 17:06:00 -0700
commit8b6747d01b8266d4c5987c008622fa403ab4752b (patch)
tree175881013705fd48ec6021f3c15b6390defc9680 /scripts
parent4735040f66155c1b8f94d339bedb6afd4905e47c (diff)
parent7c6c706160528c9234a91161b834529d4e13d761 (diff)
downloadvcpkg-8b6747d01b8266d4c5987c008622fa403ab4752b.tar.gz
vcpkg-8b6747d01b8266d4c5987c008622fa403ab4752b.zip
Merge pull request #1531 from Mixaill/windowssdk-registry
scripts/getWindowsSDK: use registry for SDK detection
Diffstat (limited to 'scripts')
-rw-r--r--scripts/getWindowsSDK.ps137
1 files changed, 22 insertions, 15 deletions
diff --git a/scripts/getWindowsSDK.ps1 b/scripts/getWindowsSDK.ps1
index 7902707cb..9aebae8e3 100644
--- a/scripts/getWindowsSDK.ps1
+++ b/scripts/getWindowsSDK.ps1
@@ -17,19 +17,14 @@ $scriptsDir = split-path -parent $MyInvocation.MyCommand.Definition
$validInstances = New-Object System.Collections.ArrayList
-$CandidateProgramFiles = $(& $scriptsDir\getProgramFiles32bit.ps1), $(& $scriptsDir\getProgramFilesPlatformBitness.ps1)
-Write-Verbose "Program Files Candidate locations: $([system.String]::Join(',', $CandidateProgramFiles))"
-
# Windows 10 SDK
-Write-Verbose "`n"
-Write-Verbose "Looking for Windows 10 SDK"
-foreach ($ProgramFiles in $CandidateProgramFiles)
+function CheckWindows10SDK($path)
{
- $folder = "$ProgramFiles\Windows Kits\10\Include"
+ $folder = "$path\Include"
if (!(Test-Path $folder))
{
Write-Verbose "$folder - Not Found"
- continue
+ return
}
Write-Verbose "$folder - Found"
@@ -42,7 +37,7 @@ foreach ($ProgramFiles in $CandidateProgramFiles)
if (!(Test-Path $windowsheader))
{
Write-Verbose "$windowsheader - Not Found"
- continue
+ return
}
Write-Verbose "$windowsheader - Found"
@@ -50,7 +45,7 @@ foreach ($ProgramFiles in $CandidateProgramFiles)
if (!(Test-Path $ddkheader))
{
Write-Verbose "$ddkheader - Not Found"
- continue
+ return
}
Write-Verbose "$ddkheader - Found"
@@ -60,16 +55,21 @@ foreach ($ProgramFiles in $CandidateProgramFiles)
}
}
-# Windows 8.1 SDK
Write-Verbose "`n"
-Write-Verbose "Looking for Windows 8.1 SDK"
-foreach ($ProgramFiles in $CandidateProgramFiles)
+Write-Verbose "Looking for Windows 10 SDK"
+CheckWindows10SDK((Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\Windows Kits\Installed Roots\' -Name 'KitsRoot10' -ErrorAction SilentlyContinue).KitsRoot10)
+CheckWindows10SDK((Get-ItemProperty -Path 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows Kits\Installed Roots\' -Name 'KitsRoot10' -ErrorAction SilentlyContinue).KitsRoot10)
+CheckWindows10SDK("$env:ProgramFiles\Windows Kits\10")
+CheckWindows10SDK("${env:ProgramFiles(x86)}\Windows Kits\10")
+
+# Windows 8.1 SDK
+function CheckWindows81SDK($path)
{
- $folder = "$ProgramFiles\Windows Kits\8.1\Include"
+ $folder = "$path\Include"
if (!(Test-Path $folder))
{
Write-Verbose "$folder - Not Found"
- continue
+ return
}
Write-Verbose "$folder - Found"
@@ -78,6 +78,13 @@ foreach ($ProgramFiles in $CandidateProgramFiles)
$validInstances.Add($win81sdkVersionString) > $null
}
+Write-Verbose "`n"
+Write-Verbose "Looking for Windows 8.1 SDK"
+CheckWindows81SDK((Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\Windows Kits\Installed Roots\' -Name 'KitsRoot81' -ErrorAction SilentlyContinue).KitsRoot81)
+CheckWindows81SDK((Get-ItemProperty -Path 'HKLM:\SOFTWARE\WOW6432Node\Microsoft\Windows Kits\Installed Roots\' -Name 'KitsRoot81' -ErrorAction SilentlyContinue).KitsRoot81)
+CheckWindows81SDK("$env:ProgramFiles\Windows Kits\8.1")
+CheckWindows81SDK("${env:ProgramFiles(x86)}\Windows Kits\8.1")
+
Write-Verbose "`n`n`n"
Write-Verbose "The following Windows SDKs were found:"
foreach ($instance in $validInstances)