X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fnetwork%2Ftrain.h;h=5c938dcbe0afc9517cb565e654912cfb973d4b58;hb=3b37ee041af581e47646c2487e7e302c55bd8cd7;hp=57154a04e7245dd997990ee1fa79c9da520c037b;hpb=010d8321e982d1684fcbff5bf6fc2bdec7cb7bae;p=r2c2.git diff --git a/source/network/train.h b/source/network/train.h index 57154a0..5c938dc 100644 --- a/source/network/train.h +++ b/source/network/train.h @@ -1,18 +1,11 @@ -/* $Id$ - -This file is part of the MSP Märklin suite -Copyright © 2009 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - -#ifndef MARKLINNET_TRAIN_H_ -#define MARKLINNET_TRAIN_H_ +#ifndef R2C2_NET_TRAIN_H_ +#define R2C2_NET_TRAIN_H_ #include -#include "libmarklin/locotype.h" +#include "libr2c2/vehicletype.h" #include "packets.h" -namespace Marklin { +namespace R2C2 { class Client; @@ -20,39 +13,49 @@ class NetTrain { public: sigc::signal signal_name_changed; - sigc::signal signal_speed_changed; - sigc::signal signal_reverse_changed; + sigc::signal signal_control_changed; sigc::signal signal_function_changed; + sigc::signal signal_target_speed_changed; + sigc::signal signal_reverse_changed; + sigc::signal signal_route_changed; sigc::signal signal_status_changed; private: Client &client; - const LocoType &loco_type; + const VehicleType &loco_type; unsigned address; std::string name; - unsigned speed; + std::map controls; + float target_speed; bool reverse; unsigned functions; + std::string route; std::string status; public: NetTrain(Client &, const TrainInfoPacket &); - const LocoType &get_loco_type() const { return loco_type; } + const VehicleType &get_loco_type() const { return loco_type; } unsigned get_address() const { return address; } const std::string &get_name() const { return name; } - void set_speed(unsigned); - unsigned get_speed() const { return speed; } + void set_control(const std::string &, float); + float get_control(const std::string &) const; + void set_target_speed(float); void set_reverse(bool); + float get_target_speed() const { return target_speed; } bool get_reverse() const { return reverse; } void set_function(unsigned, bool); bool get_function(unsigned i) const { return (functions>>i)&1; } + void set_route(const std::string &); + const std::string &get_route() const { return route; } - void process_packet(const TrainSpeedPacket &); + void process_packet(const TrainControlPacket &); void process_packet(const TrainFunctionPacket &); + void process_packet(const TrainAIControlPacket &); + void process_packet(const TrainRoutePacket &); void process_packet(const TrainStatusPacket &); }; -} // namespace Marklin +} // namespace R2C2 #endif