This commit contains autogenerated telepathy DBUS code and the output of `cargo new telepathy-delta`. It's pretty chill.
152 lines
4.7 KiB
Rust
152 lines
4.7 KiB
Rust
// This code was autogenerated with `dbus-codegen-rust --file telepathy-spec/spec/Call_Content.xml -i org.freedesktop.Telepathy -o src/telepathy/call_content.rs`, see https://github.com/diwic/dbus-rs
|
|
use dbus;
|
|
use dbus::arg;
|
|
use dbus::tree;
|
|
|
|
pub trait Call1Content {
|
|
fn remove(&self) -> Result<(), tree::MethodErr>;
|
|
fn interfaces(&self) -> Result<Vec<String>, tree::MethodErr>;
|
|
fn name(&self) -> Result<String, tree::MethodErr>;
|
|
fn type_(&self) -> Result<u32, tree::MethodErr>;
|
|
fn disposition(&self) -> Result<u32, tree::MethodErr>;
|
|
fn streams(&self) -> Result<Vec<dbus::Path<'static>>, tree::MethodErr>;
|
|
}
|
|
|
|
pub fn call1_content_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: Call1Content,
|
|
F: 'static + for<'z> Fn(&'z tree::MethodInfo<tree::MTFn<D>, D>) -> &'z T,
|
|
{
|
|
let i = factory.interface("org.freedesktop.Telepathy.Call1.Content", data);
|
|
let f = ::std::sync::Arc::new(f);
|
|
let fclone = f.clone();
|
|
let h = move |minfo: &tree::MethodInfo<tree::MTFn<D>, D>| {
|
|
let d = fclone(minfo);
|
|
d.remove()?;
|
|
let rm = minfo.msg.method_return();
|
|
Ok(vec![rm])
|
|
};
|
|
let m = factory.method("Remove", Default::default(), h);
|
|
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::<&str, _>("Name", 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.name()?);
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
|
|
let p = factory.property::<u32, _>("Type", 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.type_()?);
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
|
|
let p = factory.property::<u32, _>("Disposition", 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.disposition()?);
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
|
|
let p = factory.property::<Vec<dbus::Path>, _>("Streams", 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.streams()?);
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
let s = factory.signal("StreamsAdded", Default::default());
|
|
let s = s.arg(("Streams", "ao"));
|
|
let i = i.add_s(s);
|
|
let s = factory.signal("StreamsRemoved", Default::default());
|
|
let s = s.arg(("Streams", "ao"));
|
|
let s = s.arg(("Reason", "(uuss)"));
|
|
let i = i.add_s(s);
|
|
i
|
|
}
|
|
|
|
#[derive(Debug)]
|
|
pub struct Call1ContentStreamsAdded {
|
|
pub streams: Vec<dbus::Path<'static>>,
|
|
}
|
|
|
|
impl arg::AppendAll for Call1ContentStreamsAdded {
|
|
fn append(&self, i: &mut arg::IterAppend) {
|
|
arg::RefArg::append(&self.streams, i);
|
|
}
|
|
}
|
|
|
|
impl arg::ReadAll for Call1ContentStreamsAdded {
|
|
fn read(i: &mut arg::Iter) -> Result<Self, arg::TypeMismatchError> {
|
|
Ok(Call1ContentStreamsAdded { streams: i.read()? })
|
|
}
|
|
}
|
|
|
|
impl dbus::message::SignalArgs for Call1ContentStreamsAdded {
|
|
const NAME: &'static str = "StreamsAdded";
|
|
const INTERFACE: &'static str = "org.freedesktop.Telepathy.Call1.Content";
|
|
}
|
|
|
|
#[derive(Debug)]
|
|
pub struct Call1ContentStreamsRemoved {
|
|
pub streams: Vec<dbus::Path<'static>>,
|
|
pub reason: (u32, u32, String, String),
|
|
}
|
|
|
|
impl arg::AppendAll for Call1ContentStreamsRemoved {
|
|
fn append(&self, i: &mut arg::IterAppend) {
|
|
arg::RefArg::append(&self.streams, i);
|
|
arg::RefArg::append(&self.reason, i);
|
|
}
|
|
}
|
|
|
|
impl arg::ReadAll for Call1ContentStreamsRemoved {
|
|
fn read(i: &mut arg::Iter) -> Result<Self, arg::TypeMismatchError> {
|
|
Ok(Call1ContentStreamsRemoved {
|
|
streams: i.read()?,
|
|
reason: i.read()?,
|
|
})
|
|
}
|
|
}
|
|
|
|
impl dbus::message::SignalArgs for Call1ContentStreamsRemoved {
|
|
const NAME: &'static str = "StreamsRemoved";
|
|
const INTERFACE: &'static str = "org.freedesktop.Telepathy.Call1.Content";
|
|
}
|