request_response/
request_response.rs1use tractor::prelude::*;
2
3enum MyActorMsg {
4 Add(usize, usize),
5 AddedResult(usize),
6}
7
8enum AdderMsg {
9 Add {
10 a: usize,
11 b: usize,
12 respond: Chan<MyActorMsg>,
13 },
14}
15
16struct MyActor {
17 adder: Chan<AdderMsg>,
18}
19
20impl Actor for MyActor {
21 type Msg = MyActorMsg;
22}
23
24impl ActorHooks for MyActor {}
25
26impl ActorBehavior for MyActor {
27 fn handle(&mut self, msg: MyActorMsg, ctx: &Context<Self>) {
28 match msg {
29 MyActorMsg::Add(a, b) => {
30 self.adder.send(AdderMsg::Add {
31 a,
32 b,
33 respond: ctx.myself().chan(),
34 });
35 }
36
37 MyActorMsg::AddedResult(result) => {
38 println!("Result: {}", result);
39 }
40 }
41 }
42}
43
44struct Adder;
45
46impl Actor for Adder {
47 type Msg = AdderMsg;
48}
49
50impl ActorBehavior for Adder {
51 fn handle(&mut self, msg: AdderMsg, _: &Context<Self>) {
52 match msg {
53 AdderMsg::Add { a, b, respond } => {
54 respond.send(MyActorMsg::AddedResult(a + b));
55 }
56 }
57 }
58}
59
60impl ActorHooks for Adder {}
61
62fn run() {
63 let adder = Adder.start().chan();
64 let myactor = MyActor { adder }.start();
65
66 myactor.send(MyActorMsg::Add(1, 2));
67 myactor.send(MyActorMsg::Add(1, 5));
68}
69
70fn main() {
71 ActorSystem::run_to_completion(run);
72}