##// END OF EJS Templates
rhg: Also parse flags in the manifest parser...
rhg: Also parse flags in the manifest parser Differential Revision: https://phab.mercurial-scm.org/D11772

File last commit:

r49165:10c32e1b default
r49166:eb428010 default
Show More
path_utils.rs
49 lines | 1.6 KiB | application/rls-services+xml | RustLexer
Pulkit Goyal
rhg: refactor function to relativize paths in utils...
r48988 // path utils module
//
// This software may be used and distributed according to the terms of the
// GNU General Public License version 2 or any later version.
use crate::error::CommandError;
use crate::ui::UiError;
Simon Sapin
rhg: Propogate manifest parse errors instead of panicking...
r49165 use hg::errors::HgError;
Pulkit Goyal
rhg: refactor function to relativize paths in utils...
r48988 use hg::repo::Repo;
use hg::utils::current_dir;
use hg::utils::files::{get_bytes_from_path, relativize_path};
use hg::utils::hg_path::HgPath;
use hg::utils::hg_path::HgPathBuf;
use std::borrow::Cow;
pub fn relativize_paths(
repo: &Repo,
Simon Sapin
rhg: Propogate manifest parse errors instead of panicking...
r49165 paths: impl IntoIterator<Item = Result<impl AsRef<HgPath>, HgError>>,
Pulkit Goyal
rhg: refactor function to relativize paths in utils...
r48988 mut callback: impl FnMut(Cow<[u8]>) -> Result<(), UiError>,
) -> Result<(), CommandError> {
let cwd = current_dir()?;
let repo_root = repo.working_directory_path();
let repo_root = cwd.join(repo_root); // Make it absolute
let repo_root_hgpath =
HgPathBuf::from(get_bytes_from_path(repo_root.to_owned()));
let outside_repo: bool;
let cwd_hgpath: HgPathBuf;
if let Ok(cwd_relative_to_repo) = cwd.strip_prefix(&repo_root) {
// The current directory is inside the repo, so we can work with
// relative paths
outside_repo = false;
cwd_hgpath =
HgPathBuf::from(get_bytes_from_path(cwd_relative_to_repo));
} else {
outside_repo = true;
cwd_hgpath = HgPathBuf::from(get_bytes_from_path(cwd));
}
for file in paths {
if outside_repo {
Simon Sapin
rhg: Propogate manifest parse errors instead of panicking...
r49165 let file = repo_root_hgpath.join(file?.as_ref());
Pulkit Goyal
rhg: refactor function to relativize paths in utils...
r48988 callback(relativize_path(&file, &cwd_hgpath))?;
} else {
Simon Sapin
rhg: Propogate manifest parse errors instead of panicking...
r49165 callback(relativize_path(file?.as_ref(), &cwd_hgpath))?;
Pulkit Goyal
rhg: refactor function to relativize paths in utils...
r48988 }
}
Ok(())
}