如何在有条件地选择wasm32-unknown-unkown
目标的情况下制作配置标记?
我使用以下build.rs
打印当前环境:
use std::env;
fn main() {
for (key, value) in env::vars() {
if key.starts_with("CARGO_CFG_") {
println!("{}: {:?}", key, value);
}
}
panic!("stop and dump stdout");
}
打印哪些:
CARGO_CFG_DEBUG_ASSERTIONS: ""
CARGO_CFG_TARGET_ARCH: "wasm32"
CARGO_CFG_TARGET_ENDIAN: "little"
CARGO_CFG_TARGET_ENV: ""
CARGO_CFG_TARGET_HAS_ATOMIC: "16,32,8,ptr"
CARGO_CFG_TARGET_OS: "unknown"
CARGO_CFG_TARGET_POINTER_WIDTH: "32"
CARGO_CFG_TARGET_VENDOR: "unknown"
通常我会#[cfg(target_os = "linux")]
,但在这种情况下可能不起作用,因为#[cfg(target_os = "unknown")]
可能匹配wasm32-unknown-unknown
以上。我是否必须使用target_arch
和target_os
的组合才能正常工作,或者只是target_arch
?
答案 0 :(得分:5)
这就是stdweb正在做的事情:
#[cfg(all(target_arch = "wasm32", target_os = "unknown"))]
我测试了它,它看起来像这样简单的工作正常:
#[cfg(target_arch = "wasm32")]
fn add_seven(x: i32) -> i32 {
x + 7
}
#[cfg(not(target_arch = "wasm32"))]
fn add_seven(x: i32) -> i32 {
x + 6
}
fn main() {
let eight = add_seven(1);
println!("{}", eight);
}
Rust中的条件编译允许大量的粒度,因为您可以指定操作系统,体系结构等。如果您不需要这种粒度,那么您就不必使用它。
unknown
有emscripten
和wasm32
个操作系统目标,因此如果两个平台的代码需要不同,最好区分两者。
Stdweb选择使用更细粒度的方法。如果我这样做,我会按照他们正在做的事情,但似乎它会以任何方式工作。