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
// This file was generated by gir (https://github.com/gtk-rs/gir)
// from gir-files (https://github.com/gtk-rs/gir-files)
// from webkit-gir-files
// DO NOT EDIT

use crate::{ffi, AutoplayPolicy};
use glib::{prelude::*, translate::*};

glib::wrapper! {
    /// View specific website policies.
    ///
    /// WebKitWebsitePolicies allows you to configure per-page policies,
    /// currently only autoplay policies are supported.
    ///
    /// ## Properties
    ///
    ///
    /// #### `autoplay`
    ///  The #WebKitAutoplayPolicy of #WebKitWebsitePolicies.
    ///
    /// Readable | Writeable | Construct Only
    #[doc(alias = "WebKitWebsitePolicies")]
    pub struct WebsitePolicies(Object<ffi::WebKitWebsitePolicies, ffi::WebKitWebsitePoliciesClass>);

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

impl WebsitePolicies {
    /// Create a new #WebKitWebsitePolicies.
    ///
    /// # Returns
    ///
    /// the newly created #WebKitWebsitePolicies
    #[doc(alias = "webkit_website_policies_new")]
    pub fn new() -> WebsitePolicies {
        assert_initialized_main_thread!();
        unsafe { from_glib_full(ffi::webkit_website_policies_new()) }
    }

    //#[doc(alias = "webkit_website_policies_new_with_policies")]
    //#[doc(alias = "new_with_policies")]
    //pub fn with_policies(first_policy_name: &str, : /*Unknown conversion*//*Unimplemented*/Basic: VarArgs) -> WebsitePolicies {
    //    unsafe { TODO: call ffi:webkit_website_policies_new_with_policies() }
    //}

    // rustdoc-stripper-ignore-next
    /// Creates a new builder-pattern struct instance to construct [`WebsitePolicies`] objects.
    ///
    /// This method returns an instance of [`WebsitePoliciesBuilder`](crate::builders::WebsitePoliciesBuilder) which can be used to create [`WebsitePolicies`] objects.
    pub fn builder() -> WebsitePoliciesBuilder {
        WebsitePoliciesBuilder::new()
    }

    /// Get the #WebKitWebsitePolicies:autoplay property.
    ///
    /// # Returns
    ///
    /// #WebKitAutoplayPolicy
    #[doc(alias = "webkit_website_policies_get_autoplay_policy")]
    #[doc(alias = "get_autoplay_policy")]
    pub fn autoplay_policy(&self) -> AutoplayPolicy {
        unsafe {
            from_glib(ffi::webkit_website_policies_get_autoplay_policy(
                self.to_glib_none().0,
            ))
        }
    }

    /// The #WebKitAutoplayPolicy of #WebKitWebsitePolicies.
    pub fn autoplay(&self) -> AutoplayPolicy {
        ObjectExt::property(self, "autoplay")
    }
}

impl Default for WebsitePolicies {
    fn default() -> Self {
        Self::new()
    }
}

// rustdoc-stripper-ignore-next
/// A [builder-pattern] type to construct [`WebsitePolicies`] objects.
///
/// [builder-pattern]: https://doc.rust-lang.org/1.0.0/style/ownership/builders.html
#[must_use = "The builder must be built to be used"]
pub struct WebsitePoliciesBuilder {
    builder: glib::object::ObjectBuilder<'static, WebsitePolicies>,
}

impl WebsitePoliciesBuilder {
    fn new() -> Self {
        Self {
            builder: glib::object::Object::builder(),
        }
    }

    /// The #WebKitAutoplayPolicy of #WebKitWebsitePolicies.
    pub fn autoplay(self, autoplay: AutoplayPolicy) -> Self {
        Self {
            builder: self.builder.property("autoplay", autoplay),
        }
    }

    // rustdoc-stripper-ignore-next
    /// Build the [`WebsitePolicies`].
    #[must_use = "Building the object from the builder is usually expensive and is not expected to have side effects"]
    pub fn build(self) -> WebsitePolicies {
        self.builder.build()
    }
}