Build rules exercise

在 Chromium build 中,向 //ui/base/BUILD.gn 添加新的 Rust 目标,其中包含:


#![allow(unused)]
fn main() {
// SAFETY: There is no other global function of this name.
#[unsafe(no_mangle)]
pub extern "C" fn hello_from_rust() {
    println!("Hello from Rust!")
}
}

Important: note that no_mangle here is considered a type of unsafety by the Rust compiler, so you'll need to allow unsafe code in your gn target.

将这个新的 Rust 目标添加为 //ui/base:base 的依赖项。在 ui/base/resource/resource_bundle.cc 顶部声明此函数(稍后,我们将介绍如何通过绑定生成工具来自动执行此操作):

extern "C" void hello_from_rust();

ui/base/resource/resource_bundle.cc 中的某个位置调用此函数,我们建议在从 ResourceBundle::MaybeMangleLocalizedString 的顶部调用此函数。构建并运行 Chromium,并确保多次显示 "Hello from Rust!"。

如果您使用 VSCode,现在就请设置 Rust,以便其能在 VSCode 中正常运行。这对后续练习会很有帮助。如果操作成功,则可使用右键点击 println! 上的 "Go to definition"。

如何获取帮助

  • 适用于 [rust_static_library gn 模板] 的选项 (https://source.chromium.org/chromium/chromium/src/+/main:build/rust/rust_static_library.gni;l=16)
  • Information about #[unsafe(no_mangle)]
  • 关于 [extern "C"] 的详细信息 (https://doc.rust-lang.org/std/keyword.extern.html)
  • 关于 gn 的 [--export-rust-project] 开关的详细信息 (https://gn.googlesource.com/gn/+/main/docs/reference.md#compilation-database)
  • 如何在 VSCode 中安装 rust-analyzer
It's really important that students get this running, because future exercises will build on it.

此示例很独特,因为其归根结底是最通用的互操作语言,即 C 语言。C++ 和 Rust 本身都可以声明和调用 C ABI 函数。在本课程的稍后部分,我们会直接将 C++ 和 Rust 关联起来。

allow_unsafe = true is required here because #[unsafe(no_mangle)] might allow Rust to generate two functions with the same name, and Rust can no longer guarantee that the right one is called.

如果需要纯 Rust 可执行文件,也可以使用 rust_executable gn 模板执行此操作。