1 #include <msp/core/maputils.h>
2 #include <msp/core/refptr.h>
3 #include <msp/datafile/parser.h>
5 #include "signaltype.h"
7 #include "vehicletype.h"
14 Catalogue::Catalogue():
20 Catalogue::~Catalogue()
22 for(ObjectMap::iterator i=objects.begin(); i!=objects.end(); ++i)
26 float Catalogue::get_rail_elevation() const
28 return ballast_profile.get_height()+rail_profile.get_height();
31 void Catalogue::add(ObjectType &object)
33 insert_unique(objects, object.get_article_number(), &object);
34 signal_object_added.emit(object);
37 const ObjectType &Catalogue::get(const ArticleNumber &art_nr) const
39 return *get_item(objects, art_nr);
43 Catalogue::Loader::Loader(Catalogue &c):
44 DataFile::ObjectLoader<Catalogue>(c)
46 add("ballast_profile", &Loader::ballast_profile);
47 add("gauge", &Loader::gauge);
48 add("layout", &Loader::layout);
49 add("rail_profile", &Loader::rail_profile);
50 add("scale", &Loader::scale);
51 add("signal", &Loader::signal);
52 add("track", &Loader::track);
53 add("track_technique", &Catalogue::track_technique);
54 add("vehicle", &Loader::vehicle);
57 void Catalogue::Loader::ballast_profile()
59 load_sub(obj.ballast_profile);
62 void Catalogue::Loader::gauge(float g)
67 void Catalogue::Loader::layout()
72 void Catalogue::Loader::rail_profile()
74 load_sub(obj.rail_profile);
77 void Catalogue::Loader::scale(float n, float d)
82 void Catalogue::Loader::signal(ArticleNumber art_nr)
84 if(obj.objects.count(art_nr))
85 throw key_error(art_nr);
87 RefPtr<SignalType> sig = new SignalType(art_nr);
89 obj.add(*sig.release());
92 void Catalogue::Loader::track(ArticleNumber art_nr)
94 if(obj.objects.count(art_nr))
95 throw key_error(art_nr);
97 RefPtr<TrackType> trk = new TrackType(art_nr);
99 obj.add(*trk.release());
102 void Catalogue::Loader::vehicle(ArticleNumber art_nr)
104 if(obj.objects.count(art_nr))
105 throw key_error(art_nr);
107 RefPtr<VehicleType> veh = new VehicleType(art_nr);
109 obj.add(*veh.release());