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

213 lines
7.1 KiB
Rust

// This code was autogenerated with `dbus-codegen-rust --file telepathy-spec/spec/Channel_Interface_Room_Config.xml -i org.freedesktop.Telepathy -o src/telepathy/channel_interface_room_config.rs`, see https://github.com/diwic/dbus-rs
use dbus;
use dbus::arg;
use dbus::tree;
pub trait ChannelInterfaceRoomConfig1 {
fn update_configuration(
&self,
properties: ::std::collections::HashMap<&str, arg::Variant<Box<dyn arg::RefArg>>>,
) -> Result<(), tree::MethodErr>;
fn anonymous(&self) -> Result<bool, tree::MethodErr>;
fn invite_only(&self) -> Result<bool, tree::MethodErr>;
fn limit(&self) -> Result<u32, tree::MethodErr>;
fn moderated(&self) -> Result<bool, tree::MethodErr>;
fn title(&self) -> Result<String, tree::MethodErr>;
fn description(&self) -> Result<String, tree::MethodErr>;
fn persistent(&self) -> Result<bool, tree::MethodErr>;
fn private(&self) -> Result<bool, tree::MethodErr>;
fn password_protected(&self) -> Result<bool, tree::MethodErr>;
fn password(&self) -> Result<String, tree::MethodErr>;
fn password_hint(&self) -> Result<String, tree::MethodErr>;
fn can_update_configuration(&self) -> Result<bool, tree::MethodErr>;
fn mutable_properties(&self) -> Result<Vec<String>, tree::MethodErr>;
fn configuration_retrieved(&self) -> Result<bool, tree::MethodErr>;
}
pub fn channel_interface_room_config1_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: ChannelInterfaceRoomConfig1,
F: 'static + for<'z> Fn(&'z tree::MethodInfo<tree::MTFn<D>, D>) -> &'z T,
{
let i = factory.interface(
"org.freedesktop.Telepathy.Channel.Interface.RoomConfig1",
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 properties: ::std::collections::HashMap<&str, arg::Variant<Box<dyn arg::RefArg>>> =
i.read()?;
let d = fclone(minfo);
d.update_configuration(properties)?;
let rm = minfo.msg.method_return();
Ok(vec![rm])
};
let m = factory.method("UpdateConfiguration", Default::default(), h);
let m = m.in_arg(("Properties", "a{sv}"));
let i = i.add_m(m);
let p = factory.property::<bool, _>("Anonymous", 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.anonymous()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("InviteOnly", 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.invite_only()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<u32, _>("Limit", 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.limit()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("Moderated", 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.moderated()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<&str, _>("Title", 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.title()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<&str, _>("Description", 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.description()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("Persistent", 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.persistent()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("Private", 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.private()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("PasswordProtected", 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.password_protected()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<&str, _>("Password", 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.password()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<&str, _>("PasswordHint", 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.password_hint()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("CanUpdateConfiguration", 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_update_configuration()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<Vec<&str>, _>("MutableProperties", 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.mutable_properties()?);
Ok(())
});
let i = i.add_p(p);
let p = factory.property::<bool, _>("ConfigurationRetrieved", 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.configuration_retrieved()?);
Ok(())
});
let i = i.add_p(p);
i
}