1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-22 06:09:25 -05:00

perf(ops): inline String args (#15681)

This commit is contained in:
Divy Srivastava 2022-08-30 14:31:14 +05:30 committed by GitHub
parent 5e0fa5dd88
commit 448654764f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -592,14 +592,34 @@ fn codegen_arg(
idx: usize, idx: usize,
) -> TokenStream2 { ) -> TokenStream2 {
let ident = quote::format_ident!("{name}"); let ident = quote::format_ident!("{name}");
let pat = match arg { let (pat, ty) = match arg {
syn::FnArg::Typed(pat) => &pat.pat, syn::FnArg::Typed(pat) => (&pat.pat, &pat.ty),
_ => unreachable!(), _ => unreachable!(),
}; };
// Fast path if arg should be skipped // Fast path if arg should be skipped
if matches!(**pat, syn::Pat::Wild(_)) { if matches!(**pat, syn::Pat::Wild(_)) {
return quote! { let #ident = (); }; return quote! { let #ident = (); };
} }
// Fast path for `String`
if is_string(&**ty) {
return quote! {
let #ident = match #core::v8::Local::<#core::v8::String>::try_from(args.get(#idx as i32)) {
Ok(v8_string) => #core::serde_v8::to_utf8(v8_string, scope),
Err(_) => {
return #core::_ops::throw_type_error(scope, format!("Expected string at position {}", #idx));
}
};
};
}
// Fast path for `Option<String>`
if is_option_string(&**ty) {
return quote! {
let #ident = match #core::v8::Local::<#core::v8::String>::try_from(args.get(#idx as i32)) {
Ok(v8_string) => Some(#core::serde_v8::to_utf8(v8_string, scope)),
Err(_) => None
};
};
}
// Otherwise deserialize it via serde_v8 // Otherwise deserialize it via serde_v8
quote! { quote! {
let #ident = args.get(#idx as i32); let #ident = args.get(#idx as i32);
@ -680,6 +700,14 @@ fn is_result(ty: impl ToTokens) -> bool {
} }
} }
fn is_string(ty: impl ToTokens) -> bool {
tokens(ty) == "String"
}
fn is_option_string(ty: impl ToTokens) -> bool {
tokens(ty) == "Option < String >"
}
/// Detects if the type can be set using `rv.set_uint32` fast path /// Detects if the type can be set using `rv.set_uint32` fast path
fn is_u32_rv(ty: impl ToTokens) -> bool { fn is_u32_rv(ty: impl ToTokens) -> bool {
["u32", "u8", "u16"].iter().any(|&s| tokens(&ty) == s) || is_resource_id(&ty) ["u32", "u8", "u16"].iter().any(|&s| tokens(&ty) == s) || is_resource_id(&ty)