aboutsummaryrefslogtreecommitdiff
path: root/docs/modules/ROOT/examples/basic/build.rs
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2022-10-20 14:18:47 +0000
committerGitHub <[email protected]>2022-10-20 14:18:47 +0000
commitbf0ad38640bd683401489ea68926aebd25272858 (patch)
treebb9e5bf6f86073b86d7218d2a659e5bebfcfd074 /docs/modules/ROOT/examples/basic/build.rs
parent8c42b26fc623f556c865a0f27c7f956b06bedff9 (diff)
parentde103a5f4fba5e913988928e22301b4ee05e8515 (diff)
Merge #1019
1019: Add missing files and features for basic example r=lulf a=lulf Co-authored-by: Ulf Lilleengen <[email protected]>
Diffstat (limited to 'docs/modules/ROOT/examples/basic/build.rs')
-rw-r--r--docs/modules/ROOT/examples/basic/build.rs35
1 files changed, 35 insertions, 0 deletions
diff --git a/docs/modules/ROOT/examples/basic/build.rs b/docs/modules/ROOT/examples/basic/build.rs
new file mode 100644
index 000000000..30691aa97
--- /dev/null
+++ b/docs/modules/ROOT/examples/basic/build.rs
@@ -0,0 +1,35 @@
1//! This build script copies the `memory.x` file from the crate root into
2//! a directory where the linker can always find it at build time.
3//! For many projects this is optional, as the linker always searches the
4//! project root directory -- wherever `Cargo.toml` is. However, if you
5//! are using a workspace or have a more complicated build setup, this
6//! build script becomes required. Additionally, by requesting that
7//! Cargo re-run the build script whenever `memory.x` is changed,
8//! updating `memory.x` ensures a rebuild of the application with the
9//! new memory settings.
10
11use std::env;
12use std::fs::File;
13use std::io::Write;
14use std::path::PathBuf;
15
16fn main() {
17 // Put `memory.x` in our output directory and ensure it's
18 // on the linker search path.
19 let out = &PathBuf::from(env::var_os("OUT_DIR").unwrap());
20 File::create(out.join("memory.x"))
21 .unwrap()
22 .write_all(include_bytes!("memory.x"))
23 .unwrap();
24 println!("cargo:rustc-link-search={}", out.display());
25
26 // By default, Cargo will re-run a build script whenever
27 // any file in the project changes. By specifying `memory.x`
28 // here, we ensure the build script is only re-run when
29 // `memory.x` is changed.
30 println!("cargo:rerun-if-changed=memory.x");
31
32 println!("cargo:rustc-link-arg-bins=--nmagic");
33 println!("cargo:rustc-link-arg-bins=-Tlink.x");
34 println!("cargo:rustc-link-arg-bins=-Tdefmt.x");
35}