Expand description
Allows setting linker arugments at compile time without a build script. Currently only supports Windows MSVC toolchains.
§Usage
Add this to your Cargo.toml
:
[dependencies]
link_args = "0.6"
§Examples
Put these examples at the root of your main.rs
or lib.rs
.
§Set the size of the stack
Reserve 8 MiB (8,388,608 bytes) of virtual memory for the stack. This should
only be set for crates that produce a .exe
or .dll
binary.
link_args::windows::stack_size!(0x800000);
§Add a default library
Add “kernel32.lib” to the libraries that are serached for symbols.
link_args::windows::default_lib!("kernel32.lib");
§Use the windows!
macro
The windows!
macro lets you set multiple arguments at once.
link_args::windows! {
stack_size(0x800000);
default_lib("kernel32.lib");
}
If you use unsafe linker arguments the you must mark the whole block as
unsafe
.
// Only set these in release mode.
#[cfg(not(debug_assertions))]
link_args::windows! {
// Some of these linker args are unsafe so we have to use
// an `unsafe` block.
unsafe {
// Link the ucrt dynamically and vcruntime statically.
default_lib("ucrt", "libvcruntime", "libcmt");
// Disable the other C runtime libraries.
no_default_lib(
"libvcruntimed.lib", "vcruntime.lib", "vcruntimed.lib",
"libcmtd.lib", "msvcrt.lib", "msvcrtd.lib",
"libucrt.lib", "libucrtd.lib", "ucrtd.lib",
);
}
}
Modules§
- windows
- Set linker arguments for the Windows toolchain
Macros§
- windows
- Set a group of arguments for the Windows linker.
- windows_
msvc_ default_ lib - Adds one or more default libraries.
- windows_
msvc_ stack_ size - Set how much virtual memory is avaliable for the stack.
- windows_
raw - Embeds raw linker arguments for Windows targets.