実現したいこと
dbus-tokioを使って、、非同期にbluezのmanaged objectの情報を取得したい。
発生している問題・エラーメッセージ
blocking
の実装とnonblock
の実装でそれぞれbluez
に対してorg.freedesktop.DBus.ObjectManager.GetManagedObjects
を実施し、標準出力に取得した情報を表示するプログラムです。
期待している動作は同じ内容が2回出力されることなのですが、nonblock
の方はタイムアウトしてしまいます。以下のエラーメッセージが出力されます。
Error: D-Bus error: Timeout waiting for reply (org.freedesktop.DBus.Error.Timeout)
該当のソースコード
rust
1use dbus; 2use dbus::arg; 3use dbus::blocking::Connection; 4use dbus::nonblock::Proxy; 5use dbus_tokio::connection; 6use std::collections::HashMap; 7use std::error::Error; 8use std::time::Duration; 9 10type ManagedObjects = HashMap< 11 dbus::Path<'static>, 12 HashMap<String, HashMap<String, arg::Variant<Box<dyn arg::RefArg + 'static>>>>, 13>; 14 15#[tokio::main] 16pub async fn main() -> Result<(), Box<dyn Error>> { 17 println!("--- blocking ---"); 18 blocking_get_managed_objects()?; // OK. 19 println!("--- nonblock ---"); 20 nonblock_get_managed_objects().await?; // Error: D-Bus error: Timeout waiting for reply (org.freedesktop.DBus.Error.Timeout) 21 Ok(()) 22} 23 24async fn nonblock_get_managed_objects() -> Result<(), Box<dyn Error>> { 25 let (_resource, conn) = connection::new_system_sync()?; 26 let proxy = Proxy::new("org.bluez", "/", Duration::from_secs(2), conn); 27 let (objects,): (ManagedObjects,) = proxy 28 .method_call( 29 "org.freedesktop.DBus.ObjectManager", 30 "GetManagedObjects", 31 (), 32 ) 33 .await?; 34 print_managed_object(objects); 35 Ok(()) 36} 37 38fn blocking_get_managed_objects() -> Result<(), Box<dyn Error>> { 39 let conn = Connection::new_system()?; 40 let proxy = conn.with_proxy("org.bluez", "/", Duration::from_secs(2)); 41 let (objects,): (ManagedObjects,) = proxy.method_call( 42 "org.freedesktop.DBus.ObjectManager", 43 "GetManagedObjects", 44 (), 45 )?; 46 print_managed_object(objects); 47 Ok(()) 48} 49 50fn print_managed_object(objects: ManagedObjects) { 51 for (key, value) in objects.iter() { 52 println!("{}: {{", key); 53 for (key, value) in value.iter() { 54 println!(" {}: {{", key); 55 for (key, value) in value.iter() { 56 print!(" {}: ", key); 57 print_refarg(value); 58 } 59 println!(" }}"); 60 } 61 println!("}}"); 62 } 63} 64 65fn print_refarg(value: &dyn arg::RefArg) { 66 if let Some(s) = value.as_str() { 67 println!("{}", s); 68 } else if let Some(i) = value.as_i64() { 69 println!("{}", i); 70 } else { 71 println!("{:?}", value); 72 } 73}
試したこと
dbus-monitorでnonblockの方もmethod_returnが返ってきていることは確認しています。
補足情報(FW/ツールのバージョンなど)
項目 | バージョン |
---|---|
OS | Ubuntu 18.04 |
rustc | ver 1.40.0 |
dbus | ver 1.12.2 |
bluez | ver 5.48 |
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。