X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Froute.h;h=7c188b00e702bf37bf7786ccbdbd0af010799b20;hb=29b131b59ba562f996a338a453745e5a4dfad5b7;hp=98b64f5c9ff11e9411bb987f8ad4d5877ab8bd3c;hpb=651698847d5293cfb15b6fb23a394701388c0151;p=r2c2.git diff --git a/source/libmarklin/route.h b/source/libmarklin/route.h index 98b64f5..7c188b0 100644 --- a/source/libmarklin/route.h +++ b/source/libmarklin/route.h @@ -22,35 +22,52 @@ class Track; class Route: public sigc::trackable { public: + typedef std::map TurnoutMap; + class Loader: public Msp::DataFile::BasicLoader { + private: + TurnoutMap turnouts; + public: Loader(Route &); private: + virtual void finish(); void turnout(unsigned, unsigned); }; + sigc::signal signal_name_changed; + private: Layout &layout; std::string name; + bool temporary; std::set tracks; - std::map turnouts; + TurnoutMap turnouts; public: - Route(Layout &, const std::string &); + Route(Layout &); ~Route(); + void set_name(const std::string &); const std::string &get_name() const { return name; } + void set_temporary(bool); + bool is_temporary() const { return temporary; } + void update_turnouts(); int get_turnout(unsigned) const; const std::map &get_turnouts() const { return turnouts; } void add_track(const Track &); void add_tracks(const std::set &); + void add_track_chain(const Track &, unsigned, const TurnoutMap &); const std::set &get_tracks() const { return tracks; } void save(std::list &) const; private: - void update_turnouts(); unsigned check_validity(const Track &) const; void track_removed(Track &); + +public: + static Route *find(const Track &, unsigned, const Track &); + static Route *find(const Track &, unsigned, const Route &); }; } // namespace Marklin