##// END OF EJS Templates
rust: run a clippy pass with the latest stable version...
rust: run a clippy pass with the latest stable version Our current version of clippy is older than the latest stable. The newest version has new lints that are moslty good advice, so let's apply them ahead of time. This has the added benefit of reducing the noise for developpers like myself that use clippy as an IDE helper, as well as being more prepared for a future clippy upgrade.

File last commit:

r51872:4c5f6e95 default
r52013:532e74ad 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)
}