blob: bbfd0a286a2f1f80bcee5698560b441079643fce [file] [log] [blame]
#![allow(unstable)]
//! **petgraph** is a graph data structure library.
//!
//! The most interesting type is [**Graph\<N, E, Ty\>**](./graph/struct.Graph.html) which is
//! a directed or undirected graph with owned mutably accessible arbitrary node and edge weights.
//! It is based on rustc's graph implementation.
use std::cmp::Ordering;
use std::hash::{self, Hash};
use std::collections::hash_map::Hasher;
use std::fmt;
use std::ops::{Deref};
pub use scored::MinScored;
pub use graphmap::GraphMap;
pub use graph::Graph;
pub use self::EdgeDirection::{Outgoing, Incoming};
pub use visit::{
Bfs,
BfsIter,
Dfs,
DfsIter,
};
mod scored;
pub mod graphmap;
pub mod graph;
pub mod visit;
pub mod unionfind;
// Index into the NodeIndex and EdgeIndex arrays
/// Edge direction
#[derive(Copy, Clone, Show, PartialEq)]
pub enum EdgeDirection {
/// A **Outgoing** edge is an outward edge *from* the current node.
Outgoing = 0,
/// An **Incoming** edge is an inbound edge *to* the current node.
Incoming = 1
}
/// Marker type for a directed graph.
#[derive(Copy, Clone, Show)]
pub struct Directed;
/// Marker type for an undirected graph.
#[derive(Copy, Clone, Show)]
pub struct Undirected;
/// A graph's edge type determines whether is has directed edges or not.
pub trait EdgeType {
fn is_directed(_ig: Option<Self>) -> bool;
}
impl EdgeType for Directed {
fn is_directed(_ig: Option<Self>) -> bool { true }
}
impl EdgeType for Undirected {
fn is_directed(_ig: Option<Self>) -> bool { false }
}
/// A reference that is hashed and compared by its pointer value.
pub struct Ptr<'b, T: 'b>(pub &'b T);
impl<'b, T> Copy for Ptr<'b, T> {}
impl<'b, T> Clone for Ptr<'b, T>
{
fn clone(&self) -> Self { *self }
}
fn ptreq<T>(a: &T, b: &T) -> bool {
a as *const _ == b as *const _
}
impl<'b, T> PartialEq for Ptr<'b, T>
{
/// Ptr compares by pointer equality, i.e if they point to the same value
fn eq(&self, other: &Ptr<'b, T>) -> bool {
ptreq(self.0, other.0)
}
}
impl<'b, T> PartialOrd for Ptr<'b, T>
{
fn partial_cmp(&self, other: &Ptr<'b, T>) -> Option<Ordering> {
Some(self.cmp(other))
}
}
impl<'b, T> Ord for Ptr<'b, T>
{
/// Ptr is ordered by pointer value, i.e. an arbitrary but stable and total order.
fn cmp(&self, other: &Ptr<'b, T>) -> Ordering {
let a = self.0 as *const _;
let b = other.0 as *const _;
a.cmp(&b)
}
}
impl<'b, T> Deref for Ptr<'b, T> {
type Target = T;
fn deref<'a>(&'a self) -> &'a T {
self.0
}
}
impl<'b, T> Eq for Ptr<'b, T> {}
impl<'b, T, H: hash::Writer + hash::Hasher> Hash<H> for Ptr<'b, T>
{
fn hash(&self, st: &mut H)
{
let ptr = (self.0) as *const _;
ptr.hash(st)
}
}
impl<'b, T: fmt::Show> fmt::Show for Ptr<'b, T> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
self.0.fmt(f)
}
}