X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fengineer%2Fengineer.h;h=0769473a786e45e639c544c0b7478bf7d9205c94;hb=dabab2f3bfb5c8548b9c36f3fe40065563653990;hp=418c0cdf730d9f4cfcee5e1bbd48320f69d581b1;hpb=5a02a4f42dfc5dc6b4daef5fc02431bdfb2968d8;p=r2c2.git diff --git a/source/engineer/engineer.h b/source/engineer/engineer.h index 418c0cd..0769473 100644 --- a/source/engineer/engineer.h +++ b/source/engineer/engineer.h @@ -10,10 +10,12 @@ #include #include #include "libr2c2/catalogue.h" +#include "libr2c2/driver.h" #include "libr2c2/train.h" #include "3d/layout.h" #include "3d/overlay.h" #include "3d/path.h" +#include "3d/trackchain.h" #include "3d/view.h" #include "network/server.h" #include "options.h" @@ -32,6 +34,7 @@ private: Msp::GLtk::Resources ui_res; Msp::GLtk::Root *root; Msp::GLtk::Arrangement *root_arrangement; + bool import_active; R2C2::Catalogue catalogue; R2C2::Layout layout; @@ -48,6 +51,9 @@ private: std::list train_views; Msp::Time::TimeStamp status_timeout; R2C2::Vector pointer; + std::list emergencies; + Msp::Time::TimeStamp emergency_blink_timeout; + unsigned emergency_blink_state; public: Engineer(int argc, char **argv); @@ -69,9 +75,11 @@ private: void button_press(unsigned); void axis_motion(unsigned, float, float); void view_all(); - void sensor_event(unsigned, bool); - void block_reserved(const R2C2::Block &, const R2C2::Train *); R2C2::Object *pick_object(const R2C2::Vector &); + void emergency(R2C2::Block *, const std::string &); + void halt_event(bool); + void locomotive_detected(const R2C2::Driver::DetectedLocomotive &); + void import_finished(int); void train_added(R2C2::Train &); void process_new_train(R2C2::Train &); virtual void sighandler(int);