2020-04-11 13:53:12 +03:00
|
|
|
use super::super::*;
|
|
|
|
|
|
2020-10-05 15:37:55 +03:00
|
|
|
// Test target self-consistency and JSON encoding/decoding roundtrip.
|
|
|
|
|
pub(super) fn test_target(target: Target) {
|
|
|
|
|
target.check_consistency();
|
2021-05-27 10:21:53 +02:00
|
|
|
assert_eq!(Target::from_json(target.to_json()).map(|(j, _)| j), Ok(target));
|
2020-04-11 13:53:12 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl Target {
|
|
|
|
|
fn check_consistency(&self) {
|
2022-06-18 01:01:19 +03:00
|
|
|
assert_eq!(self.is_like_osx, self.vendor == "apple");
|
|
|
|
|
assert_eq!(self.is_like_solaris, self.os == "solaris" || self.os == "illumos");
|
|
|
|
|
assert_eq!(self.is_like_windows, self.os == "windows" || self.os == "uefi");
|
|
|
|
|
assert_eq!(self.is_like_wasm, self.arch == "wasm32" || self.arch == "wasm64");
|
2020-11-12 00:54:23 +03:00
|
|
|
assert!(self.is_like_windows || !self.is_like_msvc);
|
2022-06-18 01:01:19 +03:00
|
|
|
|
2020-04-11 13:53:12 +03:00
|
|
|
// Check that LLD with the given flavor is treated identically to the linker it emulates.
|
2020-07-07 11:12:44 -04:00
|
|
|
// If your target really needs to deviate from the rules below, except it and document the
|
|
|
|
|
// reasons.
|
2020-04-11 13:53:12 +03:00
|
|
|
assert_eq!(
|
|
|
|
|
self.linker_flavor == LinkerFlavor::Msvc
|
|
|
|
|
|| self.linker_flavor == LinkerFlavor::Lld(LldFlavor::Link),
|
2020-11-08 14:27:51 +03:00
|
|
|
self.lld_flavor == LldFlavor::Link,
|
2020-04-11 13:53:12 +03:00
|
|
|
);
|
2020-11-12 00:54:23 +03:00
|
|
|
assert_eq!(self.is_like_msvc, self.lld_flavor == LldFlavor::Link);
|
2020-04-11 13:53:12 +03:00
|
|
|
for args in &[
|
2020-11-08 14:27:51 +03:00
|
|
|
&self.pre_link_args,
|
|
|
|
|
&self.late_link_args,
|
|
|
|
|
&self.late_link_args_dynamic,
|
|
|
|
|
&self.late_link_args_static,
|
|
|
|
|
&self.post_link_args,
|
2020-04-11 13:53:12 +03:00
|
|
|
] {
|
|
|
|
|
assert_eq!(
|
|
|
|
|
args.get(&LinkerFlavor::Msvc),
|
|
|
|
|
args.get(&LinkerFlavor::Lld(LldFlavor::Link)),
|
|
|
|
|
);
|
|
|
|
|
if args.contains_key(&LinkerFlavor::Msvc) {
|
2020-11-08 14:27:51 +03:00
|
|
|
assert_eq!(self.lld_flavor, LldFlavor::Link);
|
2020-04-11 13:53:12 +03:00
|
|
|
}
|
|
|
|
|
}
|
2020-05-28 22:12:31 +03:00
|
|
|
assert!(
|
2020-11-08 14:27:51 +03:00
|
|
|
(self.pre_link_objects_fallback.is_empty()
|
|
|
|
|
&& self.post_link_objects_fallback.is_empty())
|
|
|
|
|
|| self.crt_objects_fallback.is_some()
|
2020-05-28 22:12:31 +03:00
|
|
|
);
|
2020-11-11 20:59:37 +03:00
|
|
|
// Keep the default "unknown" vendor instead.
|
|
|
|
|
assert_ne!(self.vendor, "");
|
|
|
|
|
if !self.can_use_os_unknown() {
|
|
|
|
|
// Keep the default "none" for bare metal targets instead.
|
|
|
|
|
assert_ne!(self.os, "unknown");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Add your target to the whitelist if it has `std` library
|
|
|
|
|
// and you certainly want "unknown" for the OS name.
|
|
|
|
|
fn can_use_os_unknown(&self) -> bool {
|
|
|
|
|
self.llvm_target == "wasm32-unknown-unknown"
|
2020-12-30 12:52:21 -06:00
|
|
|
|| self.llvm_target == "wasm64-unknown-unknown"
|
2020-11-11 20:59:37 +03:00
|
|
|
|| (self.env == "sgx" && self.vendor == "fortanix")
|
2020-04-11 13:53:12 +03:00
|
|
|
}
|
|
|
|
|
}
|