110 lines
3.7 KiB
Rust
110 lines
3.7 KiB
Rust
// This code was autogenerated with `dbus-codegen-rust --file telepathy-spec/spec/Connection_Interface_Anonymity.xml -i org.freedesktop.Telepathy -a AsRefClosure -o src/telepathy/connection_interface_anonymity.rs`, see https://github.com/diwic/dbus-rs
|
|
use dbus;
|
|
use dbus::arg;
|
|
use dbus::tree;
|
|
|
|
pub trait ConnectionInterfaceAnonymity {
|
|
fn supported_anonymity_modes(&self) -> Result<u32, tree::MethodErr>;
|
|
fn anonymity_mandatory(&self) -> Result<bool, tree::MethodErr>;
|
|
fn set_anonymity_mandatory(&self, value: bool) -> Result<(), tree::MethodErr>;
|
|
fn anonymity_modes(&self) -> Result<u32, tree::MethodErr>;
|
|
fn set_anonymity_modes(&self, value: u32) -> Result<(), tree::MethodErr>;
|
|
}
|
|
|
|
pub fn connection_interface_anonymity_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: AsRef<dyn ConnectionInterfaceAnonymity>,
|
|
F: 'static + Fn(&tree::MethodInfo<tree::MTFn<D>, D>) -> T,
|
|
{
|
|
let i = factory.interface(
|
|
"org.freedesktop.Telepathy.Connection.Interface.Anonymity",
|
|
data,
|
|
);
|
|
let f = ::std::sync::Arc::new(f);
|
|
let p = factory.property::<u32, _>("SupportedAnonymityModes", 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 dd = fclone(&minfo);
|
|
let d = dd.as_ref();
|
|
a.append(d.supported_anonymity_modes()?);
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
|
|
let p = factory.property::<bool, _>("AnonymityMandatory", Default::default());
|
|
let p = p.access(tree::Access::ReadWrite);
|
|
let fclone = f.clone();
|
|
let p = p.on_get(move |a, pinfo| {
|
|
let minfo = pinfo.to_method_info();
|
|
let dd = fclone(&minfo);
|
|
let d = dd.as_ref();
|
|
a.append(d.anonymity_mandatory()?);
|
|
Ok(())
|
|
});
|
|
let fclone = f.clone();
|
|
let p = p.on_set(move |iter, pinfo| {
|
|
let minfo = pinfo.to_method_info();
|
|
let dd = fclone(&minfo);
|
|
let d = dd.as_ref();
|
|
d.set_anonymity_mandatory(iter.read()?)?;
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
|
|
let p = factory.property::<u32, _>("AnonymityModes", Default::default());
|
|
let p = p.access(tree::Access::ReadWrite);
|
|
let fclone = f.clone();
|
|
let p = p.on_get(move |a, pinfo| {
|
|
let minfo = pinfo.to_method_info();
|
|
let dd = fclone(&minfo);
|
|
let d = dd.as_ref();
|
|
a.append(d.anonymity_modes()?);
|
|
Ok(())
|
|
});
|
|
let fclone = f.clone();
|
|
let p = p.on_set(move |iter, pinfo| {
|
|
let minfo = pinfo.to_method_info();
|
|
let dd = fclone(&minfo);
|
|
let d = dd.as_ref();
|
|
d.set_anonymity_modes(iter.read()?)?;
|
|
Ok(())
|
|
});
|
|
let i = i.add_p(p);
|
|
let s = factory.signal("AnonymityModesChanged", Default::default());
|
|
let s = s.arg(("Modes", "u"));
|
|
let i = i.add_s(s);
|
|
i
|
|
}
|
|
|
|
#[derive(Debug)]
|
|
pub struct ConnectionInterfaceAnonymityAnonymityModesChanged {
|
|
pub modes: u32,
|
|
}
|
|
|
|
impl arg::AppendAll for ConnectionInterfaceAnonymityAnonymityModesChanged {
|
|
fn append(&self, i: &mut arg::IterAppend) {
|
|
arg::RefArg::append(&self.modes, i);
|
|
}
|
|
}
|
|
|
|
impl arg::ReadAll for ConnectionInterfaceAnonymityAnonymityModesChanged {
|
|
fn read(i: &mut arg::Iter) -> Result<Self, arg::TypeMismatchError> {
|
|
Ok(ConnectionInterfaceAnonymityAnonymityModesChanged { modes: i.read()? })
|
|
}
|
|
}
|
|
|
|
impl dbus::message::SignalArgs for ConnectionInterfaceAnonymityAnonymityModesChanged {
|
|
const NAME: &'static str = "AnonymityModesChanged";
|
|
const INTERFACE: &'static str = "org.freedesktop.Telepathy.Connection.Interface.Anonymity";
|
|
}
|