3 This file is part of the MSP Märklin suite
4 Copyright © 2006-2008 Mikkosoft Productions, Mikko Rasa
5 Distributed under the GPL
8 #include <msp/time/utils.h>
11 #include "trafficmanager.h"
19 TrafficManager::TrafficManager(Control &c, Layout &l):
23 const set<Track *> &tracks=layout.get_tracks();
25 set<Track *> used_tracks;
26 for(set<Track *>::const_iterator i=tracks.begin(); i!=tracks.end(); ++i)
28 if(unsigned tid=(*i)->get_turnout_id())
29 new Turnout(control, tid);
30 if(unsigned sid=(*i)->get_sensor_id())
31 new Sensor(control, sid);
33 if(used_tracks.count(*i)==0)
35 Block *block=new Block(*this, **i);
36 blocks.push_back(block);
37 used_tracks.insert(block->get_tracks().begin(), block->get_tracks().end());
41 for(list<Block *>::iterator i=blocks.begin(); i!=blocks.end(); ++i)
43 for(list<Block *>::iterator j=i; j!=blocks.end(); ++j)
45 (*i)->check_link(**j);
50 TrafficManager::~TrafficManager()
52 for(list<Block *>::iterator i=blocks.begin(); i!=blocks.end(); ++i)
54 for(list<Train *>::iterator i=trains.begin(); i!=trains.end(); ++i)
58 Block &TrafficManager::get_block_by_track(const Track &t) const
60 for(list<Block *>::const_iterator i=blocks.begin(); i!=blocks.end(); ++i)
62 const set<Track *> &tracks=(*i)->get_tracks();
63 if(tracks.count(const_cast<Track *>(&t)))
67 throw InvalidParameterValue("Unknown track");
70 void TrafficManager::add_train(Train *t)
72 if(find(trains.begin(), trains.end(), t)==trains.end())
76 void TrafficManager::tick()
78 Time::TimeStamp t=Time::now();
80 for(list<Train *>::iterator i=trains.begin(); i!=trains.end(); ++i)
84 void TrafficManager::turnout_route_changed(unsigned, Turnout *)
88 } // namespace Marklin