1use std::any;
2
3use proc_macro2::{Ident, TokenStream};
4use quote::{format_ident, quote};
5use regex_syntax::hir::{
6 Capture, Class, ClassBytesRange, ClassUnicodeRange, Hir, HirKind, Literal, Look, Repetition,
7};
8
9use crate::codegen::{CodegenItem, Group, Groups};
10use crate::matcher::{Always as A, Or, Then};
11
12pub fn type_name<T>() -> &'static str {
13 any::type_name::<T>()
14 .split('<').next().unwrap()
15 .rsplit("::").next().unwrap()
16}
17
18pub fn type_ident<T>() -> Ident {
19 match ::quote::__private::IdentFragmentAdapter(&type_name::<T>()) {
arg =>
::quote::__private::mk_ident(&::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", arg))
}), ::quote::__private::Option::None.or(arg.span())),
}format_ident!("{}", type_name::<T>())
20}
21
22pub trait HirExtension {
23 fn into_matcher<I: CodegenItem>(self) -> (TokenStream, Vec<Group>);
24}
25
26impl HirExtension for Hir {
27 fn into_matcher<I: CodegenItem>(self) -> (TokenStream, Vec<Group>) {
28 let mut caps = Groups::new();
29 let tokens = self.into_matcher_expr::<I>(&mut caps);
30 (tokens, caps.into_vec())
31 }
32}
33
34pub trait IntoMatcherExpr {
35 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream;
36}
37
38impl IntoMatcherExpr for Hir {
39 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
40 match self.into_kind() {
41 HirKind::Empty => Empty.into_matcher_expr::<I>(caps),
42 HirKind::Literal(lit) => lit.into_matcher_expr::<I>(caps),
43 HirKind::Class(class) => class.into_matcher_expr::<I>(caps),
44 HirKind::Look(look) => look.into_matcher_expr::<I>(caps),
45 HirKind::Repetition(rep) => rep.into_matcher_expr::<I>(caps),
46 HirKind::Capture(cap) => cap.into_matcher_expr::<I>(caps),
47 HirKind::Concat(hirs) => Concat(hirs).into_matcher_expr::<I>(caps),
48 HirKind::Alternation(hirs) => Alternation(hirs).into_matcher_expr::<I>(caps),
49 }
50 }
51}
52
53#[derive(#[automatically_derived]
impl ::core::fmt::Debug for Empty {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::write_str(f, "Empty")
}
}Debug, #[automatically_derived]
impl ::core::clone::Clone for Empty {
#[inline]
fn clone(&self) -> Empty { Empty }
}Clone)]
54struct Empty;
55
56#[derive(#[automatically_derived]
impl ::core::fmt::Debug for Concat {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::debug_tuple_field1_finish(f, "Concat",
&&self.0)
}
}Debug, #[automatically_derived]
impl ::core::clone::Clone for Concat {
#[inline]
fn clone(&self) -> Concat { Concat(::core::clone::Clone::clone(&self.0)) }
}Clone)]
57struct Concat(pub Vec<Hir>);
58
59#[derive(#[automatically_derived]
impl ::core::fmt::Debug for Alternation {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::debug_tuple_field1_finish(f, "Alternation",
&&self.0)
}
}Debug, #[automatically_derived]
impl ::core::clone::Clone for Alternation {
#[inline]
fn clone(&self) -> Alternation {
Alternation(::core::clone::Clone::clone(&self.0))
}
}Clone)]
60struct Alternation(pub Vec<Hir>);
61
62impl IntoMatcherExpr for u8 {
63 fn into_matcher_expr<I: CodegenItem>(self, _caps: &mut Groups) -> TokenStream {
64 match (&type_name::<I>(), &type_name::<u8>()) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val, &*right_val,
::core::option::Option::None);
}
}
};assert_eq!(type_name::<I>(), type_name::<u8>());
65 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "Byte");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&self, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::Byte<#self>)
66 }
67}
68
69impl IntoMatcherExpr for &ClassBytesRange {
70 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
71 match (&type_name::<I>(), &type_name::<u8>()) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val, &*right_val,
::core::option::Option::None);
}
}
};assert_eq!(type_name::<I>(), type_name::<u8>());
72 if self.start() == self.end() {
73 self.start().into_matcher_expr::<I>(caps)
74 } else {
75 let start = self.start();
76 let end = self.end();
77 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ByteRange");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&start, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&end, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::ByteRange<#start, #end>)
78 }
79 }
80}
81
82impl IntoMatcherExpr for char {
83 fn into_matcher_expr<I: CodegenItem>(self, _caps: &mut Groups) -> TokenStream {
84 match (&type_name::<I>(), &type_name::<char>()) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val, &*right_val,
::core::option::Option::None);
}
}
};assert_eq!(type_name::<I>(), type_name::<char>());
85 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "Scalar");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&self, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::Scalar<#self>)
86 }
87}
88
89impl IntoMatcherExpr for &ClassUnicodeRange {
90 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
91 match (&type_name::<I>(), &type_name::<char>()) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val, &*right_val,
::core::option::Option::Some(format_args!("{0:?}", self)));
}
}
};assert_eq!(type_name::<I>(), type_name::<char>(), "{:?}", self);
92 if self.start() == self.end() {
93 self.start().into_matcher_expr::<I>(caps)
94 } else {
95 let start = self.start();
96 let end = self.end();
97 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ScalarRange");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&start, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&end, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::ScalarRange<#start, #end>)
98 }
99 }
100}
101
102impl IntoMatcherExpr for Empty {
103 fn into_matcher_expr<I: CodegenItem>(self, _caps: &mut Groups) -> TokenStream {
104 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "Always");
_s
}quote!(::ct_regex::internal::matcher::Always)
105 }
106}
107
108impl IntoMatcherExpr for Literal {
109 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
110 write_chunked::<Then<u8, A, A>, I, _>(
111 caps,
112 I::collect_from_bytes(&self.0)
113 )
114 }
115}
116
117impl IntoMatcherExpr for Class {
118 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
119 match I::normalize_class(self) {
120 Class::Unicode(unicode) => write_chunked::<Or<u8, A, A>, I, _>(
121 caps,
122 unicode.ranges().iter().collect()
123 ),
124 Class::Bytes(bytes) => write_chunked::<Or<u8, A, A>, I, _>(
125 caps,
126 bytes.ranges().iter().collect()
127 ),
128 }
129 }
130}
131
132impl IntoMatcherExpr for Look {
133 fn into_matcher_expr<I: CodegenItem>(self, _caps: &mut Groups) -> TokenStream {
134 match self {
135 Look::Start => {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "Start");
_s
}quote!(::ct_regex::internal::matcher::Start),
136 Look::End => {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "End");
_s
}quote!(::ct_regex::internal::matcher::End),
137 Look::StartLF => {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "LineStart");
_s
}quote!(::ct_regex::internal::matcher::LineStart),
138 Look::EndLF => {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "LineEnd");
_s
}quote!(::ct_regex::internal::matcher::LineEnd),
139 Look::StartCRLF => {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "CRLFStart");
_s
}quote!(::ct_regex::internal::matcher::CRLFStart),
140 Look::EndCRLF => {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "CRLFEnd");
_s
}quote!(::ct_regex::internal::matcher::CRLFEnd),
141 _ => {
::core::panicking::panic_fmt(format_args!("not implemented: {0}",
format_args!("complex look arounds")));
}unimplemented!("complex look arounds"),
142 }
143 }
144}
145
146impl IntoMatcherExpr for Repetition {
147 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
148 let Repetition { min, max, greedy, sub } = self;
149
150 let required = caps.required;
151 if min == 0 {
152 caps.required = false;
153 }
154
155 let item_type = type_ident::<I>();
156 let sub_matcher = sub.into_matcher_expr::<I>(caps);
157 let (min, max) = (min as usize, max.map(|m| m as usize));
161
162 if min == 0 {
163 caps.required = required;
164 }
165
166 let tokens = match max {
167 None => {
168 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "QuantifierNOrMore");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&sub_matcher, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&min, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::QuantifierNOrMore<#item_type, #sub_matcher, #min>)
169 },
170 Some(max) if min == max => {
171 return {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "QuantifierN");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&sub_matcher, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&min, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::QuantifierN<#item_type, #sub_matcher, #min>);
172 },
173 Some(max) => {
174 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "QuantifierNToM");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&sub_matcher, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&min, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&max, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::QuantifierNToM<#item_type, #sub_matcher, #min, #max>)
175 },
176 };
177
178 if greedy {
179 tokens
180 } else {
181 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "Lazy");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&tokens, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::Lazy<#item_type, #tokens>)
182 }
183 }
184}
185
186impl IntoMatcherExpr for Capture {
187 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
188 caps.insert(self.index, self.name);
189 let item_type = type_ident::<I>();
190 let sub_matcher = self.sub.into_matcher_expr::<I>(caps);
191 let index = self.index as usize;
192
193 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "CaptureGroup");
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&sub_matcher, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&index, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::CaptureGroup<#item_type, #sub_matcher, #index>)
194 }
195}
196
197impl IntoMatcherExpr for Alternation {
198 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
199 let required = caps.required;
200 caps.required = false;
201 let tokens = write_chunked::<Or<u8, A, A>, I, _>(caps, self.0);
202 caps.required = required;
203 tokens
204 }
205}
206
207impl IntoMatcherExpr for Concat {
208 fn into_matcher_expr<I: CodegenItem>(self, caps: &mut Groups) -> TokenStream {
209 write_chunked::<Then<u8, A, A>, I, _>(caps, self.0)
210 }
211}
212
213fn write_chunked<T, I: CodegenItem, W: IntoMatcherExpr>(
214 caps: &mut Groups,
215 mut items: Vec<W>,
216) -> TokenStream {
217 let n = items.len();
218 let base = match ::quote::__private::IdentFragmentAdapter(&type_name::<T>()) {
arg =>
::quote::__private::mk_ident(&::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", arg))
}), ::quote::__private::Option::None.or(arg.span())),
}format_ident!("{}", type_name::<T>());
219 let item_type = type_ident::<I>();
220
221 match n {
222 0 => { ::core::panicking::panic_fmt(format_args!("literal contains no items")); }panic!("literal contains no items"),
223 1 => items.pop().unwrap().into_matcher_expr::<I>(caps),
224 2 => {
225 let mut iter = items.into_iter();
226 let first = iter.next().unwrap().into_matcher_expr::<I>(caps);
227 let second = iter.next().unwrap().into_matcher_expr::<I>(caps);
228
229 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::ToTokens::to_tokens(&base, &mut _s);
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&first, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&second, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::#base<#item_type, #first, #second>)
230 },
231 3 => {
232 let mut iter = items.into_iter();
233 let first = iter.next().unwrap().into_matcher_expr::<I>(caps);
234 let chunked = write_chunked::<T, I, W>(caps, iter.collect());
235
236 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::ToTokens::to_tokens(&base, &mut _s);
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&first, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&chunked, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::#base<#item_type, #first, #chunked>)
237 },
238 4 | 8 | 16 => write_n_items::<T, I, W>(caps, items, n),
239 _ => {
240 let chunk_size = if n > 16 {
242 16
243 } else if n > 8 {
244 8
245 } else {
246 4
247 };
248 let remainder = items.split_off(chunk_size);
249 let n_matcher = write_n_items::<T, I, W>(caps, items, chunk_size);
250 let chunked = write_chunked::<T, I, W>(caps, remainder);
251
252 {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::ToTokens::to_tokens(&base, &mut _s);
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&n_matcher, &mut _s);
::quote::__private::push_comma(&mut _s);
::quote::ToTokens::to_tokens(&chunked, &mut _s);
::quote::__private::push_gt(&mut _s);
_s
}quote!(::ct_regex::internal::matcher::#base<#item_type, #n_matcher, #chunked>)
253 },
254 }
255}
256
257fn write_n_items<T, I: CodegenItem, W: IntoMatcherExpr>(
258 caps: &mut Groups,
259 items: Vec<W>,
260 n: usize,
261) -> TokenStream {
262 let name = match ::quote::__private::IdentFragmentAdapter(&type_name::<T>()) {
arg =>
match ::quote::__private::IdentFragmentAdapter(&n) {
arg =>
::quote::__private::mk_ident(&::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}{1}", arg, arg))
}),
::quote::__private::Option::None.or(arg.span()).or(arg.span())),
},
}format_ident!("{}{}", type_name::<T>(), n);
263 let item_type = type_ident::<I>();
264
265 let mut tokens = {
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "ct_regex");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "internal");
::quote::__private::push_colon2(&mut _s);
::quote::__private::push_ident(&mut _s, "matcher");
::quote::__private::push_colon2(&mut _s);
::quote::ToTokens::to_tokens(&name, &mut _s);
::quote::__private::push_lt(&mut _s);
::quote::ToTokens::to_tokens(&item_type, &mut _s);
_s
}quote!(::ct_regex::internal::matcher::#name<#item_type);
266
267 for item in items {
268 tokens.extend({
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_comma(&mut _s);
_s
}quote!(,));
269 tokens.extend(item.into_matcher_expr::<I>(caps));
270 }
271
272 tokens.extend({
let mut _s = ::quote::__private::TokenStream::new();
::quote::__private::push_gt(&mut _s);
_s
}quote!(>));
273 tokens
274}