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 oxi_types::{Array, Object};
use crate::trait_utils::StringOrInt;
use crate::Buffer;
/// Options passed to [`get_autocmds()`](crate::get_autocmds).
#[cfg(feature = "neovim-nightly")]
#[derive(Clone, Debug, Default, oxi_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(any(feature = "neovim-0-8", feature = "neovim-0-9"))]
#[derive(Clone, Debug, Default)]
#[repr(C)]
pub struct GetAutocmdsOpts {
events: Object,
group: Object,
buffer: Object,
patterns: Object,
}
#[cfg(any(feature = "neovim-0-8", feature = "neovim-0-9"))]
impl GetAutocmdsOpts {
#[inline(always)]
pub fn builder() -> GetAutocmdsOptsBuilder {
GetAutocmdsOptsBuilder::default()
}
}
#[cfg(any(feature = "neovim-0-8", feature = "neovim-0-9"))]
#[derive(Clone, Default)]
pub struct GetAutocmdsOptsBuilder(GetAutocmdsOpts);
#[cfg(any(feature = "neovim-0-8", feature = "neovim-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)
}
}