aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Jorge Aparicio <jorge.aparicio@ferrous-systems.com> 2022-06-07 11:51:59 +0200
committerGravatar Jorge Aparicio <jorge.aparicio@ferrous-systems.com> 2022-07-07 14:27:46 +0200
commitd1145a138fbe156ef865df0a9383565180f6d5b8 (patch)
tree3437dd3d32c7b9640893a8c7141b87fb8884d85f
parent5a3f27599e71289f03d5d33a015ed18590325701 (diff)
downloadrtic-actor.tar.gz
rtic-actor.tar.zst
rtic-actor.zip
use FakeTemperatureSensor as an actoractor
-rw-r--r--actor-example/actors/src/fake_temperature_sensor.rs28
-rw-r--r--actor-example/actors/src/lib.rs3
-rw-r--r--actor-example/firmware/src/bin/temperature-monitor.rs17
3 files changed, 36 insertions, 12 deletions
diff --git a/actor-example/actors/src/fake_temperature_sensor.rs b/actor-example/actors/src/fake_temperature_sensor.rs
index 4b4db053..b34455ce 100644
--- a/actor-example/actors/src/fake_temperature_sensor.rs
+++ b/actor-example/actors/src/fake_temperature_sensor.rs
@@ -1,6 +1,6 @@
-use rtic_actor_traits::Post;
+use rtic_actor_traits::{Post, Receive};
-use crate::TemperatureReadingCelsius;
+use crate::{DoTemperatureRead, TemperatureReadingCelsius};
pub struct FakeTemperatureSensor<P>
where
@@ -23,8 +23,13 @@ where
temperature: initial_temperature,
}
}
+}
- pub fn read(&mut self) {
+impl<P> Receive<DoTemperatureRead> for FakeTemperatureSensor<P>
+where
+ P: Post<TemperatureReadingCelsius>,
+{
+ fn receive(&mut self, _: DoTemperatureRead) {
self.outbox
.post(TemperatureReadingCelsius(self.temperature))
.expect("OOM");
@@ -41,7 +46,10 @@ mod tests {
#[test]
fn on_read_it_posts_reading() {
let mut sensor = FakeTemperatureSensor::new(PostSpy::default(), 0, 0);
- sensor.read();
+
+ // manually send a message
+ let message = DoTemperatureRead;
+ sensor.receive(message);
let spy = sensor.outbox;
let posted_messages = spy.posted_messages::<TemperatureReadingCelsius>();
@@ -52,7 +60,10 @@ mod tests {
fn reading_starts_at_initial_temperature() {
let initial_temperature = 1;
let mut sensor = FakeTemperatureSensor::new(PostSpy::default(), initial_temperature, 0);
- sensor.read();
+
+ // manually send a message
+ let message = DoTemperatureRead;
+ sensor.receive(message);
let spy = sensor.outbox;
let mut posted_messages = spy.posted_messages::<TemperatureReadingCelsius>();
@@ -67,8 +78,11 @@ mod tests {
let initial_temperature = 42;
let delta = 1;
let mut sensor = FakeTemperatureSensor::new(PostSpy::default(), initial_temperature, delta);
- sensor.read();
- sensor.read();
+
+ // manually send a message
+ let message = DoTemperatureRead;
+ sensor.receive(message);
+ sensor.receive(message);
let spy = sensor.outbox;
let mut posted_messages = spy.posted_messages::<TemperatureReadingCelsius>();
diff --git a/actor-example/actors/src/lib.rs b/actor-example/actors/src/lib.rs
index dae2c619..928f986a 100644
--- a/actor-example/actors/src/lib.rs
+++ b/actor-example/actors/src/lib.rs
@@ -8,6 +8,9 @@ pub use fake_temperature_sensor::FakeTemperatureSensor;
pub use temperature_monitor::TemperatureMonitor;
// Messages
+#[derive(Clone, Copy, Debug)]
+pub struct DoTemperatureRead;
+
pub struct TemperatureAlert;
#[derive(Clone, Debug, PartialEq)]
diff --git a/actor-example/firmware/src/bin/temperature-monitor.rs b/actor-example/firmware/src/bin/temperature-monitor.rs
index 6636d582..8e9b7613 100644
--- a/actor-example/firmware/src/bin/temperature-monitor.rs
+++ b/actor-example/firmware/src/bin/temperature-monitor.rs
@@ -6,7 +6,8 @@ use firmware as _;
#[rtic::app(device = nrf52840_hal::pac, dispatchers = [RADIO])]
mod app {
use actors::{
- FakeTemperatureSensor, TemperatureAlert, TemperatureMonitor, TemperatureReadingCelsius,
+ DoTemperatureRead, FakeTemperatureSensor, TemperatureAlert, TemperatureMonitor,
+ TemperatureReadingCelsius,
};
use rtic_actor_traits::Receive;
use systick_monotonic::*;
@@ -36,6 +37,9 @@ mod app {
#[actors]
struct Actors {
+ #[subscribe(DoTemperatureRead)]
+ temperature_sensor: FakeTemperatureSensor<Poster>,
+
#[init(AlertHandler)]
#[subscribe(TemperatureAlert)]
alert_handler: AlertHandler,
@@ -50,7 +54,7 @@ mod app {
#[local]
struct Local {
- temperature_sensor: FakeTemperatureSensor<Poster>,
+ poster: Poster,
}
#[monotonic(binds = SysTick, default = true)]
@@ -71,17 +75,20 @@ mod app {
(
Shared {},
- Local { temperature_sensor },
+ Local { poster },
init::Monotonics(mono),
Actors {
temperature_monitor,
+ temperature_sensor,
},
)
}
- #[task(local = [temperature_sensor])]
+ #[task(local = [poster])]
fn periodic(cx: periodic::Context) {
- cx.local.temperature_sensor.read();
+ // input to the actor network
+ cx.local.poster.post(DoTemperatureRead).expect("OOM");
+
periodic::spawn_after(1.secs()).expect("OOM");
}