X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Fsensor.cpp;h=618a06b7b609c6ac8a930bc62c197bb4ac2db768;hb=8a31a3ab3ab7abda30de0ed3a6d0753760f3bb1d;hp=8a65d3dedf20f52419d130bfd1612f5bb3cc2a30;hpb=eb9c7f5200da4f3f31b41233be8cee397cb6abb9;p=r2c2.git diff --git a/source/libr2c2/sensor.cpp b/source/libr2c2/sensor.cpp index 8a65d3d..618a06b 100644 --- a/source/libr2c2/sensor.cpp +++ b/source/libr2c2/sensor.cpp @@ -9,6 +9,7 @@ namespace R2C2 { Sensor::Sensor(Layout &l): layout(l), address(0), + invert(false), state(INACTIVE) { if(layout.has_driver()) @@ -19,9 +20,21 @@ Sensor::Sensor(Layout &l): Sensor::~Sensor() { + if(layout.has_driver() && address) + layout.get_driver().remove_sensor(address); layout.remove(*this); } +void Sensor::set_address(unsigned a) +{ + Driver *driver = (layout.has_driver() ? &layout.get_driver() : 0); + if(driver && address) + driver->remove_sensor(address); + address = a; + if(driver && address) + driver->add_sensor(address); +} + void Sensor::tick(const Time::TimeDelta &dt) { if(state_confirm_timeout) @@ -43,13 +56,13 @@ void Sensor::event(unsigned a, bool s) { if(a==address) { - if(s && stateMAYBE_INACTIVE) + else if(s==invert && state>MAYBE_INACTIVE) { state = MAYBE_INACTIVE; state_confirm_timeout = 700*Time::msec;