mirror of
https://github.com/rust-lang/rust.git
synced 2024-12-12 08:36:03 +00:00
Rollup merge of #125699 - nnethercote:streamline-rustfmt, r=GuillaumeGomez
Streamline `x fmt` and improve its output - Removes the ability to pass paths to `x fmt`, because it's complicated and not useful, and adds `--all`. - Improves `x fmt` output. - Improves `x fmt`'s internal code. r? ``@GuillaumeGomez``
This commit is contained in:
commit
c62fa8294e
@ -9,6 +9,7 @@ use std::collections::VecDeque;
|
|||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
use std::process::{Command, Stdio};
|
use std::process::{Command, Stdio};
|
||||||
use std::sync::mpsc::SyncSender;
|
use std::sync::mpsc::SyncSender;
|
||||||
|
use std::sync::Mutex;
|
||||||
|
|
||||||
fn rustfmt(src: &Path, rustfmt: &Path, paths: &[PathBuf], check: bool) -> impl FnMut(bool) -> bool {
|
fn rustfmt(src: &Path, rustfmt: &Path, paths: &[PathBuf], check: bool) -> impl FnMut(bool) -> bool {
|
||||||
let mut cmd = Command::new(rustfmt);
|
let mut cmd = Command::new(rustfmt);
|
||||||
@ -24,20 +25,23 @@ fn rustfmt(src: &Path, rustfmt: &Path, paths: &[PathBuf], check: bool) -> impl F
|
|||||||
cmd.args(paths);
|
cmd.args(paths);
|
||||||
let cmd_debug = format!("{cmd:?}");
|
let cmd_debug = format!("{cmd:?}");
|
||||||
let mut cmd = cmd.spawn().expect("running rustfmt");
|
let mut cmd = cmd.spawn().expect("running rustfmt");
|
||||||
// Poor man's async: return a closure that'll wait for rustfmt's completion.
|
// Poor man's async: return a closure that might wait for rustfmt's completion (depending on
|
||||||
|
// the value of the `block` argument).
|
||||||
move |block: bool| -> bool {
|
move |block: bool| -> bool {
|
||||||
if !block {
|
let status = if !block {
|
||||||
match cmd.try_wait() {
|
match cmd.try_wait() {
|
||||||
Ok(Some(_)) => {}
|
Ok(Some(status)) => Ok(status),
|
||||||
_ => return false,
|
Ok(None) => return false,
|
||||||
|
Err(err) => Err(err),
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
let status = cmd.wait().unwrap();
|
cmd.wait()
|
||||||
if !status.success() {
|
};
|
||||||
|
if !status.unwrap().success() {
|
||||||
eprintln!(
|
eprintln!(
|
||||||
"Running `{}` failed.\nIf you're running `tidy`, \
|
"fmt error: Running `{}` failed.\nIf you're running `tidy`, \
|
||||||
try again with `--bless`. Or, if you just want to format \
|
try again with `--bless`. Or, if you just want to format \
|
||||||
code, run `./x.py fmt` instead.",
|
code, run `./x.py fmt` instead.",
|
||||||
cmd_debug,
|
cmd_debug,
|
||||||
);
|
);
|
||||||
crate::exit!(1);
|
crate::exit!(1);
|
||||||
@ -97,35 +101,61 @@ struct RustfmtConfig {
|
|||||||
ignore: Vec<String>,
|
ignore: Vec<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn format(build: &Builder<'_>, check: bool, paths: &[PathBuf]) {
|
// Prints output describing a collection of paths, with lines such as "formatted modified file
|
||||||
|
// foo/bar/baz" or "skipped 20 untracked files".
|
||||||
|
fn print_paths(verb: &str, adjective: Option<&str>, paths: &[String]) {
|
||||||
|
let len = paths.len();
|
||||||
|
let adjective =
|
||||||
|
if let Some(adjective) = adjective { format!("{adjective} ") } else { String::new() };
|
||||||
|
if len <= 10 {
|
||||||
|
for path in paths {
|
||||||
|
println!("fmt: {verb} {adjective}file {path}");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
println!("fmt: {verb} {len} {adjective}files");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn format(build: &Builder<'_>, check: bool, all: bool, paths: &[PathBuf]) {
|
||||||
|
if !paths.is_empty() {
|
||||||
|
eprintln!("fmt error: path arguments are not accepted");
|
||||||
|
crate::exit!(1);
|
||||||
|
};
|
||||||
if build.config.dry_run() {
|
if build.config.dry_run() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// By default, we only check modified files locally to speed up runtime. Exceptions are if
|
||||||
|
// `--all` is specified or we are in CI. We check all files in CI to avoid bugs in
|
||||||
|
// `get_modified_rs_files` letting regressions slip through; we also care about CI time less
|
||||||
|
// since this is still very fast compared to building the compiler.
|
||||||
|
let all = all || CiEnv::is_ci();
|
||||||
|
|
||||||
let mut builder = ignore::types::TypesBuilder::new();
|
let mut builder = ignore::types::TypesBuilder::new();
|
||||||
builder.add_defaults();
|
builder.add_defaults();
|
||||||
builder.select("rust");
|
builder.select("rust");
|
||||||
let matcher = builder.build().unwrap();
|
let matcher = builder.build().unwrap();
|
||||||
let rustfmt_config = build.src.join("rustfmt.toml");
|
let rustfmt_config = build.src.join("rustfmt.toml");
|
||||||
if !rustfmt_config.exists() {
|
if !rustfmt_config.exists() {
|
||||||
eprintln!("Not running formatting checks; rustfmt.toml does not exist.");
|
eprintln!("fmt error: Not running formatting checks; rustfmt.toml does not exist.");
|
||||||
eprintln!("This may happen in distributed tarballs.");
|
eprintln!("fmt error: This may happen in distributed tarballs.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let rustfmt_config = t!(std::fs::read_to_string(&rustfmt_config));
|
let rustfmt_config = t!(std::fs::read_to_string(&rustfmt_config));
|
||||||
let rustfmt_config: RustfmtConfig = t!(toml::from_str(&rustfmt_config));
|
let rustfmt_config: RustfmtConfig = t!(toml::from_str(&rustfmt_config));
|
||||||
let mut fmt_override = ignore::overrides::OverrideBuilder::new(&build.src);
|
let mut override_builder = ignore::overrides::OverrideBuilder::new(&build.src);
|
||||||
for ignore in rustfmt_config.ignore {
|
for ignore in rustfmt_config.ignore {
|
||||||
if ignore.starts_with('!') {
|
if ignore.starts_with('!') {
|
||||||
// A `!`-prefixed entry could be added as a whitelisted entry in `fmt_override`, i.e.
|
// A `!`-prefixed entry could be added as a whitelisted entry in `override_builder`,
|
||||||
// strip the `!` prefix. But as soon as whitelisted entries are added, an
|
// i.e. strip the `!` prefix. But as soon as whitelisted entries are added, an
|
||||||
// `OverrideBuilder` will only traverse those whitelisted entries, and won't traverse
|
// `OverrideBuilder` will only traverse those whitelisted entries, and won't traverse
|
||||||
// any files that aren't explicitly mentioned. No bueno! Maybe there's a way to combine
|
// any files that aren't explicitly mentioned. No bueno! Maybe there's a way to combine
|
||||||
// explicit whitelisted entries and traversal of unmentioned files, but for now just
|
// explicit whitelisted entries and traversal of unmentioned files, but for now just
|
||||||
// forbid such entries.
|
// forbid such entries.
|
||||||
eprintln!("`!`-prefixed entries are not supported in rustfmt.toml, sorry");
|
eprintln!("fmt error: `!`-prefixed entries are not supported in rustfmt.toml, sorry");
|
||||||
crate::exit!(1);
|
crate::exit!(1);
|
||||||
} else {
|
} else {
|
||||||
fmt_override.add(&format!("!{ignore}")).expect(&ignore);
|
override_builder.add(&format!("!{ignore}")).expect(&ignore);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let git_available = match Command::new("git")
|
let git_available = match Command::new("git")
|
||||||
@ -138,6 +168,7 @@ pub fn format(build: &Builder<'_>, check: bool, paths: &[PathBuf]) {
|
|||||||
Err(_) => false,
|
Err(_) => false,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let mut adjective = None;
|
||||||
if git_available {
|
if git_available {
|
||||||
let in_working_tree = match build
|
let in_working_tree = match build
|
||||||
.config
|
.config
|
||||||
@ -161,127 +192,56 @@ pub fn format(build: &Builder<'_>, check: bool, paths: &[PathBuf]) {
|
|||||||
.arg("-z")
|
.arg("-z")
|
||||||
.arg("--untracked-files=normal"),
|
.arg("--untracked-files=normal"),
|
||||||
);
|
);
|
||||||
let untracked_paths = untracked_paths_output.split_terminator('\0').filter_map(
|
let untracked_paths: Vec<_> = untracked_paths_output
|
||||||
|entry| entry.strip_prefix("?? "), // returns None if the prefix doesn't match
|
.split_terminator('\0')
|
||||||
);
|
.filter_map(
|
||||||
let mut untracked_count = 0;
|
|entry| entry.strip_prefix("?? "), // returns None if the prefix doesn't match
|
||||||
|
)
|
||||||
|
.map(|x| x.to_string())
|
||||||
|
.collect();
|
||||||
|
print_paths("skipped", Some("untracked"), &untracked_paths);
|
||||||
|
|
||||||
for untracked_path in untracked_paths {
|
for untracked_path in untracked_paths {
|
||||||
println!("skip untracked path {untracked_path} during rustfmt invocations");
|
|
||||||
// The leading `/` makes it an exact match against the
|
// The leading `/` makes it an exact match against the
|
||||||
// repository root, rather than a glob. Without that, if you
|
// repository root, rather than a glob. Without that, if you
|
||||||
// have `foo.rs` in the repository root it will also match
|
// have `foo.rs` in the repository root it will also match
|
||||||
// against anything like `compiler/rustc_foo/src/foo.rs`,
|
// against anything like `compiler/rustc_foo/src/foo.rs`,
|
||||||
// preventing the latter from being formatted.
|
// preventing the latter from being formatted.
|
||||||
untracked_count += 1;
|
override_builder.add(&format!("!/{untracked_path}")).expect(&untracked_path);
|
||||||
fmt_override.add(&format!("!/{untracked_path}")).expect(untracked_path);
|
|
||||||
}
|
}
|
||||||
// Only check modified files locally to speed up runtime. We still check all files in
|
if !all {
|
||||||
// CI to avoid bugs in `get_modified_rs_files` letting regressions slip through; we
|
adjective = Some("modified");
|
||||||
// also care about CI time less since this is still very fast compared to building the
|
|
||||||
// compiler.
|
|
||||||
if !CiEnv::is_ci() && paths.is_empty() {
|
|
||||||
match get_modified_rs_files(build) {
|
match get_modified_rs_files(build) {
|
||||||
Ok(Some(files)) => {
|
Ok(Some(files)) => {
|
||||||
if files.len() <= 10 {
|
|
||||||
for file in &files {
|
|
||||||
println!("formatting modified file {file}");
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
let pluralized = |count| if count > 1 { "files" } else { "file" };
|
|
||||||
let untracked_msg = if untracked_count == 0 {
|
|
||||||
"".to_string()
|
|
||||||
} else {
|
|
||||||
format!(
|
|
||||||
", skipped {} untracked {}",
|
|
||||||
untracked_count,
|
|
||||||
pluralized(untracked_count),
|
|
||||||
)
|
|
||||||
};
|
|
||||||
println!(
|
|
||||||
"formatting {} modified {}{}",
|
|
||||||
files.len(),
|
|
||||||
pluralized(files.len()),
|
|
||||||
untracked_msg
|
|
||||||
);
|
|
||||||
}
|
|
||||||
for file in files {
|
for file in files {
|
||||||
fmt_override.add(&format!("/{file}")).expect(&file);
|
override_builder.add(&format!("/{file}")).expect(&file);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Ok(None) => {}
|
Ok(None) => {}
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
println!(
|
eprintln!("fmt warning: Something went wrong running git commands:");
|
||||||
"WARN: Something went wrong when running git commands:\n{err}\n\
|
eprintln!("fmt warning: {err}");
|
||||||
Falling back to formatting all files."
|
eprintln!("fmt warning: Falling back to formatting all files.");
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
println!("Not in git tree. Skipping git-aware format checks");
|
eprintln!("fmt: warning: Not in git tree. Skipping git-aware format checks");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
println!("Could not find usable git. Skipping git-aware format checks");
|
eprintln!("fmt: warning: Could not find usable git. Skipping git-aware format checks");
|
||||||
}
|
}
|
||||||
|
|
||||||
let fmt_override = fmt_override.build().unwrap();
|
let override_ = override_builder.build().unwrap(); // `override` is a reserved keyword
|
||||||
|
|
||||||
let rustfmt_path = build.initial_rustfmt().unwrap_or_else(|| {
|
let rustfmt_path = build.initial_rustfmt().unwrap_or_else(|| {
|
||||||
eprintln!("./x.py fmt is not supported on this channel");
|
eprintln!("fmt error: `x fmt` is not supported on this channel");
|
||||||
crate::exit!(1);
|
crate::exit!(1);
|
||||||
});
|
});
|
||||||
assert!(rustfmt_path.exists(), "{}", rustfmt_path.display());
|
assert!(rustfmt_path.exists(), "{}", rustfmt_path.display());
|
||||||
let src = build.src.clone();
|
let src = build.src.clone();
|
||||||
let (tx, rx): (SyncSender<PathBuf>, _) = std::sync::mpsc::sync_channel(128);
|
let (tx, rx): (SyncSender<PathBuf>, _) = std::sync::mpsc::sync_channel(128);
|
||||||
let walker = match paths.first() {
|
let walker = WalkBuilder::new(src.clone()).types(matcher).overrides(override_).build_parallel();
|
||||||
Some(first) => {
|
|
||||||
let find_shortcut_candidates = |p: &PathBuf| {
|
|
||||||
let mut candidates = Vec::new();
|
|
||||||
for entry in
|
|
||||||
WalkBuilder::new(src.clone()).max_depth(Some(3)).build().map_while(Result::ok)
|
|
||||||
{
|
|
||||||
if let Some(dir_name) = p.file_name() {
|
|
||||||
if entry.path().is_dir() && entry.file_name() == dir_name {
|
|
||||||
candidates.push(entry.into_path());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
candidates
|
|
||||||
};
|
|
||||||
|
|
||||||
// Only try to look for shortcut candidates for single component paths like
|
|
||||||
// `std` and not for e.g. relative paths like `../library/std`.
|
|
||||||
let should_look_for_shortcut_dir = |p: &PathBuf| p.components().count() == 1;
|
|
||||||
|
|
||||||
let mut walker = if should_look_for_shortcut_dir(first) {
|
|
||||||
if let [single_candidate] = &find_shortcut_candidates(first)[..] {
|
|
||||||
WalkBuilder::new(single_candidate)
|
|
||||||
} else {
|
|
||||||
WalkBuilder::new(first)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
WalkBuilder::new(src.join(first))
|
|
||||||
};
|
|
||||||
|
|
||||||
for path in &paths[1..] {
|
|
||||||
if should_look_for_shortcut_dir(path) {
|
|
||||||
if let [single_candidate] = &find_shortcut_candidates(path)[..] {
|
|
||||||
walker.add(single_candidate);
|
|
||||||
} else {
|
|
||||||
walker.add(path);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
walker.add(src.join(path));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
walker
|
|
||||||
}
|
|
||||||
None => WalkBuilder::new(src.clone()),
|
|
||||||
}
|
|
||||||
.types(matcher)
|
|
||||||
.overrides(fmt_override)
|
|
||||||
.build_parallel();
|
|
||||||
|
|
||||||
// There is a lot of blocking involved in spawning a child process and reading files to format.
|
// There is a lot of blocking involved in spawning a child process and reading files to format.
|
||||||
// Spawn more processes than available concurrency to keep the CPU busy.
|
// Spawn more processes than available concurrency to keep the CPU busy.
|
||||||
@ -319,16 +279,33 @@ pub fn format(build: &Builder<'_>, check: bool, paths: &[PathBuf]) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let formatted_paths = Mutex::new(Vec::new());
|
||||||
|
let formatted_paths_ref = &formatted_paths;
|
||||||
walker.run(|| {
|
walker.run(|| {
|
||||||
let tx = tx.clone();
|
let tx = tx.clone();
|
||||||
Box::new(move |entry| {
|
Box::new(move |entry| {
|
||||||
|
let cwd = std::env::current_dir();
|
||||||
let entry = t!(entry);
|
let entry = t!(entry);
|
||||||
if entry.file_type().map_or(false, |t| t.is_file()) {
|
if entry.file_type().map_or(false, |t| t.is_file()) {
|
||||||
|
formatted_paths_ref.lock().unwrap().push({
|
||||||
|
// `into_path` produces an absolute path. Try to strip `cwd` to get a shorter
|
||||||
|
// relative path.
|
||||||
|
let mut path = entry.clone().into_path();
|
||||||
|
if let Ok(cwd) = cwd {
|
||||||
|
if let Ok(path2) = path.strip_prefix(cwd) {
|
||||||
|
path = path2.to_path_buf();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
path.display().to_string()
|
||||||
|
});
|
||||||
t!(tx.send(entry.into_path()));
|
t!(tx.send(entry.into_path()));
|
||||||
}
|
}
|
||||||
ignore::WalkState::Continue
|
ignore::WalkState::Continue
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
let mut paths = formatted_paths.into_inner().unwrap();
|
||||||
|
paths.sort();
|
||||||
|
print_paths(if check { "checked" } else { "formatted" }, adjective, &paths);
|
||||||
|
|
||||||
drop(tx);
|
drop(tx);
|
||||||
|
|
||||||
|
@ -1140,7 +1140,13 @@ HELP: to skip test's attempt to check tidiness, pass `--skip src/tools/tidy` to
|
|||||||
);
|
);
|
||||||
crate::exit!(1);
|
crate::exit!(1);
|
||||||
}
|
}
|
||||||
crate::core::build_steps::format::format(builder, !builder.config.cmd.bless(), &[]);
|
let all = false;
|
||||||
|
crate::core::build_steps::format::format(
|
||||||
|
builder,
|
||||||
|
!builder.config.cmd.bless(),
|
||||||
|
all,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.info("tidy check");
|
builder.info("tidy check");
|
||||||
|
@ -284,8 +284,8 @@ pub enum Subcommand {
|
|||||||
name = "fmt",
|
name = "fmt",
|
||||||
long_about = "\n
|
long_about = "\n
|
||||||
Arguments:
|
Arguments:
|
||||||
This subcommand optionally accepts a `--check` flag which succeeds if formatting is correct and
|
This subcommand optionally accepts a `--check` flag which succeeds if
|
||||||
fails if it is not. For example:
|
formatting is correct and fails if it is not. For example:
|
||||||
./x.py fmt
|
./x.py fmt
|
||||||
./x.py fmt --check"
|
./x.py fmt --check"
|
||||||
)]
|
)]
|
||||||
@ -294,6 +294,10 @@ pub enum Subcommand {
|
|||||||
/// check formatting instead of applying
|
/// check formatting instead of applying
|
||||||
#[arg(long)]
|
#[arg(long)]
|
||||||
check: bool,
|
check: bool,
|
||||||
|
|
||||||
|
/// apply to all appropriate files, not just those that have been modified
|
||||||
|
#[arg(long)]
|
||||||
|
all: bool,
|
||||||
},
|
},
|
||||||
#[command(aliases = ["d"], long_about = "\n
|
#[command(aliases = ["d"], long_about = "\n
|
||||||
Arguments:
|
Arguments:
|
||||||
|
@ -660,10 +660,11 @@ impl Build {
|
|||||||
|
|
||||||
// hardcoded subcommands
|
// hardcoded subcommands
|
||||||
match &self.config.cmd {
|
match &self.config.cmd {
|
||||||
Subcommand::Format { check } => {
|
Subcommand::Format { check, all } => {
|
||||||
return core::build_steps::format::format(
|
return core::build_steps::format::format(
|
||||||
&builder::Builder::new(self),
|
&builder::Builder::new(self),
|
||||||
*check,
|
*check,
|
||||||
|
*all,
|
||||||
&self.config.paths,
|
&self.config.paths,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -216,6 +216,7 @@ complete -c x.py -n "__fish_seen_subcommand_from fmt" -l llvm-profile-use -d 'us
|
|||||||
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l reproducible-artifact -d 'Additional reproducible artifacts that should be added to the reproducible artifacts archive' -r
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l reproducible-artifact -d 'Additional reproducible artifacts that should be added to the reproducible artifacts archive' -r
|
||||||
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l set -d 'override options in config.toml' -r -f
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l set -d 'override options in config.toml' -r -f
|
||||||
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l check -d 'check formatting instead of applying'
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l check -d 'check formatting instead of applying'
|
||||||
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l all -d 'apply to all appropriate files, not just those that have been modified'
|
||||||
complete -c x.py -n "__fish_seen_subcommand_from fmt" -s v -l verbose -d 'use verbose output (-vv for very verbose)'
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -s v -l verbose -d 'use verbose output (-vv for very verbose)'
|
||||||
complete -c x.py -n "__fish_seen_subcommand_from fmt" -s i -l incremental -d 'use incremental compilation'
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -s i -l incremental -d 'use incremental compilation'
|
||||||
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l include-default-paths -d 'include default paths in addition to the provided ones'
|
complete -c x.py -n "__fish_seen_subcommand_from fmt" -l include-default-paths -d 'include default paths in addition to the provided ones'
|
||||||
|
@ -275,6 +275,7 @@ Register-ArgumentCompleter -Native -CommandName 'x.py' -ScriptBlock {
|
|||||||
[CompletionResult]::new('--reproducible-artifact', 'reproducible-artifact', [CompletionResultType]::ParameterName, 'Additional reproducible artifacts that should be added to the reproducible artifacts archive')
|
[CompletionResult]::new('--reproducible-artifact', 'reproducible-artifact', [CompletionResultType]::ParameterName, 'Additional reproducible artifacts that should be added to the reproducible artifacts archive')
|
||||||
[CompletionResult]::new('--set', 'set', [CompletionResultType]::ParameterName, 'override options in config.toml')
|
[CompletionResult]::new('--set', 'set', [CompletionResultType]::ParameterName, 'override options in config.toml')
|
||||||
[CompletionResult]::new('--check', 'check', [CompletionResultType]::ParameterName, 'check formatting instead of applying')
|
[CompletionResult]::new('--check', 'check', [CompletionResultType]::ParameterName, 'check formatting instead of applying')
|
||||||
|
[CompletionResult]::new('--all', 'all', [CompletionResultType]::ParameterName, 'apply to all appropriate files, not just those that have been modified')
|
||||||
[CompletionResult]::new('-v', 'v', [CompletionResultType]::ParameterName, 'use verbose output (-vv for very verbose)')
|
[CompletionResult]::new('-v', 'v', [CompletionResultType]::ParameterName, 'use verbose output (-vv for very verbose)')
|
||||||
[CompletionResult]::new('--verbose', 'verbose', [CompletionResultType]::ParameterName, 'use verbose output (-vv for very verbose)')
|
[CompletionResult]::new('--verbose', 'verbose', [CompletionResultType]::ParameterName, 'use verbose output (-vv for very verbose)')
|
||||||
[CompletionResult]::new('-i', 'i', [CompletionResultType]::ParameterName, 'use incremental compilation')
|
[CompletionResult]::new('-i', 'i', [CompletionResultType]::ParameterName, 'use incremental compilation')
|
||||||
|
@ -1077,7 +1077,7 @@ _x.py() {
|
|||||||
return 0
|
return 0
|
||||||
;;
|
;;
|
||||||
x.py__fmt)
|
x.py__fmt)
|
||||||
opts="-v -i -j -h --check --verbose --incremental --config --build-dir --build --host --target --exclude --skip --include-default-paths --rustc-error-format --on-fail --dry-run --dump-bootstrap-shims --stage --keep-stage --keep-stage-std --src --jobs --warnings --error-format --json-output --color --bypass-bootstrap-lock --llvm-skip-rebuild --rust-profile-generate --rust-profile-use --llvm-profile-use --llvm-profile-generate --enable-bolt-settings --skip-stage0-validation --reproducible-artifact --set --help [PATHS]... [ARGS]..."
|
opts="-v -i -j -h --check --all --verbose --incremental --config --build-dir --build --host --target --exclude --skip --include-default-paths --rustc-error-format --on-fail --dry-run --dump-bootstrap-shims --stage --keep-stage --keep-stage-std --src --jobs --warnings --error-format --json-output --color --bypass-bootstrap-lock --llvm-skip-rebuild --rust-profile-generate --rust-profile-use --llvm-profile-use --llvm-profile-generate --enable-bolt-settings --skip-stage0-validation --reproducible-artifact --set --help [PATHS]... [ARGS]..."
|
||||||
if [[ ${cur} == -* || ${COMP_CWORD} -eq 2 ]] ; then
|
if [[ ${cur} == -* || ${COMP_CWORD} -eq 2 ]] ; then
|
||||||
COMPREPLY=( $(compgen -W "${opts}" -- "${cur}") )
|
COMPREPLY=( $(compgen -W "${opts}" -- "${cur}") )
|
||||||
return 0
|
return 0
|
||||||
|
@ -271,6 +271,7 @@ _arguments "${_arguments_options[@]}" \
|
|||||||
'*--reproducible-artifact=[Additional reproducible artifacts that should be added to the reproducible artifacts archive]:REPRODUCIBLE_ARTIFACT: ' \
|
'*--reproducible-artifact=[Additional reproducible artifacts that should be added to the reproducible artifacts archive]:REPRODUCIBLE_ARTIFACT: ' \
|
||||||
'*--set=[override options in config.toml]:section.option=value:( )' \
|
'*--set=[override options in config.toml]:section.option=value:( )' \
|
||||||
'--check[check formatting instead of applying]' \
|
'--check[check formatting instead of applying]' \
|
||||||
|
'--all[apply to all appropriate files, not just those that have been modified]' \
|
||||||
'*-v[use verbose output (-vv for very verbose)]' \
|
'*-v[use verbose output (-vv for very verbose)]' \
|
||||||
'*--verbose[use verbose output (-vv for very verbose)]' \
|
'*--verbose[use verbose output (-vv for very verbose)]' \
|
||||||
'-i[use incremental compilation]' \
|
'-i[use incremental compilation]' \
|
||||||
|
Loading…
Reference in New Issue
Block a user