Browse Source

Merge pull request #89 from retep998/sturdy-rabbits

Fix relying on Windows 8/8.1 SDKs
vs2017
Alex Crichton 9 years ago
committed by GitHub
parent
commit
6e33b148a0
  1. 62
      src/windows_registry.rs

62
src/windows_registry.rs

@ -128,21 +128,28 @@ pub fn find_tool(target: &str, tool: &str) -> Option<Tool> {
let sub = otry!(lib_subdir(target)); let sub = otry!(lib_subdir(target));
let (ucrt, ucrt_version) = otry!(get_ucrt_dir()); let (ucrt, ucrt_version) = otry!(get_ucrt_dir());
let ucrt_include = ucrt.join("Include").join(&ucrt_version); let ucrt_include = ucrt.join("include").join(&ucrt_version);
tool.include.push(ucrt_include.join("ucrt")); tool.include.push(ucrt_include.join("ucrt"));
tool.include.push(ucrt_include.join("um"));
tool.include.push(ucrt_include.join("winrt"));
tool.include.push(ucrt_include.join("shared"));
let ucrt_lib = ucrt.join("Lib").join(&ucrt_version); let ucrt_lib = ucrt.join("lib").join(&ucrt_version);
tool.libs.push(ucrt_lib.join("ucrt").join(sub)); tool.libs.push(ucrt_lib.join("ucrt").join(sub));
tool.path.push(ucrt.join("bin").join(sub)); if let Some((sdk, version)) = get_sdk10_dir() {
tool.path.push(sdk.join("bin").join(sub));
if let Some(dir) = get_sdk10_dir() { let sdk_lib = sdk.join("lib").join(&version);
tool.libs.push(dir.join("um").join(sub)); tool.libs.push(sdk_lib.join("um").join(sub));
} else if let Some(dir) = get_sdk81_dir() { let sdk_include = sdk.join("include").join(&version);
tool.libs.push(dir.join("um").join(sub)); tool.include.push(sdk_include.join("um"));
tool.include.push(sdk_include.join("winrt"));
tool.include.push(sdk_include.join("shared"));
} else if let Some(sdk) = get_sdk81_dir() {
tool.path.push(sdk.join("bin").join(sub));
let sdk_lib = sdk.join("lib").join("winv6.3");
tool.libs.push(sdk_lib.join("um").join(sub));
let sdk_include = sdk.join("include");
tool.include.push(sdk_include.join("um"));
tool.include.push(sdk_include.join("winrt"));
tool.include.push(sdk_include.join("shared"));
} else { } else {
return None return None
} }
@ -155,11 +162,13 @@ pub fn find_tool(target: &str, tool: &str) -> Option<Tool> {
let mut tool = otry!(get_tool(tool, &vcdir, target)); let mut tool = otry!(get_tool(tool, &vcdir, target));
let sub = otry!(lib_subdir(target)); let sub = otry!(lib_subdir(target));
let sdk81 = otry!(get_sdk81_dir()); let sdk81 = otry!(get_sdk81_dir());
tool.libs.push(sdk81.join("um").join(sub));
tool.path.push(sdk81.join("bin").join(sub)); tool.path.push(sdk81.join("bin").join(sub));
tool.include.push(sdk81.join("include/shared")); let sdk_lib = sdk81.join("lib").join("winv6.3");
tool.include.push(sdk81.join("include/um")); tool.libs.push(sdk_lib.join("um").join(sub));
tool.include.push(sdk81.join("include/winrt")); let sdk_include = sdk81.join("include");
tool.include.push(sdk_include.join("shared"));
tool.include.push(sdk_include.join("um"));
tool.include.push(sdk_include.join("winrt"));
Some(tool.into_tool()) Some(tool.into_tool())
} }
@ -169,11 +178,13 @@ pub fn find_tool(target: &str, tool: &str) -> Option<Tool> {
let mut tool = otry!(get_tool(tool, &vcdir, target)); let mut tool = otry!(get_tool(tool, &vcdir, target));
let sub = otry!(lib_subdir(target)); let sub = otry!(lib_subdir(target));
let sdk8 = otry!(get_sdk8_dir()); let sdk8 = otry!(get_sdk8_dir());
tool.libs.push(sdk8.join("um").join(sub));
tool.path.push(sdk8.join("bin").join(sub)); tool.path.push(sdk8.join("bin").join(sub));
tool.include.push(sdk8.join("include/shared")); let sdk_lib = sdk8.join("lib").join("win8");
tool.include.push(sdk8.join("include/um")); tool.libs.push(sdk_lib.join("um").join(sub));
tool.include.push(sdk8.join("include/winrt")); let sdk_include = sdk8.join("include");
tool.include.push(sdk_include.join("shared"));
tool.include.push(sdk_include.join("um"));
tool.include.push(sdk_include.join("winrt"));
Some(tool.into_tool()) Some(tool.into_tool())
} }
@ -248,7 +259,7 @@ pub fn find_tool(target: &str, tool: &str) -> Option<Tool> {
// only need to bother checking x64, making this code a tiny bit simpler. // only need to bother checking x64, making this code a tiny bit simpler.
// Like we do for the Universal CRT, we sort the possibilities // Like we do for the Universal CRT, we sort the possibilities
// asciibetically to find the newest one as that is what vcvars does. // asciibetically to find the newest one as that is what vcvars does.
fn get_sdk10_dir() -> Option<PathBuf> { fn get_sdk10_dir() -> Option<(PathBuf, String)> {
let key = r"SOFTWARE\Microsoft\Microsoft SDKs\Windows\v10.0"; let key = r"SOFTWARE\Microsoft\Microsoft SDKs\Windows\v10.0";
let key = otry!(LOCAL_MACHINE.open(key.as_ref()).ok()); let key = otry!(LOCAL_MACHINE.open(key.as_ref()).ok());
let root = otry!(key.query_str("InstallationFolder").ok()); let root = otry!(key.query_str("InstallationFolder").ok());
@ -257,9 +268,12 @@ pub fn find_tool(target: &str, tool: &str) -> Option<Tool> {
.map(|dir| dir.path()) .map(|dir| dir.path())
.collect::<Vec<_>>(); .collect::<Vec<_>>();
dirs.sort(); dirs.sort();
dirs.into_iter().rev().filter(|dir| { let dir = otry!(dirs.into_iter().rev().filter(|dir| {
dir.join("um").join("x64").join("kernel32.lib").is_file() dir.join("um").join("x64").join("kernel32.lib").is_file()
}).next() }).next());
let version = dir.components().last().unwrap();
let version = version.as_os_str().to_str().unwrap().to_string();
Some((root.into(), version))
} }
// Interestingly there are several subdirectories, `win7` `win8` and // Interestingly there are several subdirectories, `win7` `win8` and
@ -270,14 +284,14 @@ pub fn find_tool(target: &str, tool: &str) -> Option<Tool> {
let key = r"SOFTWARE\Microsoft\Microsoft SDKs\Windows\v8.1"; let key = r"SOFTWARE\Microsoft\Microsoft SDKs\Windows\v8.1";
let key = otry!(LOCAL_MACHINE.open(key.as_ref()).ok()); let key = otry!(LOCAL_MACHINE.open(key.as_ref()).ok());
let root = otry!(key.query_str("InstallationFolder").ok()); let root = otry!(key.query_str("InstallationFolder").ok());
Some(Path::new(&root).join("lib").join("winv6.3")) Some(root.into())
} }
fn get_sdk8_dir() -> Option<PathBuf> { fn get_sdk8_dir() -> Option<PathBuf> {
let key = r"SOFTWARE\Microsoft\Microsoft SDKs\Windows\v8.0"; let key = r"SOFTWARE\Microsoft\Microsoft SDKs\Windows\v8.0";
let key = otry!(LOCAL_MACHINE.open(key.as_ref()).ok()); let key = otry!(LOCAL_MACHINE.open(key.as_ref()).ok());
let root = otry!(key.query_str("InstallationFolder").ok()); let root = otry!(key.query_str("InstallationFolder").ok());
Some(Path::new(&root).join("lib").join("win8")) Some(root.into())
} }
const PROCESSOR_ARCHITECTURE_INTEL: u16 = 0; const PROCESSOR_ARCHITECTURE_INTEL: u16 = 0;

Loading…
Cancel
Save