// This code was autogenerated with `dbus-codegen-rust --file telepathy-spec/spec/Call_Stream.xml -i org.freedesktop.Telepathy -o src/telepathy/call_stream.rs`, see https://github.com/diwic/dbus-rs use dbus; use dbus::arg; use dbus::tree; pub trait Call1Stream { fn set_sending(&self, send: bool) -> Result<(), tree::MethodErr>; fn request_receiving(&self, contact: u32, receive: bool) -> Result<(), tree::MethodErr>; fn interfaces(&self) -> Result, tree::MethodErr>; fn remote_members(&self) -> Result<::std::collections::HashMap, tree::MethodErr>; fn remote_member_identifiers( &self, ) -> Result<::std::collections::HashMap, tree::MethodErr>; fn local_sending_state(&self) -> Result; fn can_request_receiving(&self) -> Result; } pub fn call1_stream_server( factory: &tree::Factory, D>, data: D::Interface, f: F, ) -> tree::Interface, D> where D: tree::DataType, D::Method: Default, D::Property: Default, D::Signal: Default, T: Call1Stream, F: 'static + for<'z> Fn(&'z tree::MethodInfo, D>) -> &'z T, { let i = factory.interface("org.freedesktop.Telepathy.Call1.Stream", data); let f = ::std::sync::Arc::new(f); let fclone = f.clone(); let h = move |minfo: &tree::MethodInfo, D>| { let mut i = minfo.msg.iter_init(); let send: bool = i.read()?; let d = fclone(minfo); d.set_sending(send)?; let rm = minfo.msg.method_return(); Ok(vec![rm]) }; let m = factory.method("SetSending", Default::default(), h); let m = m.in_arg(("Send", "b")); let i = i.add_m(m); let fclone = f.clone(); let h = move |minfo: &tree::MethodInfo, D>| { let mut i = minfo.msg.iter_init(); let contact: u32 = i.read()?; let receive: bool = i.read()?; let d = fclone(minfo); d.request_receiving(contact, receive)?; let rm = minfo.msg.method_return(); Ok(vec![rm]) }; let m = factory.method("RequestReceiving", Default::default(), h); let m = m.in_arg(("Contact", "u")); let m = m.in_arg(("Receive", "b")); let i = i.add_m(m); let p = factory.property::, _>("Interfaces", Default::default()); let p = p.access(tree::Access::Read); let fclone = f.clone(); let p = p.on_get(move |a, pinfo| { let minfo = pinfo.to_method_info(); let d = fclone(&minfo); a.append(d.interfaces()?); Ok(()) }); let i = i.add_p(p); let p = factory .property::<::std::collections::HashMap, _>("RemoteMembers", Default::default()); let p = p.access(tree::Access::Read); let fclone = f.clone(); let p = p.on_get(move |a, pinfo| { let minfo = pinfo.to_method_info(); let d = fclone(&minfo); a.append(d.remote_members()?); Ok(()) }); let i = i.add_p(p); let p = factory.property::<::std::collections::HashMap, _>( "RemoteMemberIdentifiers", Default::default(), ); let p = p.access(tree::Access::Read); let fclone = f.clone(); let p = p.on_get(move |a, pinfo| { let minfo = pinfo.to_method_info(); let d = fclone(&minfo); a.append(d.remote_member_identifiers()?); Ok(()) }); let i = i.add_p(p); let p = factory.property::("LocalSendingState", Default::default()); let p = p.access(tree::Access::Read); let fclone = f.clone(); let p = p.on_get(move |a, pinfo| { let minfo = pinfo.to_method_info(); let d = fclone(&minfo); a.append(d.local_sending_state()?); Ok(()) }); let i = i.add_p(p); let p = factory.property::("CanRequestReceiving", Default::default()); let p = p.access(tree::Access::Read); let fclone = f.clone(); let p = p.on_get(move |a, pinfo| { let minfo = pinfo.to_method_info(); let d = fclone(&minfo); a.append(d.can_request_receiving()?); Ok(()) }); let i = i.add_p(p); let s = factory.signal("RemoteMembersChanged", Default::default()); let s = s.arg(("Updates", "a{uu}")); let s = s.arg(("Identifiers", "a{us}")); let s = s.arg(("Removed", "au")); let s = s.arg(("Reason", "(uuss)")); let i = i.add_s(s); let s = factory.signal("LocalSendingStateChanged", Default::default()); let s = s.arg(("State", "u")); let s = s.arg(("Reason", "(uuss)")); let i = i.add_s(s); i } #[derive(Debug)] pub struct Call1StreamRemoteMembersChanged { pub updates: ::std::collections::HashMap, pub identifiers: ::std::collections::HashMap, pub removed: Vec, pub reason: (u32, u32, String, String), } impl arg::AppendAll for Call1StreamRemoteMembersChanged { fn append(&self, i: &mut arg::IterAppend) { arg::RefArg::append(&self.updates, i); arg::RefArg::append(&self.identifiers, i); arg::RefArg::append(&self.removed, i); arg::RefArg::append(&self.reason, i); } } impl arg::ReadAll for Call1StreamRemoteMembersChanged { fn read(i: &mut arg::Iter) -> Result { Ok(Call1StreamRemoteMembersChanged { updates: i.read()?, identifiers: i.read()?, removed: i.read()?, reason: i.read()?, }) } } impl dbus::message::SignalArgs for Call1StreamRemoteMembersChanged { const NAME: &'static str = "RemoteMembersChanged"; const INTERFACE: &'static str = "org.freedesktop.Telepathy.Call1.Stream"; } #[derive(Debug)] pub struct Call1StreamLocalSendingStateChanged { pub state: u32, pub reason: (u32, u32, String, String), } impl arg::AppendAll for Call1StreamLocalSendingStateChanged { fn append(&self, i: &mut arg::IterAppend) { arg::RefArg::append(&self.state, i); arg::RefArg::append(&self.reason, i); } } impl arg::ReadAll for Call1StreamLocalSendingStateChanged { fn read(i: &mut arg::Iter) -> Result { Ok(Call1StreamLocalSendingStateChanged { state: i.read()?, reason: i.read()?, }) } } impl dbus::message::SignalArgs for Call1StreamLocalSendingStateChanged { const NAME: &'static str = "LocalSendingStateChanged"; const INTERFACE: &'static str = "org.freedesktop.Telepathy.Call1.Stream"; }