revlog.rs
71 lines
| 2.2 KiB
| application/rls-services+xml
|
RustLexer
Georges Racinet
|
r44457 | // Copyright 2018-2020 Georges Racinet <georges.racinet@octobus.net> | ||
// and Mercurial contributors | ||||
// | ||||
// This software may be used and distributed according to the terms of the | ||||
// GNU General Public License version 2 or any later version. | ||||
//! Mercurial concepts for handling revision history | ||||
Georges Racinet
|
r44601 | pub mod node; | ||
Georges Racinet
|
r44600 | pub mod nodemap; | ||
Simon Sapin
|
r46706 | mod nodemap_docket; | ||
Antoine Cezar
|
r46110 | pub mod path_encode; | ||
Simon Sapin
|
r47160 | pub use node::{FromHexError, Node, NodePrefix}; | ||
Antoine Cezar
|
r46103 | pub mod changelog; | ||
Antoine Cezar
|
r46097 | pub mod index; | ||
Antoine Cezar
|
r46104 | pub mod manifest; | ||
Antoine Cezar
|
r46097 | pub mod patch; | ||
pub mod revlog; | ||||
Georges Racinet
|
r44600 | |||
Georges Racinet
|
r44457 | /// Mercurial revision numbers | ||
/// | ||||
/// As noted in revlog.c, revision numbers are actually encoded in | ||||
/// 4 bytes, and are liberally converted to ints, whence the i32 | ||||
pub type Revision = i32; | ||||
/// Marker expressing the absence of a parent | ||||
/// | ||||
/// Independently of the actual representation, `NULL_REVISION` is guaranteed | ||||
Aay Jay Chan
|
r44547 | /// to be smaller than all existing revisions. | ||
Georges Racinet
|
r44457 | pub const NULL_REVISION: Revision = -1; | ||
/// Same as `mercurial.node.wdirrev` | ||||
/// | ||||
/// This is also equal to `i32::max_value()`, but it's better to spell | ||||
/// it out explicitely, same as in `mercurial.node` | ||||
Raphaël Gomès
|
r45500 | #[allow(clippy::unreadable_literal)] | ||
Georges Racinet
|
r44457 | pub const WORKING_DIRECTORY_REVISION: Revision = 0x7fffffff; | ||
Pulkit Goyal
|
r47577 | pub const WORKING_DIRECTORY_HEX: &str = | ||
"ffffffffffffffffffffffffffffffffffffffff"; | ||||
Georges Racinet
|
r44457 | /// The simplest expression of what we need of Mercurial DAGs. | ||
pub trait Graph { | ||||
/// Return the two parents of the given `Revision`. | ||||
/// | ||||
/// Each of the parents can be independently `NULL_REVISION` | ||||
fn parents(&self, rev: Revision) -> Result<[Revision; 2], GraphError>; | ||||
} | ||||
#[derive(Clone, Debug, PartialEq)] | ||||
pub enum GraphError { | ||||
ParentOutOfRange(Revision), | ||||
WorkingDirectoryUnsupported, | ||||
} | ||||
Georges Racinet
|
r44642 | |||
/// The Mercurial Revlog Index | ||||
/// | ||||
/// This is currently limited to the minimal interface that is needed for | ||||
/// the [`nodemap`](nodemap/index.html) module | ||||
pub trait RevlogIndex { | ||||
/// Total number of Revisions referenced in this index | ||||
fn len(&self) -> usize; | ||||
Raphaël Gomès
|
r45500 | fn is_empty(&self) -> bool { | ||
self.len() == 0 | ||||
} | ||||
Georges Racinet
|
r44642 | /// Return a reference to the Node or `None` if rev is out of bounds | ||
/// | ||||
/// `NULL_REVISION` is not considered to be out of bounds. | ||||
fn node(&self, rev: Revision) -> Option<&Node>; | ||||
} | ||||