X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Fcatalogue.h;h=dcde9f38f9600dfac5a2a7f761e72ec0c54738c5;hb=0bfaea65cfa324dfbb517b551709219529ef24b8;hp=5ac3665f2eb2e7573715951560aafebfecd27658;hpb=d91ab10fd78ef29272282b020fa4e08063cb4808;p=r2c2.git diff --git a/source/libr2c2/catalogue.h b/source/libr2c2/catalogue.h index 5ac3665..dcde9f3 100644 --- a/source/libr2c2/catalogue.h +++ b/source/libr2c2/catalogue.h @@ -1,28 +1,20 @@ -/* $Id$ - -This file is part of R²C² -Copyright © 2006-2010 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - #ifndef LIBR2C2_CATALOGUE_H_ #define LIBR2C2_CATALOGUE_H_ #include -#include +#include #include "articlenumber.h" #include "layout.h" #include "profile.h" namespace R2C2 { -class TrackType; -class VehicleType; +class ObjectType; class Catalogue { public: - class Loader: public Msp::DataFile::BasicLoader + class Loader: public Msp::DataFile::ObjectLoader { public: Loader(Catalogue &); @@ -32,27 +24,22 @@ public: void layout(); void rail_profile(); void scale(float, float); - void track(unsigned); + void signal(ArticleNumber); void track(ArticleNumber); - void vehicle(unsigned); void vehicle(ArticleNumber); }; - typedef std::map TrackMap; - typedef std::map VehicleMap; + typedef std::map ObjectMap; - sigc::signal signal_track_added; - sigc::signal signal_vehicle_added; + sigc::signal signal_object_added; private: float scale; float gauge; Profile rail_profile; Profile ballast_profile; - Profile path_profile; std::string track_technique; - TrackMap tracks; - VehicleMap vehicles; + ObjectMap objects; Layout layout; public: @@ -64,16 +51,15 @@ public: float get_rail_elevation() const; const Profile &get_rail_profile() const { return rail_profile; } const Profile &get_ballast_profile() const { return ballast_profile; } - const Profile &get_path_profile() const { return path_profile; } const std::string &get_track_technique() const { return track_technique; } - void add_track(TrackType &); - const TrackType &get_track(const ArticleNumber &) const; - const TrackMap &get_tracks() const { return tracks; } + void add(ObjectType &); + const ObjectType &get(const ArticleNumber &) const; + const ObjectMap &get_all() const { return objects; } - void add_vehicle(VehicleType &); - const VehicleType &get_vehicle(const ArticleNumber &) const; - const VehicleMap &get_vehicles() const { return vehicles; } + template + const T &get(const ArticleNumber &an) const + { return dynamic_cast(get(an)); } Layout &get_layout() { return layout; } };