/*============================================================================ CMake - Cross Platform Makefile Generator Copyright 2000-2009 Kitware, Inc., Insight Software Consortium Distributed under the OSI-approved BSD License (the "License"); see accompanying file Copyright.txt for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License for more information. ============================================================================*/ #ifndef cmGraphAdjacencyList_h #define cmGraphAdjacencyList_h #include #include "cmStandardIncludes.h" /** * Graph edge representation. Most use cases just need the * destination vertex, so we support conversion to/from an int. We * also store boolean to indicate whether an edge is "strong". */ class cmGraphEdge { public: cmGraphEdge() : Dest(0) , Strong(true) { } cmGraphEdge(int n) : Dest(n) , Strong(true) { } cmGraphEdge(int n, bool s) : Dest(n) , Strong(s) { } cmGraphEdge(cmGraphEdge const& r) : Dest(r.Dest) , Strong(r.Strong) { } operator int() const { return this->Dest; } bool IsStrong() const { return this->Strong; } private: int Dest; bool Strong; }; struct cmGraphEdgeList : public std::vector { }; struct cmGraphNodeList : public std::vector { }; struct cmGraphAdjacencyList : public std::vector { }; #endif