X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Fselection.h;h=89f7100e3e6e854945219bf074ad7f4ff3388e4f;hb=28947c087bd2d05c1850e320844f2e33fc0fc253;hp=1c0d267f1618044271f7672c967c61d8cb118db6;hpb=1d735b80482317fd930eb47ca255ab9f1f120a7d;p=r2c2.git diff --git a/source/designer/selection.h b/source/designer/selection.h index 1c0d267..89f7100 100644 --- a/source/designer/selection.h +++ b/source/designer/selection.h @@ -3,25 +3,59 @@ #include #include -#include "3d/track.h" +#include "libr2c2/object.h" class Selection { +public: + sigc::signal signal_changed; + private: - std::set tracks; + std::set objects; public: - sigc::signal signal_changed; + const std::set &get_objects() const { return objects; } + R2C2::Object *get_object() const; + + template + std::set get_objects() const + { + std::set result; + for(std::set::const_iterator i=objects.begin(); i!=objects.end(); ++i) + if(T *to = dynamic_cast(*i)) + result.insert(to); + return result; + } + + template + T *get_object() const + { + for(std::set::const_iterator i=objects.begin(); i!=objects.end(); ++i) + if(T *to = dynamic_cast(*i)) + return to; + return 0; + } + + unsigned size() const { return objects.size(); } + bool empty() const { return objects.empty(); } - const std::set &get_tracks() const { return tracks; } - Marklin::Track *get_track() const; - unsigned size() const { return tracks.size(); } void clear(); - void add_track(Marklin::Track *); - void remove_track(Marklin::Track *); - void toggle_track(Marklin::Track *); + + template + void replace(Iter begin, Iter end) + { + objects.clear(); + objects.insert(begin, end); + signal_changed.emit(); + } + + void add_object(R2C2::Object *); + void remove_object(R2C2::Object *); + void toggle_object(R2C2::Object *); + void select_more(); void select_linked(); + void select_blocks(); }; #endif