forked from eclipse-zenoh/zenoh-python
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathz_advanced_sub.py
More file actions
74 lines (59 loc) · 2.06 KB
/
z_advanced_sub.py
File metadata and controls
74 lines (59 loc) · 2.06 KB
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
#
# Copyright (c) 2022 ZettaScale Technology
#
# This program and the accompanying materials are made available under the
# terms of the Eclipse Public License 2.0 which is available at
# http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
# which is available at https://www.apache.org/licenses/LICENSE-2.0.
#
# SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
#
# Contributors:
# ZettaScale Zenoh Team, <zenoh@zettascale.tech>
#
import time
import zenoh
from zenoh.ext import HistoryConfig, Miss, RecoveryConfig, declare_advanced_subscriber
def main(conf: zenoh.Config, key: str):
# initiate logging
zenoh.init_log_from_env_or("error")
print("Opening session...")
with zenoh.open(conf) as session:
print(f"Declaring Subscriber on '{key}'...")
def listener(sample: zenoh.Sample):
print(
f">> [Subscriber] Received {sample.kind} ('{sample.key_expr}': '{sample.payload.to_string()}')"
)
advanced_sub = declare_advanced_subscriber(
session,
key,
listener,
history=HistoryConfig(detect_late_publishers=True),
recovery=RecoveryConfig(heartbeat=True),
subscriber_detection=True,
)
def miss_listener(miss: Miss):
print(f">> [Subscriber] Missed {miss.nb} samples from {miss.source} !!!")
advanced_sub.sample_miss_listener(miss_listener)
print("Press CTRL-C to quit...")
while True:
time.sleep(1)
# --- Command line argument parsing --- --- --- --- --- ---
if __name__ == "__main__":
import argparse
import common
parser = argparse.ArgumentParser(
prog="z_advanced_sub", description="zenoh advanced sub example"
)
common.add_config_arguments(parser)
parser.add_argument(
"--key",
"-k",
dest="key",
default="demo/example/**",
type=str,
help="The key expression to subscribe to.",
)
args = parser.parse_args()
conf = common.get_config_from_args(args)
main(conf, args.key)