cargo::core::compiler::unit_dependencies

Struct State

Source
struct State<'a, 'gctx> {
Show 15 fields ws: &'a Workspace<'gctx>, gctx: &'gctx GlobalContext, unit_dependencies: UnitGraph, package_set: &'a PackageSet<'gctx>, usr_resolve: &'a Resolve, usr_features: &'a ResolvedFeatures, std_resolve: Option<&'a Resolve>, std_features: Option<&'a ResolvedFeatures>, is_std: bool, global_mode: CompileMode, target_data: &'a RustcTargetData<'gctx>, profiles: &'a Profiles, interner: &'a UnitInterner, scrape_units: &'a [Unit], dev_dependency_edges: HashSet<(Unit, Unit)>,
}
Expand description

Collection of stuff used while creating the UnitGraph.

Fields§

§ws: &'a Workspace<'gctx>§gctx: &'gctx GlobalContext§unit_dependencies: UnitGraph

Stores the result of building the UnitGraph.

§package_set: &'a PackageSet<'gctx>§usr_resolve: &'a Resolve§usr_features: &'a ResolvedFeatures§std_resolve: Option<&'a Resolve>

Like usr_resolve but for building standard library (-Zbuild-std).

§std_features: Option<&'a ResolvedFeatures>

Like usr_features but for building standard library (-Zbuild-std).

§is_std: bool

true while generating the dependencies for the standard library.

§global_mode: CompileMode

The mode we are compiling in. Used for preventing from building lib thrice.

§target_data: &'a RustcTargetData<'gctx>§profiles: &'a Profiles§interner: &'a UnitInterner§scrape_units: &'a [Unit]§dev_dependency_edges: HashSet<(Unit, Unit)>

A set of edges in unit_dependencies where (a, b) means that the dependency from a to b was added purely because it was a dev-dependency. This is used during connect_run_custom_build_deps.

Implementations§

Source§

impl<'a, 'gctx> State<'a, 'gctx>

Source

fn resolve(&self) -> &'a Resolve

Gets std_resolve during building std, otherwise usr_resolve.

Source

fn features(&self) -> &'a ResolvedFeatures

Gets std_features during building std, otherwise usr_features.

Source

fn activated_features( &self, pkg_id: PackageId, features_for: FeaturesFor, ) -> Vec<InternedString>

Source

fn is_dep_activated( &self, pkg_id: PackageId, features_for: FeaturesFor, dep_name: InternedString, ) -> bool

Source

fn get(&self, id: PackageId) -> &'a Package

Source

fn deps( &self, unit: &Unit, unit_for: UnitFor, ) -> Vec<(PackageId, Vec<&Dependency>)>

Returns a filtered set of dependencies for the given unit.

Auto Trait Implementations§

§

impl<'a, 'gctx> Freeze for State<'a, 'gctx>

§

impl<'a, 'gctx> !RefUnwindSafe for State<'a, 'gctx>

§

impl<'a, 'gctx> !Send for State<'a, 'gctx>

§

impl<'a, 'gctx> !Sync for State<'a, 'gctx>

§

impl<'a, 'gctx> Unpin for State<'a, 'gctx>

§

impl<'a, 'gctx> !UnwindSafe for State<'a, 'gctx>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more

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: 200 bytes