##// END OF EJS Templates
rust-pyo3: intermediate ProxyIndex extraction...
rust-pyo3: intermediate ProxyIndex extraction Retrieving the `UnsafePyLeaked` without borrowing it will be necessary for the upcoming classes that need to store an inner object derived from it.

File last commit:

r50809:58074252 default
r53424:64a61804 default
Show More
debugrhgsparse.rs
49 lines | 1.5 KiB | application/rls-services+xml | RustLexer
/ rust / rhg / src / commands / debugrhgsparse.rs
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 use std::{
ffi::{OsStr, OsString},
os::unix::prelude::OsStrExt,
};
Raphaël Gomès
rhg: add debugrhgsparse command to help figure out bugs in rhg
r50379
use crate::error::CommandError;
use hg::{self, utils::hg_path::HgPath};
pub const HELP_TEXT: &str = "";
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 pub fn args() -> clap::Command {
clap::command!("debugrhgsparse")
Raphaël Gomès
rhg: add debugrhgsparse command to help figure out bugs in rhg
r50379 .arg(
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 clap::Arg::new("files")
.value_name("FILES")
Raphaël Gomès
rhg: add debugrhgsparse command to help figure out bugs in rhg
r50379 .required(true)
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 .num_args(1..)
.value_parser(clap::value_parser!(std::ffi::OsString))
Raphaël Gomès
rhg: add debugrhgsparse command to help figure out bugs in rhg
r50379 .help("Files to check against sparse profile"),
)
.about(HELP_TEXT)
}
pub fn run(invocation: &crate::CliInvocation) -> Result<(), CommandError> {
let repo = invocation.repo?;
Raphaël Gomès
rust: run `cargo clippy`...
r50809 let (matcher, _warnings) = hg::sparse::matcher(repo).unwrap();
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 let files = invocation.subcommand_args.get_many::<OsString>("files");
Raphaël Gomès
rhg: add debugrhgsparse command to help figure out bugs in rhg
r50379 if let Some(files) = files {
Raphaël Gomès
rhg: upgrade `clap` dependency...
r50534 let files: Vec<&OsStr> = files
.filter(|s| !s.is_empty())
.map(|s| s.as_os_str())
.collect();
Raphaël Gomès
rhg: add debugrhgsparse command to help figure out bugs in rhg
r50379 for file in files {
invocation.ui.write_stdout(b"matches: ")?;
invocation.ui.write_stdout(
if matcher.matches(HgPath::new(file.as_bytes())) {
b"yes"
} else {
b"no"
},
)?;
invocation.ui.write_stdout(b" | file: ")?;
invocation.ui.write_stdout(file.as_bytes())?;
invocation.ui.write_stdout(b"\n")?;
}
}
Ok(())
}