X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Froute.h;h=e5164ce06a283f854d5ce2f7e1881bbac159610f;hb=dda1e6c8716b6ac70d63a3f6ff95474a8b8b7336;hp=4f5d0564934e665bbc86c9c7f0827965141e535e;hpb=d15ac13f2e170f155b4bbd124df48400c339b644;p=r2c2.git diff --git a/source/libr2c2/route.h b/source/libr2c2/route.h index 4f5d056..e5164ce 100644 --- a/source/libr2c2/route.h +++ b/source/libr2c2/route.h @@ -5,7 +5,7 @@ #include #include #include -#include +#include namespace R2C2 { @@ -14,12 +14,32 @@ class Track; class TrackIter; class Zone; +enum RouteValidityMask +{ + ROUTE_INVALID = 0, + ROUTE_LINKED = 1, + ROUTE_LINEAR = 2, + ROUTE_SMOOTH = 4, + ROUTE_VALID = 7 +}; + +class bad_route: public std::logic_error +{ +public: + bad_route(RouteValidityMask m): std::logic_error(get_message(m)) { } + virtual ~bad_route() throw() { } + +private: + static std::string get_message(RouteValidityMask); +}; + + class Route: public sigc::trackable { public: typedef std::map TurnoutMap; - class Loader: public Msp::DataFile::BasicLoader + class Loader: public Msp::DataFile::ObjectLoader { private: TurnoutMap turnouts; @@ -55,12 +75,12 @@ public: const std::map &get_turnouts() const { return turnouts; } void add_track(Track &); void add_tracks(const std::set &); - void add_track_chain(Track &, unsigned, const TurnoutMap &); + void add_track_chain(const TrackIter &, const TurnoutMap &); const std::set &get_tracks() const { return tracks; } bool has_track(Track &) const; void save(std::list &) const; private: - unsigned check_validity(Track &) const; + RouteValidityMask check_validity(Track &) const; void track_removed(Track &); public: