struct ToolBuild {
build_compiler: Compiler,
target: TargetSelection,
tool: &'static str,
path: &'static str,
mode: Mode,
source_type: SourceType,
extra_features: Vec<String>,
allow_features: &'static str,
cargo_args: Vec<String>,
artifact_kind: ToolArtifactKind,
}Fields§
§build_compiler: CompilerCompiler that will build this tool.
target: TargetSelection§tool: &'static str§path: &'static str§mode: Mode§source_type: SourceType§extra_features: Vec<String>§allow_features: &'static strNightly-only features that are allowed (comma-separated list).
cargo_args: Vec<String>Additional arguments to pass to the cargo invocation.
artifact_kind: ToolArtifactKindWhether the tool builds a binary or a library.
Trait Implementations§
Source§impl Step for ToolBuild
impl Step for ToolBuild
Source§fn run(self, builder: &Builder<'_>) -> ToolBuildResult
fn run(self, builder: &Builder<'_>) -> ToolBuildResult
Builds a tool in src/tools
This will build the specified tool with the specified host compiler in
stage into the normal cargo output directory.
Source§type Output = ToolBuildResult
type Output = ToolBuildResult
Result type of
Step::run.Source§fn should_run(run: ShouldRun<'_>) -> ShouldRun<'_>
fn should_run(run: ShouldRun<'_>) -> ShouldRun<'_>
Determines if this
Step should be run when given specific paths (e.g., x build $path).Source§const DEFAULT: bool = false
const DEFAULT: bool = false
Whether this step is run by default as part of its respective phase, as defined by the
describe
macro in Builder::get_step_descriptions. Read moreSource§const IS_HOST: bool = false
const IS_HOST: bool = false
If this value is true, then the values of
run.target passed to the make_run function of
this Step will be determined based on the --host flag.
If this value is false, then they will be determined based on the --target flag. Read moreSource§fn make_run(_run: RunConfig<'_>)
fn make_run(_run: RunConfig<'_>)
Called directly by the bootstrap
Step handler when not triggered indirectly by other Steps using Builder::ensure.
For example, ./x.py test bootstrap runs this for test::Bootstrap. Similarly, ./x.py test runs it for every step
that is listed by the describe macro in Builder::get_step_descriptions.Source§fn metadata(&self) -> Option<StepMetadata>
fn metadata(&self) -> Option<StepMetadata>
Returns metadata of the step, for tests
impl Eq for ToolBuild
impl StructuralPartialEq for ToolBuild
Auto Trait Implementations§
impl Freeze for ToolBuild
impl RefUnwindSafe for ToolBuild
impl Send for ToolBuild
impl Sync for ToolBuild
impl Unpin for ToolBuild
impl UnwindSafe for ToolBuild
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Pointable for T
impl<T> Pointable for T
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: 176 bytes