]> git.tdb.fi Git - r2c2.git/blobdiff - source/designer/trackproperties.cpp
Make designer work on generic objects
[r2c2.git] / source / designer / trackproperties.cpp
index cdb5cb0855b5b62a3c1e37eb0b013b040c1d5b89..9753849eccf3aadae3b4d937e7dbb51e2baecc64 100644 (file)
@@ -1,5 +1,6 @@
 #include <msp/gltk/button.h>
 #include <msp/gltk/label.h>
+#include "libr2c2/track.h"
 #include "libr2c2/tracktype.h"
 #include "selection.h"
 #include "trackproperties.h"
@@ -42,11 +43,11 @@ TrackProperties::TrackProperties(const Selection &s):
 
        if(selection.size()==1)
        {
-               if(unsigned tid = selection.get_track()->get_turnout_id())
+               if(unsigned tid = selection.get_object<Track>()->get_turnout_id())
                        ent_turnout_id->set_text(lexical_cast<string>(tid));
        }
 
-       const set<Track *> &tracks = selection.get_tracks();
+       const set<Track *> &tracks = selection.get_objects<Track>();
        int sensor_id = -1;
        for(set<Track *>::const_iterator i=tracks.begin(); i!=tracks.end(); ++i)
        {
@@ -69,7 +70,7 @@ void TrackProperties::on_response(int code)
        {
                if(selection.size()==1)
                {
-                       Track *track = selection.get_track();
+                       Track *track = selection.get_object<Track>();
                        if(track->get_type().is_turnout())
                                track->set_turnout_id(lexical_cast<unsigned>(ent_turnout_id->get_text()));
                }
@@ -78,7 +79,7 @@ void TrackProperties::on_response(int code)
                if(!sensor_id_text.empty())
                {
                        unsigned sensor_id = lexical_cast<unsigned>(sensor_id_text);
-                       const set<Track *> &tracks = selection.get_tracks();
+                       const set<Track *> &tracks = selection.get_objects<Track>();
                        for(set<Track *>::const_iterator i=tracks.begin(); i!=tracks.end(); ++i)
                                if(!(*i)->get_type().is_turnout())
                                        (*i)->set_sensor_id(sensor_id);