-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Description
Steps
-
cargo new repro && cd repro -
rustc +nightly -Z unstable-options --print target-spec-json --target x86_64-apple-darwin > x86_64-apple-darwin.jsonThe JSON filename should match the target to avoid some strange cases in the compiler. This should occur on other platforms as well.
-
Create
build.rsfn main() { dbg!(std::env::var("TARGET")); }
-
cargo +nightly build --target $PWD/x86_64-apple-darwin.json -Z build-std --verbose --verbose --verboseThe
build-stdisn't really important to this issue, it's only used to support the non-standard target specification.
You'll see the TARGET variable no longer has the path and .json extension in the output:
[repro 0.1.0] [build.rs:2] std::env::var("TARGET") = Ok(
[repro 0.1.0] "x86_64-apple-darwin",
[repro 0.1.0] )
This caused an issue in the rust-lang/rust repository while I was trying to port to aarch64-apple-darwin by using a JSON target file. Specifically, indexmap uses autocfg which uses TARGET to build things.
This was failing because my target didn't yet exist in the compiler, so autocfg decided it was the wrong version of rustc.
Possible Solution(s)
It seems like it should include the full path to the JSON file in the environment variable, but I'm not sure what the impact of such a change would be.
Notes
% cargo +nightly version
cargo 1.47.0-nightly (51b66125b 2020-08-19)
% rustc +nightly --version
rustc 1.47.0-nightly (5180f3da5 2020-08-23)