##// END OF EJS Templates
rust-index: optimize find_gca_candidates() on less than 8 revisions...
rust-index: optimize find_gca_candidates() on less than 8 revisions This is expected to be by far the most common case, given that, e.g., merging involves using it on two revisions. Using a `u8` as support for the bitset obviously divides the amount of RAM needed by 8. To state the obvious, on a repository with 10 million changesets, this spares 70MB. It is also possible that it'd be slightly faster, because it is easier to allocate and provides better cache locality. It is possible that some exhaustive listing of the traits implemented by `u8` and `u64` would avoid the added duplication, but that can be done later and would need a replacement for the `MAX` consts.

File last commit:

r51872:4c5f6e95 default
r52122:1b23aaf5 default
Show More
dagops.rs
74 lines | 2.5 KiB | application/rls-services+xml | RustLexer
Georges Racinet
rust-cpython: binding for headrevs()...
r41843 // dagops.rs
//
// Copyright 2019 Georges Racinet <georges.racinet@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.
//! Bindings for the `hg::dagops` module provided by the
//! `hg-core` package.
//!
//! From Python, this will be seen as `mercurial.rustext.dagop`
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 use crate::PyRevision;
rust-index: add a function to convert PyObject index for hg-core...
r44398 use crate::{conversion::rev_pyiter_collect, exceptions::GraphError};
Georges Racinet
rust-cpython: binding for headrevs()...
r41843 use cpython::{PyDict, PyModule, PyObject, PyResult, Python};
use hg::dagops;
use hg::Revision;
use std::collections::HashSet;
pacien
rust: expose rank computation function to python...
r49709 use vcsgraph::ancestors::node_rank;
use vcsgraph::graph::{Parents, Rank};
Georges Racinet
rust-cpython: binding for headrevs()...
r41843
rust-index: add a function to convert PyObject index for hg-core...
r44398 use crate::revlog::pyindex_to_graph;
Georges Racinet
rust-cpython: binding for headrevs()...
r41843 /// Using the the `index`, return heads out of any Python iterable of Revisions
///
/// This is the Rust counterpart for `mercurial.dagop.headrevs`
pub fn headrevs(
py: Python,
index: PyObject,
revs: PyObject,
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 ) -> PyResult<HashSet<PyRevision>> {
let index = pyindex_to_graph(py, index)?;
let mut as_set: HashSet<Revision> = rev_pyiter_collect(py, &revs, &index)?;
dagops::retain_heads(&index, &mut as_set)
Georges Racinet
rust-cpython: binding for headrevs()...
r41843 .map_err(|e| GraphError::pynew(py, e))?;
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 Ok(as_set.into_iter().map(Into::into).collect())
Georges Racinet
rust-cpython: binding for headrevs()...
r41843 }
pacien
rust: expose rank computation function to python...
r49709 /// Computes the rank, i.e. the number of ancestors including itself,
/// of a node represented by its parents.
pub fn rank(
py: Python,
index: PyObject,
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 p1r: PyRevision,
p2r: PyRevision,
pacien
rust: expose rank computation function to python...
r49709 ) -> PyResult<Rank> {
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 node_rank(&pyindex_to_graph(py, index)?, &Parents([p1r.0, p2r.0]))
pacien
rust: expose rank computation function to python...
r49709 .map_err(|e| GraphError::pynew_from_vcsgraph(py, e))
}
Georges Racinet
rust-cpython: binding for headrevs()...
r41843 /// Create the module, with `__package__` given from parent
pub fn init_module(py: Python, package: &str) -> PyResult<PyModule> {
let dotted_name = &format!("{}.dagop", package);
let m = PyModule::new(py, dotted_name)?;
m.add(py, "__package__", package)?;
m.add(py, "__doc__", "DAG operations - Rust implementation")?;
m.add(
py,
"headrevs",
py_fn!(py, headrevs(index: PyObject, revs: PyObject)),
)?;
pacien
rust: expose rank computation function to python...
r49709 m.add(
py,
"rank",
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 py_fn!(py, rank(index: PyObject, p1r: PyRevision, p2r: PyRevision)),
pacien
rust: expose rank computation function to python...
r49709 )?;
Georges Racinet
rust-cpython: binding for headrevs()...
r41843
let sys = PyModule::import(py, "sys")?;
let sys_modules: PyDict = sys.get(py, "modules")?.extract(py)?;
sys_modules.set_item(py, dotted_name, &m)?;
// Example C code (see pyexpat.c and import.c) will "give away the
// reference", but we won't because it will be consumed once the
// Rust PyObject is dropped.
Ok(m)
}