| // The rustc-cfg listed below are considered public API, but it is *unstable* |
| // and outside of the normal semver guarantees: |
| // - `crossbeam_no_atomic_cas` |
| // Assume the target does *not* support atomic CAS operations. |
| // This is usually detected automatically by the build script, but you may |
| // need to enable it manually when building for custom targets or using |
| // non-cargo build systems that don't run the build script. |
| // With the exceptions mentioned above, the rustc-cfg emitted by the build |
| // script are *not* public API. |
| #![warn(rust_2018_idioms)] |
| include!("no_atomic.rs"); |
| let target = match env::var("TARGET") { |
| "cargo:warning={}: unable to get TARGET environment variable: {}", |
| // Note that this is `no_*`, not `has_*`. This allows treating |
| // `cfg(target_has_atomic = "ptr")` as true when the build script doesn't |
| // run. This is needed for compatibility with non-cargo build systems that |
| // don't run the build script. |
| if NO_ATOMIC_CAS.contains(&&*target) { |
| println!("cargo:rustc-cfg=crossbeam_no_atomic_cas"); |
| println!("cargo:rerun-if-changed=no_atomic.rs"); |