1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
use super::connection::Connection;
use crate::command::Command;
use futures::StreamExt;
impl Connection {
pub(crate) async fn run(mut self) {
while let Some(cmd) = self.command_receiver.next().await {
match cmd {
Command::ReceiveMessage(msg) => self.receive_message(msg),
Command::SendMessage(msg) => self.send_message(msg),
Command::SendMessageOneshot(msg, response) => {
self.send_message_oneshot(msg, response)
}
Command::SendMessageMpcs(msg, response_reply_serial, response) => {
self.send_message_mpsc(msg, response_reply_serial, response)
}
Command::AddMethodCall(object_path, object) => {
self.method_calls.insert(object_path, object);
}
Command::DeleteMethodCall(object_path) => {
self.method_calls.remove(&object_path);
}
Command::DeleteMethodCallSender(sender_other) => {
self.method_calls
.retain(|_, sender| !sender_other.same_receiver(sender));
}
Command::DeleteMethodCallReceiver(receiver) => {
self.method_calls
.retain(|_, sender| !sender.is_connected_to(&receiver));
}
Command::ListMethodCall(object_path, sender) => {
self.list_path(&object_path, sender)
}
Command::AddMethodCallInterface(interface, sender) => {
self.method_calls_interface.insert(interface, sender);
}
Command::DeleteMethodCallInterface(interface) => {
self.method_calls_interface.remove(&interface);
}
Command::DeleteMethodCallInterfaceSender(sender_other) => {
self.method_calls_interface
.retain(|_, sender| !sender_other.same_receiver(sender));
}
Command::DeleteMethodCallInterfaceReceiver(receiver) => {
self.method_calls_interface
.retain(|_, sender| !sender.is_connected_to(&receiver));
}
Command::AddSignal(object_path, filter, sender) => {
if let Some(vec) = self.signals.get_mut(&object_path) {
vec.push((filter, sender));
} else {
self.signals.insert(object_path, vec![(filter, sender)]);
}
}
Command::DeleteSignalSender(sender_other) => {
for vec_sender_message in self.signals.values_mut() {
vec_sender_message
.retain(|(_, sender)| !sender_other.same_receiver(sender));
}
}
Command::DeleteSignalReceiver(receiver) => {
for vec_sender_message in self.signals.values_mut() {
vec_sender_message.retain(|(_, sender)| !sender.is_connected_to(&receiver));
}
}
Command::Close => {
return;
}
}
}
}
}