Fix wrong iteration in ListGraph snapshot, part II. (#598)
1 /* -*- mode: C++; indent-tabs-mode: nil; -*-
3 * This file is a part of LEMON, a generic C++ optimization library.
5 * Copyright (C) 2003-2013
6 * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
7 * (Egervary Research Group on Combinatorial Optimization, EGRES).
9 * Permission to use, modify and distribute this software is granted
10 * provided that this copyright notice appears in all copies. For
11 * precise terms see the accompanying LICENSE file.
13 * This software is provided "AS IS" with no warranty of any kind,
14 * express or implied, and with no claim as to its suitability for any
20 #include "lemon/list_graph.h"
21 #include "lemon/lgf_reader.h"
23 #include "test_tools.h"
25 using namespace lemon;
27 const std::string lgf =
68 std::istringstream lgfs(lgf);
69 DigraphReader<ListDigraph>(graph, lgfs).run();
71 AllArcLookUp<ListDigraph> lookup(graph);
73 int numArcs = countArcs(graph);
76 for(ListDigraph::NodeIt n1(graph); n1 != INVALID; ++n1)
77 for(ListDigraph::NodeIt n2(graph); n2 != INVALID; ++n2)
78 for(ListDigraph::Arc a = lookup(n1, n2); a != INVALID;
79 a = lookup(n1, n2, a))
81 check(arcCnt==numArcs, "Wrong total number of arcs");