Mercurial > hg
view rust/rhg/src/commands/debugrhgsparse.rs @ 52273:fdecc547a75d stable
rhg-status: rename a variable to be more explicit
Possibly we would have caught the looming bug earlier if this had been named
closer to what it actual is used for.
author | Raphaël Gomès <rgomes@octobus.net> |
---|---|
date | Mon, 18 Nov 2024 15:02:59 +0100 |
parents | 58074252db3c |
children |
line wrap: on
line source
use std::{ ffi::{OsStr, OsString}, os::unix::prelude::OsStrExt, }; use crate::error::CommandError; use hg::{self, utils::hg_path::HgPath}; pub const HELP_TEXT: &str = ""; pub fn args() -> clap::Command { clap::command!("debugrhgsparse") .arg( clap::Arg::new("files") .value_name("FILES") .required(true) .num_args(1..) .value_parser(clap::value_parser!(std::ffi::OsString)) .help("Files to check against sparse profile"), ) .about(HELP_TEXT) } pub fn run(invocation: &crate::CliInvocation) -> Result<(), CommandError> { let repo = invocation.repo?; let (matcher, _warnings) = hg::sparse::matcher(repo).unwrap(); let files = invocation.subcommand_args.get_many::<OsString>("files"); if let Some(files) = files { let files: Vec<&OsStr> = files .filter(|s| !s.is_empty()) .map(|s| s.as_os_str()) .collect(); 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(()) }