X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrack.h;h=f169c0a92671c7ac9a458aca9a36ae327986da3b;hb=7e7cb480bc83406b0ad1cc5cb1e07cc953f49a7d;hp=916ea1966183c8ce5a87ec97a0c2297570a29c4a;hpb=107a7f787d406f1f664c4986557f9a896e0845ea;p=r2c2.git diff --git a/source/libr2c2/track.h b/source/libr2c2/track.h index 916ea19..f169c0a 100644 --- a/source/libr2c2/track.h +++ b/source/libr2c2/track.h @@ -13,6 +13,7 @@ namespace R2C2 { class Block; class Layout; +class TrackAttachment; class Track: public Object, public sigc::trackable { @@ -30,6 +31,8 @@ public: void turnout_id(unsigned); }; + typedef std::list AttachmentList; + sigc::signal signal_link_changed; sigc::signal signal_path_changing; sigc::signal signal_path_changed; @@ -44,6 +47,7 @@ private: std::vector links; unsigned active_path; bool path_changing; + AttachmentList attachments; Track(const Track &); Track &operator=(const Track &); @@ -74,8 +78,8 @@ public: unsigned get_active_path() const { return active_path; } bool is_path_changing() const { return path_changing; } - TrackPoint get_point(unsigned, unsigned, float) const; - TrackPoint get_point(unsigned, float) const; + OrientedPoint get_point(unsigned, unsigned, float) const; + OrientedPoint get_point(unsigned, float) const; virtual unsigned get_n_snap_nodes() const; virtual Snap get_snap_node(unsigned) const; @@ -92,6 +96,11 @@ public: using Object::break_link; virtual bool break_link(unsigned); + void add_attachment(TrackAttachment &); + void remove_attachment(TrackAttachment &); + const AttachmentList &get_attachments() const { return attachments; } + AttachmentList get_attachments_ordered(unsigned) const; + void save(std::list &) const; private: void turnout_event(unsigned, unsigned);