pub struct Config {
Show 16 fields pub opts: Options, pub crate_cfg: FxHashSet<(String, Option<String>)>, pub crate_check_cfg: CheckCfg, pub input: Input, pub output_dir: Option<PathBuf>, pub output_file: Option<OutFileName>, pub ice_file: Option<PathBuf>, pub file_loader: Option<Box<dyn FileLoader + Send + Sync>>, pub locale_resources: &'static [&'static str], pub lint_caps: FxHashMap<LintId, Level>, pub parse_sess_created: Option<Box<dyn FnOnce(&mut ParseSess) + Send>>, pub register_lints: Option<Box<dyn Fn(&Session, &mut LintStore) + Send + Sync>>, pub override_queries: Option<fn(_: &Session, _: &mut Providers)>, pub make_codegen_backend: Option<Box<dyn FnOnce(&Options) -> Box<dyn CodegenBackend> + Send>>, pub registry: Registry, pub expanded_args: Vec<String>,
}
Expand description

The compiler configuration

Fields§

§opts: Options

Command line options

§crate_cfg: FxHashSet<(String, Option<String>)>

cfg! configuration in addition to the default ones

§crate_check_cfg: CheckCfg§input: Input§output_dir: Option<PathBuf>§output_file: Option<OutFileName>§ice_file: Option<PathBuf>§file_loader: Option<Box<dyn FileLoader + Send + Sync>>§locale_resources: &'static [&'static str]§lint_caps: FxHashMap<LintId, Level>§parse_sess_created: Option<Box<dyn FnOnce(&mut ParseSess) + Send>>

This is a callback from the driver that is called when ParseSess is created.

§register_lints: Option<Box<dyn Fn(&Session, &mut LintStore) + Send + Sync>>

This is a callback from the driver that is called when we’re registering lints; it is called during plugin registration when we have the LintStore in a non-shared state.

Note that if you find a Some here you probably want to call that function in the new function being registered.

§override_queries: Option<fn(_: &Session, _: &mut Providers)>

This is a callback from the driver that is called just after we have populated the list of queries.

The second parameter is local providers and the third parameter is external providers.

§make_codegen_backend: Option<Box<dyn FnOnce(&Options) -> Box<dyn CodegenBackend> + Send>>

This is a callback from the driver that is called to create a codegen backend.

§registry: Registry

Registry of diagnostics codes.

§expanded_args: Vec<String>

All commandline args used to invoke the compiler, with @file args fully expanded. This will only be used within debug info, e.g. in the pdb file on windows This is mainly useful for other tools that reads that debuginfo to figure out how to call the compiler with the same arguments.

Auto Trait Implementations§

§

impl !RefUnwindSafe for Config

§

impl Send for Config

§

impl !Sync for Config

§

impl Unpin for Config

§

impl !UnwindSafe for Config

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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.

source§

impl<T, U> Into<U> for Twhere 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, U> TryFrom<U> for Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.

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