linktime
Cross-platform libraries for link-time initialization, finalization and collection in Rust.
Crates
The linktime project comprises three crates, and the top-level linktime
crate aggregates them all.
Pick-and-choose, or import the top-level crate to get all three.
ctor
Module initialization functions for Rust (like __attribute__((constructor)) in
C/C++).
Run code before main to initialize data, external resources, or other state.
[]
= { = "...", = ["ctor"] } # note: already enabled by default
# or
= "..."
use ctor; // or ctor::ctor
use *;
dtor
Module shutdown functions for Rust (like __attribute__((destructor))).
Run code after main to clean up resources, or perform other final operations.
[]
= { = "...", = ["dtor"] } # note: already enabled by default
# or
= "..."
use dtor; // or dtor::dtor
use *;
link-section
Typed and untyped link section support for Rust.
Collect related items from an entire linked binary into a single link section.
[]
= { = "...", = ["link-section"] } # note: already enabled by default
# or
= "..."
use ;
use ctor;
use *;
static FOO: ;
scattered-collect
A crate for defining zero-allocation,linker-managed scattered collections in Rust.
ScatteredIterable: A collection of items that are available only viaScatteredSlice: A collection of sized items that collected into a slice in an arbitrary order.ScatteredSortedSlice: A collection of items that are available via slice, in sorted order.ScatteredReferencedSlice: A collection of items collected into a slice (link order).ScatteredSortedReferencedSlice: A collection of sized items that are available both via sorted slice and via reference at the declaration site.ScatteredMap: A collection of key-value pairs that are available via slice, as well as indexed by key.
use ;
static SLICE_PLUGINS: ;
const _: &'static str = "json";
const _: &'static str = "yaml";
Contributing
Contributions are welcome!
License
These projects are dual-licensed under the Apache License, Version 2.0 and the MIT License.