-
Notifications
You must be signed in to change notification settings - Fork 173
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* add querier * add LivelinessQuerier * code clean up * interest support * make keyexpr include/intersect checking functions generic * remove liveliness querier * add matching status for querier * add matching listener support * clippy fix * clippy fix * clippy fix * clippy and fmt fix * doc test fix * docs fix * fix MatchingStatus/Listener to work on session-local entities with origin=Locality::SessionLocal * Merge branch 'main' into querier * clippy fix * fix review comments * explain #[allow(unused_mut)] * explain behaviour of keyexpr_intersect and keyexpr_include in case of conversion failure * log error when keyexpr_intersect/includes fails keyexpr conversion * add matching listener to z_pub example; add flag to enable/disable matching listener in the z_pub and z_querier examples; * add test for querier * add test for matching listener/status * simplify MatchingListenerBuilder::with<Handler> * remove aggregated queriers * moved all MatchingStatus/Listener functionality under separate module * fixed z_querier example to accept selector instead of keyexpr * new clippy fixes * mark querier related features as unstable
- Loading branch information
1 parent
c764bf9
commit 549bc7b
Showing
27 changed files
with
2,553 additions
and
750 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,157 @@ | ||
// | ||
// Copyright (c) 2024 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, <[email protected]> | ||
// | ||
use std::time::Duration; | ||
|
||
use clap::Parser; | ||
use zenoh::{ | ||
query::{QueryTarget, Selector}, | ||
Config, | ||
}; | ||
use zenoh_examples::CommonArgs; | ||
|
||
#[tokio::main] | ||
async fn main() { | ||
// initiate logging | ||
zenoh::init_log_from_env_or("error"); | ||
#[cfg(feature = "unstable")] | ||
let (config, selector, payload, target, timeout, add_matching_listener) = parse_args(); | ||
#[cfg(not(feature = "unstable"))] | ||
let (config, selector, payload, target, timeout, _) = parse_args(); | ||
|
||
println!("Opening session..."); | ||
let session = zenoh::open(config).await.unwrap(); | ||
|
||
println!("Declaring Querier on '{}'...", selector.key_expr()); | ||
let querier = session | ||
.declare_querier(selector.key_expr()) | ||
.target(target) | ||
.timeout(timeout) | ||
.await | ||
.unwrap(); | ||
|
||
#[cfg(feature = "unstable")] | ||
if add_matching_listener { | ||
querier | ||
.matching_listener() | ||
.callback(|matching_status| { | ||
if matching_status.matching() { | ||
println!("Querier has matching queryables."); | ||
} else { | ||
println!("Querier has NO MORE matching queryables."); | ||
} | ||
}) | ||
.background() | ||
.await | ||
.unwrap(); | ||
} | ||
|
||
let params = selector.parameters().as_str(); | ||
|
||
println!("Press CTRL-C to quit..."); | ||
for idx in 0..u32::MAX { | ||
tokio::time::sleep(Duration::from_secs(1)).await; | ||
let buf = format!("[{idx:4}] {}", payload.clone().unwrap_or_default()); | ||
println!("Querying '{}' with payload: '{}'...", &selector, buf); | ||
let replies = querier | ||
.get() | ||
// // By default get receives replies from a FIFO. | ||
// // Uncomment this line to use a ring channel instead. | ||
// // More information on the ring channel are available in the z_pull example. | ||
// .with(zenoh::handlers::RingChannel::default()) | ||
// Refer to z_bytes.rs to see how to serialize different types of message | ||
.payload(buf) | ||
.parameters(params) | ||
.await | ||
.unwrap(); | ||
while let Ok(reply) = replies.recv_async().await { | ||
match reply.result() { | ||
Ok(sample) => { | ||
// Refer to z_bytes.rs to see how to deserialize different types of message | ||
let payload = sample | ||
.payload() | ||
.try_to_string() | ||
.unwrap_or_else(|e| e.to_string().into()); | ||
println!( | ||
">> Received ('{}': '{}')", | ||
sample.key_expr().as_str(), | ||
payload, | ||
); | ||
} | ||
Err(err) => { | ||
let payload = err | ||
.payload() | ||
.try_to_string() | ||
.unwrap_or_else(|e| e.to_string().into()); | ||
println!(">> Received (ERROR: '{}')", payload); | ||
} | ||
} | ||
} | ||
} | ||
} | ||
|
||
#[derive(clap::ValueEnum, Clone, Copy, Debug)] | ||
#[value(rename_all = "SCREAMING_SNAKE_CASE")] | ||
enum Qt { | ||
BestMatching, | ||
All, | ||
AllComplete, | ||
} | ||
|
||
#[derive(Parser, Clone, Debug)] | ||
struct Args { | ||
#[arg(short, long, default_value = "demo/example/**")] | ||
/// The selection of resources to query | ||
selector: Selector<'static>, | ||
#[arg(short, long)] | ||
/// An optional payload to put in the query. | ||
payload: Option<String>, | ||
#[arg(short, long, default_value = "BEST_MATCHING")] | ||
/// The target queryables of the query. | ||
target: Qt, | ||
#[arg(short = 'o', long, default_value = "10000")] | ||
/// The query timeout in milliseconds. | ||
timeout: u64, | ||
/// Enable matching listener. | ||
#[cfg(feature = "unstable")] | ||
#[arg(long)] | ||
add_matching_listener: bool, | ||
#[command(flatten)] | ||
common: CommonArgs, | ||
} | ||
|
||
fn parse_args() -> ( | ||
Config, | ||
Selector<'static>, | ||
Option<String>, | ||
QueryTarget, | ||
Duration, | ||
bool, | ||
) { | ||
let args = Args::parse(); | ||
( | ||
args.common.into(), | ||
args.selector, | ||
args.payload, | ||
match args.target { | ||
Qt::BestMatching => QueryTarget::BestMatching, | ||
Qt::All => QueryTarget::All, | ||
Qt::AllComplete => QueryTarget::AllComplete, | ||
}, | ||
Duration::from_millis(args.timeout), | ||
#[cfg(feature = "unstable")] | ||
args.add_matching_listener, | ||
#[cfg(not(feature = "unstable"))] | ||
false, | ||
) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.