Struct cargo::core::compiler::custom_build::BuildScripts
source · pub struct BuildScripts {
pub to_link: Vec<(PackageId, Metadata)>,
seen_to_link: HashSet<(PackageId, Metadata)>,
pub plugins: BTreeSet<(PackageId, Metadata)>,
}
Expand description
Linking information for a Unit
.
See build_map
for more details.
Fields§
§to_link: Vec<(PackageId, Metadata)>
List of build script outputs this Unit needs to include for linking. Each
element is an index into BuildScriptOutputs
.
Cargo will use this to_link
vector to add -L
flags to compiles as we
propagate them upwards towards the final build. Note, however, that we
need to preserve the ordering of to_link
to be topologically sorted.
This will ensure that build scripts which print their paths properly will
correctly pick up the files they generated (if there are duplicates
elsewhere).
To preserve this ordering, the (id, metadata) is stored in two places, once
in the Vec
and once in seen_to_link
for a fast lookup. We maintain
this as we’re building interactively below to ensure that the memory
usage here doesn’t blow up too much.
For more information, see #2354.
seen_to_link: HashSet<(PackageId, Metadata)>
This is only used while constructing to_link
to avoid duplicates.
plugins: BTreeSet<(PackageId, Metadata)>
Host-only dependencies that have build scripts. Each element is an
index into BuildScriptOutputs
.
This is the set of transitive dependencies that are host-only
(proc-macro, plugin, build-dependency) that contain a build script.
Any BuildOutput::library_paths
path relative to target
will be
added to LD_LIBRARY_PATH so that the compiler can find any dynamic
libraries a build script may have generated.
Trait Implementations§
source§impl Default for BuildScripts
impl Default for BuildScripts
source§fn default() -> BuildScripts
fn default() -> BuildScripts
Auto Trait Implementations§
impl RefUnwindSafe for BuildScripts
impl Send for BuildScripts
impl Sync for BuildScripts
impl Unpin for BuildScripts
impl UnwindSafe for BuildScripts
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,
source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 96 bytes