#![doc = include_str!("../README.md")]
use std::collections::HashMap;
use uuid::Uuid;
#[derive(Debug)]
pub struct Graph<Node, EdgeData> {
pub nodes: HashMap<NodeIndex, Node>,
pub edges: HashMap<EdgeIndex, Edge<EdgeData>>,
}
#[derive(Debug, Clone)]
pub struct Edge<Data> {
pub nodes: (NodeIndex, NodeIndex),
pub data: Data,
}
impl<Data> Edge<Data> {
pub fn new(nodes: (NodeIndex, NodeIndex), data: Data) -> Edge<Data> {
Edge {
nodes,
data,
}
}
}
#[derive(Debug, Clone, Copy, Eq, Hash, Ord, PartialEq, PartialOrd)]
pub struct NodeIndex(Uuid);
#[derive(Debug, Clone, Copy, Eq, Hash, Ord, PartialEq, PartialOrd)]
pub struct EdgeIndex(Uuid);
impl NodeIndex {
pub fn new() -> NodeIndex {
NodeIndex(Uuid::new_v4())
}
}
impl EdgeIndex {
pub fn new() -> EdgeIndex {
EdgeIndex(Uuid::new_v4())
}
}
impl<Node, EdgeData> Graph<Node, EdgeData> {
pub fn new() -> Self {
Self {
nodes: HashMap::new(),
edges: HashMap::new()
}
}
pub fn nodes<'a>(&'a self) -> impl Iterator + 'a {
self.nodes.iter()
}
pub fn edges<'a>(&'a self) -> impl Iterator + 'a {
self.edges.iter()
}
pub fn edge(&mut self, edge: Edge<EdgeData>) -> EdgeIndex {
let idx = EdgeIndex::new();
self.edges.insert(idx, edge);
idx
}
pub fn r_edge(&mut self, idx: EdgeIndex) -> Option<Edge<EdgeData>> {
self.edges.remove(&idx)
}
pub fn node(&mut self, node: Node) -> NodeIndex {
let idx = NodeIndex::new();
self.nodes.insert(idx, node);
idx
}
pub fn r_node(&mut self, idx: NodeIndex) -> Option<Node> {
self.nodes.remove(&idx)
}
}
pub mod prelude {
pub use crate::{
Graph,
NodeIndex,
EdgeIndex,
Edge,
};
}