Files
telepathy-padfoot/src/telepathy/channel_interface_picture.rs
2020-05-09 01:32:35 +01:00

196 lines
6.6 KiB
Rust

// This code was autogenerated with `dbus-codegen-rust --file telepathy-spec/spec/Channel_Interface_Picture.xml -i org.freedesktop.Telepathy -o src/telepathy/channel_interface_picture.rs`, see https://github.com/diwic/dbus-rs
use dbus;
use dbus::arg;
use dbus::tree;
pub trait ChannelInterfacePicture1 {
fn set_picture(&self, picture: Vec<u8>, mimetype: &str) -> Result<(), tree::MethodErr>;
fn picture(&self) -> Result<(Vec<u8>, String), tree::MethodErr>;
fn actor(&self) -> Result<String, tree::MethodErr>;
fn actor_handle(&self) -> Result<u32, tree::MethodErr>;
fn timestamp(&self) -> Result<i64, tree::MethodErr>;
fn can_set(&self) -> Result<bool, tree::MethodErr>;
fn supported_mimetypes(&self) -> Result<Vec<String>, tree::MethodErr>;
fn minimum_height(&self) -> Result<u32, tree::MethodErr>;
fn minimum_width(&self) -> Result<u32, tree::MethodErr>;
fn recommended_height(&self) -> Result<u32, tree::MethodErr>;
fn recommended_width(&self) -> Result<u32, tree::MethodErr>;
fn maximum_height(&self) -> Result<u32, tree::MethodErr>;
fn maximum_width(&self) -> Result<u32, tree::MethodErr>;
fn maximum_bytes(&self) -> Result<u32, tree::MethodErr>;
}
pub fn channel_interface_picture1_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,
T: ChannelInterfacePicture1,
F: 'static + for<'z> Fn(&'z tree::MethodInfo<tree::MTFn<D>, D>) -> &'z T,
{
let i = factory.interface("org.freedesktop.Telepathy.Channel.Interface.Picture1", 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 picture: Vec<u8> = i.read()?;
let mimetype: &str = i.read()?;
let d = fclone(minfo);
d.set_picture(picture, mimetype)?;
let rm = minfo.msg.method_return();
Ok(vec![rm])
};
let m = factory.method("SetPicture", Default::default(), h);
let m = m.in_arg(("Picture", "ay"));
let m = m.in_arg(("MIME_Type", "s"));
let i = i.add_m(m);
let p = factory.property::<(Vec<u8>, &str), _>("Picture", 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.picture()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<&str, _>("Actor", 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.actor()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("ActorHandle", 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.actor_handle()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<i64, _>("Timestamp", 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.timestamp()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("CanSet", 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_set()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<Vec<&str>, _>("SupportedMIMETypes", 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.supported_mimetypes()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("MinimumHeight", 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.minimum_height()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("MinimumWidth", 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.minimum_width()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("RecommendedHeight", 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.recommended_height()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("RecommendedWidth", 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.recommended_width()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("MaximumHeight", 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.maximum_height()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("MaximumWidth", 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.maximum_width()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("MaximumBytes", 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.maximum_bytes()?);
Ok(())
});
let i = i.add_p(p);
i
}