COIN-OR::LEMON - Graph Library

source: lemon-0.x/src/work/alpar/file-reader.cc @ 988:aa19ca32d9b0

Last change on this file since 988:aa19ca32d9b0 was 972:c0fdb1ad8e8d, checked in by Alpar Juttner, 20 years ago

A graph reader interface proposal

File size: 2.5 KB
Line 
1#include <lemon/list_graph.h>
2#include <lemon/maps.h>
3#include <list>
4
5using namespace lemon;
6
7template<class GR>
8class Reader
9{
10 
11public:
12  typedef GR Graph;
13  typedef typename Graph::Node Node;
14  typedef typename Graph::Edge Edge;
15   
16  ///A beolvasando ertekek tipusa.
17
18  ///Ebben gyakorlatilag egy stringet tarolunk.
19  ///Tovabba ez egy olyan tipus, amitol elvarjuk, hogy konvertalodjon
20  ///a beolvasando mapok Value-jara.
21  class InputValue
22  {
23  public:
24    operator int()    const { return 0; }
25    operator double() const { return 0; }
26  };
27
28  ///Ez adja a mapok kozos interface-et.
29  class WrapEdgeMapBase
30  {
31  public:
32    virtual void set(Edge n,const InputValue &v) = 0;
33    virtual ~WrapEdgeMapBase() {}
34  };
35
36  ///Ez meg becsomagol egy mapot a kozos formara.
37  template<class M>
38  class WrapEdgeMap : public WrapEdgeMapBase
39  {
40    M &map;
41   
42  public:
43    WrapEdgeMap(M &m) : map(m) {}
44    void set(Edge n,const InputValue &v) {map.set(n,v);}
45  };
46
47  ///Ebben a strukturaban adunk meg egy feltoltendo mapot.
48  struct EdgeMapDesc
49  {
50    std::string name;
51    int column;
52    WrapEdgeMapBase *map;
53   
54    template<class M> EdgeMapDesc(char *n,M &m) : name(n), map(&m) {}
55    ~EdgeMapDesc() {}   
56  };
57 
58  ///Itt vannak felsorolva a feltoltendo mapok
59  std::list<EdgeMapDesc> EdgeMaps;
60
61  ///Ezzel lehet egy mapot hozzaadni a feltoltendok listajahoz.
62  template<class M> void addEdgeMap(char *name,M &map)
63  {
64    EdgeMaps.push_back(EdgeMapDesc(name,*(new WrapEdgeMap<M>(map))));
65  }
66 
67  ///Ez meg kiuriti a map-listat.
68  void removeEdgeMaps()
69  {
70    while(EdgeMaps.begin()!=EdgeMaps.end()) {
71      //Ez igy OK?:
72      delete EdgeMaps.begin()->map;
73      EdgeMaps.pop_front();
74    }
75  }
76 
77  //Esetleg stream a file-nev helyett...
78  Reader(char *file,Graph &G)
79  {
80     removeEdgeMaps();
81  }
82 
83  ///Ez inditja a beolvasast.
84  void read()
85  {
86    //Ez olvassa be/vegig a file-t.
87  }
88 
89  ~Reader()
90  {
91    //Ez kell!!!
92    removeEdgeMaps();
93  }
94 
95};
96
97class SumMap : public MapBase<ListGraph::Edge,double>
98{
99  double sum;
100public:
101  SumMap() : sum(0) {}
102  void set(ListGraph::Edge e,double d)
103  {
104    sum+=d;
105  }
106  double getSum() { return sum; }
107};
108
109int main()
110{
111  ListGraph g; //Kis g!!!
112  ListGraph::EdgeMap<double> cost(g);
113  ListGraph::EdgeMap<int> channels(g);
114 
115  SumMap sum_cost; //Ez egy sajat "custom" irhato map
116 
117  Reader<ListGraph> r("file_name.lgf",g);
118  r.addEdgeMap("cost",cost);
119  r.addEdgeMap("channels",channels);
120  r.addEdgeMap("cost",sum_cost);
121  r.read();
122}
Note: See TracBrowser for help on using the repository browser.