Crate link_args[][src]

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.