use std::collections::HashMap;
use std::path::Path;
use anyhow::Result;
use crate::graph::*;
use crate::properties;
use crate::NodeType;
#[derive(Clone, Debug)]
pub struct Transposed<G: SwhGraph>(pub G);
impl<G: SwhGraph> SwhGraph for Transposed<G> {
#[inline(always)]
fn path(&self) -> &Path {
self.0.path()
}
#[inline(always)]
fn is_transposed(&self) -> bool {
!self.0.is_transposed()
}
#[inline(always)]
fn num_nodes(&self) -> usize {
self.0.num_nodes()
}
#[inline(always)]
fn num_arcs(&self) -> u64 {
self.0.num_arcs()
}
fn num_arcs_by_type(&self) -> Result<HashMap<(NodeType, NodeType), usize>> {
Ok(self
.0
.num_arcs_by_type()?
.into_iter()
.map(|((src_type, dst_type), count)| ((dst_type, src_type), count))
.collect())
}
#[inline(always)]
fn has_node(&self, node_id: NodeId) -> bool {
self.0.has_node(node_id)
}
#[inline(always)]
fn has_arc(&self, src_node_id: NodeId, dst_node_id: NodeId) -> bool {
self.0.has_arc(dst_node_id, src_node_id)
}
}
impl<G: SwhBackwardGraph> SwhForwardGraph for Transposed<G> {
type Successors<'succ>
= <G as SwhBackwardGraph>::Predecessors<'succ>
where
Self: 'succ;
#[inline(always)]
fn successors(&self, node_id: NodeId) -> Self::Successors<'_> {
self.0.predecessors(node_id)
}
#[inline(always)]
fn outdegree(&self, node_id: NodeId) -> usize {
self.0.indegree(node_id)
}
}
impl<G: SwhLabeledBackwardGraph> SwhLabeledForwardGraph for Transposed<G> {
type LabeledArcs<'arc>
= <G as SwhLabeledBackwardGraph>::LabeledArcs<'arc>
where
Self: 'arc;
type LabeledSuccessors<'succ>
= <G as SwhLabeledBackwardGraph>::LabeledPredecessors<'succ>
where
Self: 'succ;
#[inline(always)]
fn untyped_labeled_successors(&self, node_id: NodeId) -> Self::LabeledSuccessors<'_> {
self.0.untyped_labeled_predecessors(node_id)
}
}
impl<G: SwhForwardGraph> SwhBackwardGraph for Transposed<G> {
type Predecessors<'succ>
= <G as SwhForwardGraph>::Successors<'succ>
where
Self: 'succ;
#[inline(always)]
fn predecessors(&self, node_id: NodeId) -> Self::Predecessors<'_> {
self.0.successors(node_id)
}
#[inline(always)]
fn indegree(&self, node_id: NodeId) -> usize {
self.0.outdegree(node_id)
}
}
impl<G: SwhLabeledForwardGraph> SwhLabeledBackwardGraph for Transposed<G> {
type LabeledArcs<'arc>
= <G as SwhLabeledForwardGraph>::LabeledArcs<'arc>
where
Self: 'arc;
type LabeledPredecessors<'succ>
= <G as SwhLabeledForwardGraph>::LabeledSuccessors<'succ>
where
Self: 'succ;
#[inline(always)]
fn untyped_labeled_predecessors(&self, node_id: NodeId) -> Self::LabeledPredecessors<'_> {
self.0.untyped_labeled_successors(node_id)
}
}
impl<G: SwhGraphWithProperties> SwhGraphWithProperties for Transposed<G> {
type Maps = <G as SwhGraphWithProperties>::Maps;
type Timestamps = <G as SwhGraphWithProperties>::Timestamps;
type Persons = <G as SwhGraphWithProperties>::Persons;
type Contents = <G as SwhGraphWithProperties>::Contents;
type Strings = <G as SwhGraphWithProperties>::Strings;
type LabelNames = <G as SwhGraphWithProperties>::LabelNames;
#[inline(always)]
fn properties(
&self,
) -> &properties::SwhGraphProperties<
Self::Maps,
Self::Timestamps,
Self::Persons,
Self::Contents,
Self::Strings,
Self::LabelNames,
> {
self.0.properties()
}
}