marci@330: // -*- c++ -*-
marci@330: #ifndef FOR_EACH_MACROS_H
marci@330: #define FOR_EACH_MACROS_H
marci@330: 
marci@330: namespace hugo {
marci@330: 
marci@409: #define FOR_EACH_GLOB(e, g) for((g).first((e)); (g).valid((e)); (g).next((e)))
marci@409: #define FOR_EACH_INC_GLOB(e, g, v) for((g).first((e), (v)); (g).valid((e)); (g).next((e)))
marci@330: 
marci@409: #define FOR_EACH_EDGE_GLOB(e, g) for((g).first((e)); (g).valid((e)); (g).next((e)))
marci@409: #define FOR_EACH_NODE_GLOB(e, g) for((g).first((e)); (g).valid((e)); (g).next((e)))
marci@409: #define FOR_EACH_INEDGE_GLOB(e, g, v) for((g).first((e), (v)); (g).valid((e)); (g).next((e)))
marci@409: #define FOR_EACH_OUTEDGE_GLOB(e, g, v) for((g).first((e), (v)); (g).valid((e)); (g).next((e)))
marci@330: 
marci@330: //   template<typename It, typename Graph> 
marci@330: //   It loopFirst(const Graph& g) const {
marci@330: //     It e; g.first(e); return e; 
marci@330: //   }
marci@330: 
marci@330: //   template<typename It, typename Graph> 
marci@330: //   It loopFirst(const Graph& g, const Node& v) const {
marci@330: //     It e; g.first(e, v); return e; 
marci@330: //   }
marci@330: 
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::NodeIt loopFirstNode(const Graph& g) const {
marci@330: //     typename Graph::NodeIt e; g.first(e); return e; 
marci@330: //   }
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::EdgeIt loopFirstEdge(const Graph& g) const {
marci@330: //     typename Graph::EdgeIt e; g.first(e); return e; 
marci@330: //   }
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::OutEdgeIt 
marci@330: //   loopFirstOutEdge(const Graph& g, const Node& n) const {
marci@330: //     typename Graph::OutEdgeIt e; g.first(e, n); return e; 
marci@330: //   }
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::InEdgeIt 
marci@330: //   loopFirstIn Edge(const Graph& g, const Node& n) const {
marci@330: //     typename Graph::InEdgeIt e; g.first(e, n); return e; 
marci@330: //   }
marci@330: 
marci@330: //FIXME ezt hogy a gorcsbe birja levezetni. Csak ugy leveszi a const-ot??
marci@330:   template<typename It, typename Graph> 
marci@333:   It loopFirst(const It&, const Graph& g) {
marci@333:     It e; g.first(e); return e; 
marci@330:   }
marci@330: 
marci@330:   template<typename It, typename Graph, typename Node> 
marci@333:   It loopFirst(const It&, const Graph& g, const Node& v) {
marci@333:     It e; g.first(e, v); return e; 
marci@330:   }
marci@330: 
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::NodeIt loopFirstNode(const Graph& g) const {
marci@330: //     typename Graph::NodeIt e; g.first(e); return e; 
marci@330: //   }
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::EdgeIt loopFirstEdge(const Graph& g) const {
marci@330: //     typename Graph::EdgeIt e; g.first(e); return e; 
marci@330: //   }
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::OutEdgeIt 
marci@330: //   loopFirstOutEdge(const Graph& g, const Node& n) const {
marci@330: //     typename Graph::OutEdgeIt e; g.first(e, n); return e; 
marci@330: //   }
marci@330: //   template<typename Graph> 
marci@330: //   typename Graph::InEdgeIt 
marci@330: //   loopFirstIn Edge(const Graph& g, const Node& n) const {
marci@330: //     typename Graph::InEdgeIt e; g.first(e, n); return e; 
marci@330: //   }
marci@330: 
marci@333: #define FOR_EACH_LOC(Ittype, e, g) for(Ittype e=loopFirst(Ittype(), (g)); (g).valid(e); (g).next(e))
marci@333: #define FOR_EACH_INC_LOC(Ittype, e, g, v) for(Ittype e=loopFirst(Ittype(), (g), (v)); (g).valid(e); (g).next(e))
marci@330: 
marci@333: // #define FOR_EACH_EDGE_LOC(e, g) ezt nem tom hogy kell for((g).first((e)); (g).valid((e)); (g).next((e)))
marci@330: // #define FOR_EACH_NODE_LOC(e, g) for((g).first((e)); (g).valid((e)); (g).next((e)))
marci@330: // #define FOR_EACH_INEDGE_LOC(e, g, v) for((g).first((e), (v)); (g).valid((e)); (g).next((e)))
marci@330: // #define FOR_EACH_OUTEDGE_LOC(e, g, v) for((g).first((e), (v)); (g).valid((e)); (g).next((e)))
marci@330: 
marci@330: 
marci@330: } //namespace hugo
marci@330: 
marci@330: #endif //FOR_EACH_MACROS_H