X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftracktype.cpp;h=51b685f5ceed7964e54bf6ef26b84b3a83f41a89;hb=b860a56bd9bc8894311c02d7673f379beff3220b;hp=59b8f9ca275b4fe508b94fe77c32ec220ab83472;hpb=145ba6391812e2b1040a78a8f0fda5888bfea610;p=r2c2.git diff --git a/source/libr2c2/tracktype.cpp b/source/libr2c2/tracktype.cpp index 59b8f9c..51b685f 100644 --- a/source/libr2c2/tracktype.cpp +++ b/source/libr2c2/tracktype.cpp @@ -1,5 +1,7 @@ #include +#include #include +#include "trackappearance.h" #include "tracktype.h" using namespace std; @@ -7,13 +9,24 @@ using namespace Msp; namespace R2C2 { -TrackType::TrackType(const ArticleNumber &an, const TrackAppearance &ta): - ObjectType(an), - appearance(ta), +TrackType::TrackType(): + appearance(0), state_bits(0), autofit_preference(1) { } +const TrackAppearance &TrackType::get_appearance() const +{ + if(!appearance) + throw logic_error("no appearance"); + return *appearance; +} + +float TrackType::get_gauge() const +{ + return get_appearance().get_gauge(); +} + float TrackType::get_total_length() const { return get_path_length(-1); @@ -208,10 +221,12 @@ TrackType::Endpoint::Endpoint(float x, float y, const Angle &d, unsigned p): { } -TrackType::Loader::Loader(TrackType &t): +TrackType::Loader::Loader(TrackType &t, Collection &c): DataFile::DerivedObjectLoader(t), + coll(c), state_bits_set(false) { + add("appearance", &TrackType::appearance); add("autofit_preference", &TrackType::autofit_preference); add("object", &TrackType::object); add("state_bits", &Loader::state_bits);