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
use types::{Array, Object};

use crate::trait_utils::StringOrInt;
use crate::Buffer;

/// Options passed to [`get_autocmds()`](crate::get_autocmds).
#[cfg(feature = "neovim-0-10")] // On 0.10 and nightly.
#[derive(Clone, Debug, Default, macros::OptsBuilder)]
#[repr(C)]
pub struct GetAutocmdsOpts {
    #[builder(mask)]
    mask: u64,

    /// Get all the autocommands triggered by one or more of the specified
    /// events.
    #[builder(
        generics = "'a, E: IntoIterator<Item = &'a str>",
        method = "events",
        argtype = "E",
        inline = "Array::from_iter({0}).into()"
    )]
    event: Object,

    /// Only get the autocommands belonging to a specific augroup. The
    /// augroup can be specified by both id and name.
    #[builder(
        generics = "G: StringOrInt",
        method = "group",
        argtype = "G",
        inline = "{0}.to_object()"
    )]
    group: Object,

    /// Only get the autocommands that match specific patterns. For example, if
    /// you have `"*.py"` as a pattern for a particular autocommand, you must
    /// pass that exact pattern to clear it. Cannot be used together with
    /// `buffer`.
    #[builder(
        generics = "'a, P: IntoIterator<Item = &'a str>",
        method = "patterns",
        argtype = "P",
        inline = "Array::from_iter({0}).into()"
    )]
    pattern: Object,

    /// Get the autocommands local to a specific `Buffer`. Cannot be used
    /// together with `patterns`.
    #[builder(argtype = "Buffer", inline = "{0}.into()")]
    buffer: Object,
}

/// Options passed to [`get_autocmds()`](crate::get_autocmds).
#[cfg(not(feature = "neovim-0-10"))] // 0nly on 0.9.
#[derive(Clone, Debug, Default)]
#[repr(C)]
pub struct GetAutocmdsOpts {
    events: Object,
    group: Object,
    buffer: Object,
    patterns: Object,
}

#[cfg(not(feature = "neovim-0-10"))] // 0nly on 0.9.
impl GetAutocmdsOpts {
    #[inline(always)]
    pub fn builder() -> GetAutocmdsOptsBuilder {
        GetAutocmdsOptsBuilder::default()
    }
}

#[cfg(not(feature = "neovim-0-10"))] // 0nly on 0.9.
#[derive(Clone, Default)]
pub struct GetAutocmdsOptsBuilder(GetAutocmdsOpts);

#[cfg(not(feature = "neovim-0-10"))] // 0nly on 0.9.
impl GetAutocmdsOptsBuilder {
    /// Get the autocommands local to a specific `Buffer`. Cannot be used
    /// together with `patterns`.
    #[inline]
    pub fn buffer(&mut self, buffer: Buffer) -> &mut Self {
        self.0.buffer = buffer.into();
        self
    }

    /// Get all the autocommands triggered by one or more of the specified
    /// events.
    #[inline]
    pub fn events<'a, I>(&mut self, events: I) -> &mut Self
    where
        I: IntoIterator<Item = &'a str>,
    {
        self.0.events = Array::from_iter(events).into();
        self
    }

    /// Only get the autocommands belonging to a specific augroup. The
    /// augroup can be specified by both id and name.
    #[inline]
    pub fn group<Group>(&mut self, group: Group) -> &mut Self
    where
        Group: StringOrInt,
    {
        self.0.group = group.to_object();
        self
    }

    /// Only get the autocommands that match specific patterns. For example, if
    /// you have `"*.py"` as a pattern for a particular autocommand, you must
    /// pass that exact pattern to clear it. Cannot be used together with
    /// `buffer`.
    #[inline]
    pub fn patterns<'a, I>(&mut self, patterns: I) -> &mut Self
    where
        I: IntoIterator<Item = &'a str>,
    {
        self.0.patterns = Array::from_iter(patterns).into();
        self
    }

    #[inline]
    pub fn build(&mut self) -> GetAutocmdsOpts {
        std::mem::take(&mut self.0)
    }
}