Files
telepathy-padfoot/src/telepathy/call_stream.rs
Nick Thomas 3d44ce6b3d Initial checkin
This commit contains autogenerated telepathy DBUS code and the output
of `cargo new telepathy-delta`. It's pretty chill.
2020-05-08 20:38:30 +01:00

191 lines
6.4 KiB
Rust

// 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<Vec<String>, tree::MethodErr>;
fn remote_members(&self) -> Result<::std::collections::HashMap<u32, u32>, tree::MethodErr>;
fn remote_member_identifiers(
&self,
) -> Result<::std::collections::HashMap<u32, String>, tree::MethodErr>;
fn local_sending_state(&self) -> Result<u32, tree::MethodErr>;
fn can_request_receiving(&self) -> Result<bool, tree::MethodErr>;
}
pub fn call1_stream_server<F, T, D>(
factory: &tree::Factory<tree::MTFn<D>, D>,
data: D::Interface,
f: F,
) -> tree::Interface<tree::MTFn<D>, D>
where
D: tree::DataType,
D::Method: Default,
D::Property: Default,
D::Signal: Default,
T: Call1Stream,
F: 'static + for<'z> Fn(&'z tree::MethodInfo<tree::MTFn<D>, 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<tree::MTFn<D>, 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<tree::MTFn<D>, 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::<Vec<&str>, _>("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<u32, u32>, _>("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<u32, &str>, _>(
"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::<u32, _>("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::<bool, _>("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<u32, u32>,
pub identifiers: ::std::collections::HashMap<u32, String>,
pub removed: Vec<u32>,
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<Self, arg::TypeMismatchError> {
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<Self, arg::TypeMismatchError> {
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";
}