Mercurial > public > mercurial-scm > hg
view rust/hg-core/src/operations/debugdata.rs @ 52969:874c64e041b5
rhg-annotate: support whitespace options
This adds support to rhg annotate for all the whitespace options:
-w, --ignore-all-space
-b, --ignore-space-change
-B, --ignore-blank-lines
-Z, --ignore-space-at-eol
Note that --ignore-blank-lines has no effect on annotate so it is ignored. You
can see this in dagop.py _annotepair which only checks if blocks are '=' or not,
whereas the effect of --ignore-blank-lines is to change some '!' into '~'.
When the other 3 are combined, we use the strongest option since -w implies -b
and -b implies -Z. This is not explicit in the Python implementation, but I have
verified that's how it behaves.
author | Mitchell Kember <mkember@janestreet.com> |
---|---|
date | Fri, 07 Feb 2025 17:42:43 -0500 |
parents | a3fa37bdb7ec |
children |
line wrap: on
line source
// debugdata.rs // // Copyright 2020 Antoine Cezar <antoine.cezar@octobus.net> // // 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::errors::HgError; use crate::exit_codes; use crate::repo::Repo; use crate::revlog::options::default_revlog_options; use crate::revlog::{Revlog, RevlogError, RevlogType}; /// Dump the contents data of a revision. pub fn debug_data( repo: &Repo, revset: &str, kind: RevlogType, ) -> Result<Vec<u8>, RevlogError> { let index_file = match kind { RevlogType::Changelog => "00changelog.i", RevlogType::Manifestlog => "00manifest.i", _ => { return Err(RevlogError::Other(HgError::abort( format!("invalid revlog type {}", kind), exit_codes::ABORT, None, ))) } }; let revlog = Revlog::open( &repo.store_vfs(), index_file, None, default_revlog_options( repo.config(), repo.requirements(), RevlogType::Changelog, )?, )?; let rev = crate::revset::resolve_rev_number_or_hex_prefix(revset, &revlog)?; let data = revlog.get_data(rev)?; Ok(data.into_owned()) }