1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// This file was generated by gir (https://github.com/gtk-rs/gir)
// from
// from gir-files (https://github.com/gtk-rs/gir-files.git)
// DO NOT EDIT

use crate::AnimationTarget;
use glib::{prelude::*, translate::*};

glib::wrapper! {
    /// An [`AnimationTarget`][crate::AnimationTarget] changing the value of a property of a
    /// [`glib::Object`][crate::glib::Object] instance.
    ///
    /// ## Properties
    ///
    ///
    /// #### `object`
    ///  The object whose property will be animated.
    ///
    /// The [`PropertyAnimationTarget`][crate::PropertyAnimationTarget] instance does not hold a strong reference
    /// on the object; make sure the object is kept alive throughout the target's
    /// lifetime.
    ///
    /// Readable | Writeable | Construct Only
    ///
    ///
    /// #### `pspec`
    ///  The `GParamSpec` of the property to be animated.
    ///
    /// Readable | Writeable | Construct Only
    ///
    /// # Implements
    ///
    /// [`AnimationTargetExt`][trait@crate::prelude::AnimationTargetExt], [`trait@glib::ObjectExt`]
    #[doc(alias = "AdwPropertyAnimationTarget")]
    pub struct PropertyAnimationTarget(Object<ffi::AdwPropertyAnimationTarget, ffi::AdwPropertyAnimationTargetClass>) @extends AnimationTarget;

    match fn {
        type_ => || ffi::adw_property_animation_target_get_type(),
    }
}

impl PropertyAnimationTarget {
    /// Creates a new [`PropertyAnimationTarget`][crate::PropertyAnimationTarget] for the @property_name property on
    /// @object.
    /// ## `object`
    /// an object to be animated
    /// ## `property_name`
    /// the name of the property on @object to animate
    ///
    /// # Returns
    ///
    /// the newly created [`PropertyAnimationTarget`][crate::PropertyAnimationTarget]
    #[doc(alias = "adw_property_animation_target_new")]
    pub fn new(object: &impl IsA<glib::Object>, property_name: &str) -> PropertyAnimationTarget {
        assert_initialized_main_thread!();
        unsafe {
            AnimationTarget::from_glib_full(ffi::adw_property_animation_target_new(
                object.as_ref().to_glib_none().0,
                property_name.to_glib_none().0,
            ))
            .unsafe_cast()
        }
    }

    /// Creates a new [`PropertyAnimationTarget`][crate::PropertyAnimationTarget] for the @pspec property on
    /// @object.
    /// ## `object`
    /// an object to be animated
    /// ## `pspec`
    /// the param spec of the property on @object to animate
    ///
    /// # Returns
    ///
    /// new newly created [`PropertyAnimationTarget`][crate::PropertyAnimationTarget]
    #[doc(alias = "adw_property_animation_target_new_for_pspec")]
    #[doc(alias = "new_for_pspec")]
    pub fn for_pspec(
        object: &impl IsA<glib::Object>,
        pspec: impl AsRef<glib::ParamSpec>,
    ) -> PropertyAnimationTarget {
        assert_initialized_main_thread!();
        unsafe {
            AnimationTarget::from_glib_full(ffi::adw_property_animation_target_new_for_pspec(
                object.as_ref().to_glib_none().0,
                pspec.as_ref().to_glib_none().0,
            ))
            .unsafe_cast()
        }
    }

    /// Gets the object animated by @self.
    ///
    /// The [`PropertyAnimationTarget`][crate::PropertyAnimationTarget] instance does not hold a strong reference on
    /// the object; make sure the object is kept alive throughout the target's
    /// lifetime.
    ///
    /// # Returns
    ///
    /// the animated object
    #[doc(alias = "adw_property_animation_target_get_object")]
    #[doc(alias = "get_object")]
    pub fn object(&self) -> glib::Object {
        unsafe {
            from_glib_none(ffi::adw_property_animation_target_get_object(
                self.to_glib_none().0,
            ))
        }
    }

    /// Gets the `GParamSpec` of the property animated by @self.
    ///
    /// # Returns
    ///
    /// the animated property's `GParamSpec`
    #[doc(alias = "adw_property_animation_target_get_pspec")]
    #[doc(alias = "get_pspec")]
    pub fn pspec(&self) -> glib::ParamSpec {
        unsafe {
            from_glib_none(ffi::adw_property_animation_target_get_pspec(
                self.to_glib_none().0,
            ))
        }
    }
}