ManifestErrorContext

Struct ManifestErrorContext 

Source
struct ManifestErrorContext {
    path: PathBuf,
    spans: Spanned<DeTable<'static>>,
    contents: String,
    rename_table: HashMap<InternedString, InternedString>,
    requested_kinds: Vec<CompileKind>,
    cfgs: Vec<Vec<Cfg>>,
    host_name: InternedString,
    cwd: PathBuf,
    term_width: usize,
}
Expand description

Cloned and sendable context about the manifest file.

Sometimes we enrich rustc’s errors with some locations in the manifest file; this contains a Send-able copy of the manifest information that we need for the enriched errors.

Fields§

§path: PathBuf

The path to the manifest.

§spans: Spanned<DeTable<'static>>

The locations of various spans within the manifest.

§contents: String

The raw manifest contents.

§rename_table: HashMap<InternedString, InternedString>

A lookup for all the unambiguous renamings, mapping from the original package name to the renamed one.

§requested_kinds: Vec<CompileKind>

A list of targets we’re compiling for, to determine which of the [target.<something>.dependencies] tables might be of interest.

§cfgs: Vec<Vec<Cfg>>

A list of all the collections of cfg values, one collection for each target, to determine which of the [target.'cfg(...)'.dependencies] tables might be of interest.

§host_name: InternedString§cwd: PathBuf

Cargo’s working directory (for printing out a more friendly manifest path).

§term_width: usize

Terminal width for formatting diagnostics.

Implementations§

Source§

impl ManifestErrorContext

Source

fn new(build_runner: &BuildRunner<'_, '_>, unit: &Unit) -> ManifestErrorContext

Source

fn requested_target_names(&self) -> impl Iterator<Item = &str>

Source

fn find_crate_span(&self, unrenamed: &str) -> Option<Range<usize>>

Find a span for the dependency that specifies this unrenamed crate, if it’s unique.

rustc diagnostics (at least for public-in-private) mention the un-renamed crate: if you have foo = { package = "bar" }, the rustc diagnostic will say “bar”.

This function does its best to find a span for “bar”, but it could fail if there are multiple candidates:

foo = { package = "bar" }
baz = { path = "../bar", package = "bar" }

Auto Trait Implementations§

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.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

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
§

impl<T> ErasedDestructor for T
where T: 'static,

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