]> git.tdb.fi Git - r2c2.git/blob - source/libmarklin/trafficmanager.cpp
Initial revision
[r2c2.git] / source / libmarklin / trafficmanager.cpp
1 #include "control.h"
2 #include "layout.h"
3 #include "trafficmanager.h"
4 #include "turnout.h"
5
6 using namespace std;
7
8 namespace Marklin {
9
10 TrafficManager::TrafficManager(Control &c, Layout &l):
11         control(c),
12         layout(l)
13 {
14         const TrackSeq &tracks=layout.get_tracks();
15
16         TrackSet used_tracks;
17         for(TrackSeq::const_iterator i=tracks.begin(); i!=tracks.end(); ++i)
18         {
19                 if(unsigned tid=(*i)->get_turnout_id())
20                 {
21                         Turnout *t=control.get_turnout(tid);
22                         if(!t)
23                                 t=new Turnout(control, tid);
24                         //t->signal_route_changed.connect(sigc::mem_fun(*i, &Track::set_current_route));
25                 }
26                 if(unsigned sid=(*i)->get_sensor_id())
27                 {
28                         Sensor *s=control.get_sensor(sid);
29                         if(!s)
30                                 s=new Sensor(control, sid);
31                 }
32                 if(used_tracks.count(*i)==0)
33                 {
34                         Section *sect=new Section(*this, *i);
35                         sections.push_back(sect);
36                         used_tracks.insert(sect->get_tracks().begin(), sect->get_tracks().end());
37                 }
38         }
39
40         for(SectionSeq::iterator i=sections.begin(); i!=sections.end(); ++i)
41         {
42                 for(SectionSeq::iterator j=i; j!=sections.end(); ++j)
43                         if(j!=i)
44                                 (*i)->check_link(**j);
45                 (*i)->print_debug();
46         }
47 }
48
49 Section *TrafficManager::get_section_by_track(const Track *t) const
50 {
51         for(SectionSeq::const_iterator i=sections.begin(); i!=sections.end(); ++i)
52         {
53                 const TrackSet &tracks=(*i)->get_tracks();
54                 if(tracks.count(const_cast<Track *>(t)))
55                         return *i;
56         }
57
58         return 0;
59 }
60
61 void TrafficManager::add_train(Train *t)
62 {
63         if(find(trains.begin(), trains.end(), t)==trains.end())
64                 trains.push_back(t);
65 }
66
67 void TrafficManager::turnout_route_changed(unsigned, Turnout *)
68 {
69 }
70
71 } // namespace Marklin