##// END OF EJS Templates
rust: make RevlogError AmbiguousPrefix case contain the actual prefix...
rust: make RevlogError AmbiguousPrefix case contain the actual prefix This brings the work started in `652149ed64f0` to its logical conclusion and makes the RevlogError self-sufficient so it can be directly converted to CommandError, without an extra rev text annotation. Without this change, it's confusing that the extra annotation is ignored in most-but-not-all cases.

File last commit:

r52938:652149ed default
r53240:393ad268 default
Show More
revset.rs
71 lines | 2.3 KiB | application/rls-services+xml | RustLexer
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 //! The revset query language
//!
//! <https://www.mercurial-scm.org/repo/hg/help/revsets>
Simon Sapin
rhg: Fall back to Python for unsupported revset syntax...
r47459 use crate::errors::HgError;
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 use crate::repo::Repo;
use crate::revlog::NodePrefix;
Pulkit Goyal
rhg: raise wdir specific error for `hg debugdata`...
r47577 use crate::revlog::{Revision, NULL_REVISION, WORKING_DIRECTORY_HEX};
Raphaël Gomès
rust-clippy: merge "revlog" module definition and struct implementation...
r50832 use crate::revlog::{Revlog, RevlogError};
Pulkit Goyal
rhg: raise wdir specific error for `hg debugdata`...
r47577 use crate::Node;
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162
/// Resolve a query string into a single revision.
///
/// Only some of the revset language is implemented yet.
pub fn resolve_single(
input: &str,
repo: &Repo,
) -> Result<Revision, RevlogError> {
Simon Sapin
rust: Keep lazily-initialized Changelog and Manifest log on the Repo object...
r48773 let changelog = repo.changelog()?;
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162
Raphaël Gomès
rust-revset: add separate match logic for shortcuts...
r48892 match input {
Raphaël Gomès
rust-revset: support explicit `.` revision...
r48893 "." => {
let p1 = repo.dirstate_parents()?.p1;
Raphaël Gomès
rust-clippy: fix most warnings in `hg-core`...
r50825 return changelog.revlog.rev_from_node(p1.into());
Raphaël Gomès
rust-revset: support explicit `.` revision...
r48893 }
Raphaël Gomès
rust-revset: add separate match logic for shortcuts...
r48892 "null" => return Ok(NULL_REVISION),
_ => {}
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 }
Raphaël Gomès
rust-revset: add separate match logic for shortcuts...
r48892 match resolve_rev_number_or_hex_prefix(input, &changelog.revlog) {
Raphaël Gomès
rust: improve `InvalidRevision` error message...
r52938 Err(RevlogError::InvalidRevision(revision)) => {
Raphaël Gomès
rust-revset: add separate match logic for shortcuts...
r48892 // TODO: support for the rest of the language here.
Raphaël Gomès
rust: improve `InvalidRevision` error message...
r52938 let msg = format!("cannot parse revset '{}'", revision);
Raphaël Gomès
rust-revset: add separate match logic for shortcuts...
r48892 Err(HgError::unsupported(msg).into())
}
Raphaël Gomès
rust-clippy: fix most warnings in `hg-core`...
r50825 result => result,
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 }
}
/// Resolve the small subset of the language suitable for revlogs other than
/// the changelog, such as in `hg debugdata --manifest` CLI argument.
///
/// * A non-negative decimal integer for a revision number, or
/// * An hexadecimal string, for the unique node ID that starts with this
/// prefix
pub fn resolve_rev_number_or_hex_prefix(
input: &str,
revlog: &Revlog,
) -> Result<Revision, RevlogError> {
Simon Sapin
rhg: Align with Python on some revset parsing corner cases...
r48776 // The Python equivalent of this is part of `revsymbol` in
// `mercurial/scmutil.py`
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 if let Ok(integer) = input.parse::<i32>() {
Simon Sapin
rhg: Align with Python on some revset parsing corner cases...
r48776 if integer.to_string() == input
&& integer >= 0
Raphaël Gomès
rust: use the new `UncheckedRevision` everywhere applicable...
r51870 && revlog.has_rev(integer.into())
Simon Sapin
rhg: Align with Python on some revset parsing corner cases...
r48776 {
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 // This is fine because we've just checked that the revision is
// valid for the given revlog.
return Ok(Revision(integer));
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 }
}
if let Ok(prefix) = NodePrefix::from_hex(input) {
Pulkit Goyal
rhg: raise wdir specific error for `hg debugdata`...
r47577 if prefix.is_prefix_of(&Node::from_hex(WORKING_DIRECTORY_HEX).unwrap())
{
return Err(RevlogError::WDirUnsupported);
}
Simon Sapin
rust: Rename the `Revlog::get_node_rev` method to `rev_from_node`...
r48782 return revlog.rev_from_node(prefix);
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 }
Raphaël Gomès
rust: improve `InvalidRevision` error message...
r52938 Err(RevlogError::InvalidRevision(input.to_string()))
Simon Sapin
rhg: centralize parsing of `--rev` CLI arguments...
r47162 }