]> git.tdb.fi Git - r2c2.git/blobdiff - source/libmarklin/catalogue.h
Full vehicle unification
[r2c2.git] / source / libmarklin / catalogue.h
index e531941b40fb6e1c072491f90094b2ae8164ce1a..d529cfc07969e18f8c17983359aadc5cd543e45b 100644 (file)
@@ -15,8 +15,8 @@ Distributed under the GPL
 
 namespace Marklin {
 
-class LocoType;
 class TrackType;
+class VehicleType;
 
 class Catalogue
 {
@@ -29,19 +29,23 @@ public:
                void ballast_profile();
                void gauge(float);
                void layout();
-               void locomotive(unsigned);
                void rail_profile();
                void scale(float, float);
                void track(unsigned);
+               void vehicle(unsigned);
        };
 
+       sigc::signal<void, const TrackType &> signal_track_added;
+       sigc::signal<void, const VehicleType &> signal_vehicle_added;
+
 private:
        float scale;
        float gauge;
        Profile rail_profile;
        Profile ballast_profile;
+       Profile path_profile;
        std::map<unsigned, TrackType *> tracks;
-       std::map<unsigned, LocoType *> locos;
+       std::map<unsigned, VehicleType *> vehicles;
        Layout layout;
 
 public:
@@ -52,10 +56,16 @@ public:
        float get_gauge() const { return gauge; }
        const Profile &get_rail_profile() const { return rail_profile; }
        const Profile &get_ballast_profile() const { return ballast_profile; }
-       TrackType &get_track(unsigned) const;
+       const Profile &get_path_profile() const { return path_profile; }
+
+       void add_track(TrackType &);
+       const TrackType &get_track(unsigned) const;
        const std::map<unsigned, TrackType *> &get_tracks() const { return tracks; }
-       LocoType &get_locomotive(unsigned) const;
-       const std::map<unsigned, LocoType *> &get_locomotives() const { return locos; }
+
+       void add_vehicle(VehicleType &);
+       const VehicleType &get_vehicle(unsigned) const;
+       const std::map<unsigned, VehicleType *> &get_vehicles() const { return vehicles; }
+
        Layout &get_layout() { return layout; }
 };