use crate::ActionGroup;
use glib::{prelude::*, translate::*};
glib::wrapper! {
#[doc(alias = "GRemoteActionGroup")]
pub struct RemoteActionGroup(Interface<ffi::GRemoteActionGroup, ffi::GRemoteActionGroupInterface>) @requires ActionGroup;
match fn {
type_ => || ffi::g_remote_action_group_get_type(),
}
}
impl RemoteActionGroup {
pub const NONE: Option<&'static RemoteActionGroup> = None;
}
mod sealed {
pub trait Sealed {}
impl<T: super::IsA<super::RemoteActionGroup>> Sealed for T {}
}
pub trait RemoteActionGroupExt: IsA<RemoteActionGroup> + sealed::Sealed + 'static {
#[doc(alias = "g_remote_action_group_activate_action_full")]
fn activate_action_full(
&self,
action_name: &str,
parameter: Option<&glib::Variant>,
platform_data: &glib::Variant,
) {
unsafe {
ffi::g_remote_action_group_activate_action_full(
self.as_ref().to_glib_none().0,
action_name.to_glib_none().0,
parameter.to_glib_none().0,
platform_data.to_glib_none().0,
);
}
}
#[doc(alias = "g_remote_action_group_change_action_state_full")]
fn change_action_state_full(
&self,
action_name: &str,
value: &glib::Variant,
platform_data: &glib::Variant,
) {
unsafe {
ffi::g_remote_action_group_change_action_state_full(
self.as_ref().to_glib_none().0,
action_name.to_glib_none().0,
value.to_glib_none().0,
platform_data.to_glib_none().0,
);
}
}
}
impl<O: IsA<RemoteActionGroup>> RemoteActionGroupExt for O {}