From 5e1b9f83032c1bc7725b9e6e6f17d1f479680002 Mon Sep 17 00:00:00 2001 From: "K.J. Valencik" Date: Wed, 28 Aug 2024 08:57:00 -0400 Subject: [PATCH 1/2] change(neon): Change TryIntoJs and TryFromJs accept Cx instead of being generic over Context Being generic over `Context` offers no benefits over `Cx`. It is simpler to remove a generic argument. * Every `Context` derefs to `Cx` * `Cx` implements `Context` * Reduces code bloat from monomorphization --- crates/neon/src/macro_internal/mod.rs | 25 ++--- crates/neon/src/types_impl/extract/error.rs | 7 +- crates/neon/src/types_impl/extract/json.rs | 60 +++-------- crates/neon/src/types_impl/extract/mod.rs | 17 ++- .../src/types_impl/extract/try_from_js.rs | 101 ++++++++---------- .../src/types_impl/extract/try_into_js.rs | 72 +++---------- crates/neon/src/types_impl/extract/with.rs | 13 +-- 7 files changed, 92 insertions(+), 203 deletions(-) diff --git a/crates/neon/src/macro_internal/mod.rs b/crates/neon/src/macro_internal/mod.rs index 1cb6e0b3a..bc4b1ecdb 100644 --- a/crates/neon/src/macro_internal/mod.rs +++ b/crates/neon/src/macro_internal/mod.rs @@ -3,7 +3,7 @@ pub use linkme; use crate::{ - context::{Context, ModuleContext}, + context::{Cx, ModuleContext}, handle::Handle, result::{JsResult, NeonResult}, types::{extract::TryIntoJs, JsValue}, @@ -19,19 +19,14 @@ pub static MAIN: [for<'cx> fn(ModuleContext<'cx>) -> NeonResult<()>]; // Provides an identically named method to `NeonExportReturnJson` for easy swapping in macros pub trait NeonExportReturnValue<'cx> { - fn try_neon_export_return(self, cx: &mut C) -> JsResult<'cx, JsValue> - where - C: Context<'cx>; + fn try_neon_export_return(self, cx: &mut Cx<'cx>) -> JsResult<'cx, JsValue>; } impl<'cx, T> NeonExportReturnValue<'cx> for T where T: TryIntoJs<'cx>, { - fn try_neon_export_return(self, cx: &mut C) -> JsResult<'cx, JsValue> - where - C: Context<'cx>, - { + fn try_neon_export_return(self, cx: &mut Cx<'cx>) -> JsResult<'cx, JsValue> { self.try_into_js(cx).map(|v| v.upcast()) } } @@ -40,9 +35,7 @@ where // Trait used for specializing `Json` wrapping of `T` or `Result` in macros // Leverages the [autoref specialization](https://github.com/dtolnay/case-studies/blob/master/autoref-specialization/README.md) technique pub trait NeonExportReturnJson<'cx> { - fn try_neon_export_return(self, cx: &mut C) -> JsResult<'cx, JsValue> - where - C: Context<'cx>; + fn try_neon_export_return(self, cx: &mut Cx<'cx>) -> JsResult<'cx, JsValue>; } #[cfg(feature = "serde")] @@ -52,10 +45,7 @@ where T: serde::Serialize, E: TryIntoJs<'cx>, { - fn try_neon_export_return(self, cx: &mut C) -> JsResult<'cx, JsValue> - where - C: Context<'cx>, - { + fn try_neon_export_return(self, cx: &mut Cx<'cx>) -> JsResult<'cx, JsValue> { self.map(crate::types::extract::Json).try_into_js(cx) } } @@ -66,10 +56,7 @@ impl<'cx, T> NeonExportReturnJson<'cx> for &T where T: serde::Serialize, { - fn try_neon_export_return(self, cx: &mut C) -> JsResult<'cx, JsValue> - where - C: Context<'cx>, - { + fn try_neon_export_return(self, cx: &mut Cx<'cx>) -> JsResult<'cx, JsValue> { crate::types::extract::Json(self).try_into_js(cx) } } diff --git a/crates/neon/src/types_impl/extract/error.rs b/crates/neon/src/types_impl/extract/error.rs index 51b1c2105..609692a8a 100644 --- a/crates/neon/src/types_impl/extract/error.rs +++ b/crates/neon/src/types_impl/extract/error.rs @@ -1,7 +1,7 @@ use std::{error, fmt}; use crate::{ - context::Context, + context::{Context, Cx}, result::JsResult, types::{extract::TryIntoJs, JsError}, }; @@ -114,10 +114,7 @@ impl fmt::Display for Error { impl<'cx> TryIntoJs<'cx> for Error { type Value = JsError; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { let message = self.cause.to_string(); match self.kind { diff --git a/crates/neon/src/types_impl/extract/json.rs b/crates/neon/src/types_impl/extract/json.rs index e99628a1d..0dc8930af 100644 --- a/crates/neon/src/types_impl/extract/json.rs +++ b/crates/neon/src/types_impl/extract/json.rs @@ -1,5 +1,5 @@ use crate::{ - context::Context, + context::{Context, Cx}, handle::Handle, object::Object, result::{JsResult, NeonResult}, @@ -12,10 +12,7 @@ use crate::{ #[cfg(feature = "napi-6")] use crate::{handle::Root, thread::LocalKey}; -fn global_json_stringify<'cx, C>(cx: &mut C) -> JsResult<'cx, JsFunction> -where - C: Context<'cx>, -{ +fn global_json_stringify<'cx>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { cx.global::("JSON")?.get(cx, "stringify") } @@ -24,18 +21,12 @@ where // method could cause differences between calls. However, threading a `Root` through // would require a significant refactor and "don't do this or things will break" is // fairly common in JS. -fn json_stringify<'cx, C>(cx: &mut C) -> JsResult<'cx, JsFunction> -where - C: Context<'cx>, -{ +fn json_stringify<'cx, C>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { global_json_stringify(cx) } #[cfg(feature = "napi-6")] -fn json_stringify<'cx, C>(cx: &mut C) -> JsResult<'cx, JsFunction> -where - C: Context<'cx>, -{ +fn json_stringify<'cx>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { static STRINGIFY: LocalKey> = LocalKey::new(); STRINGIFY @@ -43,36 +34,24 @@ where .map(|f| f.to_inner(cx)) } -fn stringify<'cx, C>(cx: &mut C, v: Handle) -> NeonResult -where - C: Context<'cx>, -{ +fn stringify<'cx>(cx: &mut Cx<'cx>, v: Handle) -> NeonResult { json_stringify(cx)? .call(cx, v, [v])? .downcast_or_throw::(cx) .map(|s| s.value(cx)) } -fn global_json_parse<'cx, C>(cx: &mut C) -> JsResult<'cx, JsFunction> -where - C: Context<'cx>, -{ +fn global_json_parse<'cx>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { cx.global::("JSON")?.get(cx, "parse") } #[cfg(not(feature = "napi-6"))] -fn json_parse<'cx, C>(cx: &mut C) -> JsResult<'cx, JsFunction> -where - C: Context<'cx>, -{ +fn json_parse<'cx>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { global_json_parse(cx) } #[cfg(feature = "napi-6")] -fn json_parse<'cx, C>(cx: &mut C) -> JsResult<'cx, JsFunction> -where - C: Context<'cx>, -{ +fn json_parse<'cx>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { static PARSE: LocalKey> = LocalKey::new(); PARSE @@ -80,10 +59,7 @@ where .map(|f| f.to_inner(cx)) } -fn parse<'cx, C>(cx: &mut C, s: &str) -> JsResult<'cx, JsValue> -where - C: Context<'cx>, -{ +fn parse<'cx>(cx: &mut Cx<'cx>, s: &str) -> JsResult<'cx, JsValue> { let s = cx.string(s).upcast(); json_parse(cx)?.call(cx, s, [s]) @@ -99,17 +75,14 @@ where { type Error = serde_json::Error; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { Ok(serde_json::from_str(&stringify(cx, v)?).map(Json)) } - fn from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult - where - C: Context<'cx>, - { + fn from_js(cx: &mut Cx<'cx>, v: Handle<'cx, JsValue>) -> NeonResult { Self::try_from_js(cx, v)?.or_else(|err| cx.throw_error(err.to_string())) } } @@ -120,10 +93,7 @@ where { type Value = JsValue; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { let s = serde_json::to_string(&self.0).or_else(|err| cx.throw_error(err.to_string()))?; parse(cx, &s) diff --git a/crates/neon/src/types_impl/extract/mod.rs b/crates/neon/src/types_impl/extract/mod.rs index 997fd9c9c..3e2815ce9 100644 --- a/crates/neon/src/types_impl/extract/mod.rs +++ b/crates/neon/src/types_impl/extract/mod.rs @@ -102,7 +102,7 @@ use std::{fmt, marker::PhantomData}; use crate::{ - context::{Context, FunctionContext}, + context::{Context, Cx, FunctionContext}, handle::Handle, result::{JsResult, NeonResult, ResultExt}, types::{JsValue, Value}, @@ -133,14 +133,13 @@ where type Error; /// Extract this Rust type from a JavaScript value - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>; + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult>; /// Same as [`TryFromJs`], but all errors are converted to JavaScript exceptions - fn from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult - where - C: Context<'cx>; + fn from_js(cx: &mut Cx<'cx>, v: Handle<'cx, JsValue>) -> NeonResult; } /// Convert Rust data into a JavaScript value @@ -152,9 +151,7 @@ where type Value: Value; /// Convert `self` into a JavaScript value - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>; + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value>; } #[cfg_attr(docsrs, doc(cfg(feature = "napi-5")))] diff --git a/crates/neon/src/types_impl/extract/try_from_js.rs b/crates/neon/src/types_impl/extract/try_from_js.rs index c2c133095..d7357b224 100644 --- a/crates/neon/src/types_impl/extract/try_from_js.rs +++ b/crates/neon/src/types_impl/extract/try_from_js.rs @@ -6,7 +6,7 @@ use std::{convert::Infallible, ptr}; use crate::{ - context::Context, + context::{internal::ContextInternal, Cx}, handle::Handle, result::{NeonResult, ResultExt, Throw}, sys, @@ -23,10 +23,7 @@ use crate::types::JsDate; macro_rules! from_js { () => { - fn from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult - where - C: Context<'cx>, - { + fn from_js(cx: &mut Cx<'cx>, v: Handle<'cx, JsValue>) -> NeonResult { Self::try_from_js(cx, v)?.or_throw(cx) } }; @@ -38,10 +35,10 @@ where { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { Ok(v.downcast(cx).map_err(|_| TypeExpected::new())) } @@ -54,10 +51,10 @@ where { type Error = T::Error; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { if is_null_or_undefined(cx, v)? { return Ok(Ok(None)); } @@ -65,10 +62,7 @@ where T::try_from_js(cx, v).map(|v| v.map(Some)) } - fn from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult - where - C: Context<'cx>, - { + fn from_js(cx: &mut Cx<'cx>, v: Handle<'cx, JsValue>) -> NeonResult { if is_null_or_undefined(cx, v)? { return Ok(None); } @@ -80,10 +74,10 @@ where impl<'cx> TryFromJs<'cx> for f64 { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let mut n = 0f64; unsafe { @@ -103,10 +97,10 @@ impl<'cx> TryFromJs<'cx> for f64 { impl<'cx> TryFromJs<'cx> for bool { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let mut b = false; unsafe { @@ -126,10 +120,10 @@ impl<'cx> TryFromJs<'cx> for bool { impl<'cx> TryFromJs<'cx> for String { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let env = cx.env().to_raw(); let v = v.to_local(); let mut len = 0usize; @@ -173,10 +167,10 @@ impl<'cx> TryFromJs<'cx> for String { impl<'cx> TryFromJs<'cx> for Date { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let mut d = 0f64; unsafe { @@ -206,20 +200,14 @@ impl<'cx> TryFromJs<'cx> for Date { impl<'cx> TryFromJs<'cx> for () { type Error = Infallible; - fn try_from_js( - _cx: &mut C, + fn try_from_js( + _cx: &mut Cx<'cx>, _v: Handle<'cx, JsValue>, - ) -> NeonResult> - where - C: Context<'cx>, - { + ) -> NeonResult> { Ok(Ok(())) } - fn from_js(_cx: &mut C, _v: Handle<'cx, JsValue>) -> NeonResult - where - C: Context<'cx>, - { + fn from_js(_cx: &mut Cx<'cx>, _v: Handle<'cx, JsValue>) -> NeonResult { Ok(()) } } @@ -231,10 +219,10 @@ where { type Error = TypeExpected>; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let v = match v.downcast::, _>(cx) { Ok(v) => v, Err(_) => return Ok(Err(Self::Error::new())), @@ -249,10 +237,10 @@ where impl<'cx> TryFromJs<'cx> for Buffer { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let v = match v.downcast::(cx) { Ok(v) => v, Err(_) => return Ok(Err(Self::Error::new())), @@ -267,10 +255,10 @@ impl<'cx> TryFromJs<'cx> for Buffer { impl<'cx> TryFromJs<'cx> for ArrayBuffer { type Error = TypeExpected; - fn try_from_js(cx: &mut C, v: Handle<'cx, JsValue>) -> NeonResult> - where - C: Context<'cx>, - { + fn try_from_js( + cx: &mut Cx<'cx>, + v: Handle<'cx, JsValue>, + ) -> NeonResult> { let v = match v.downcast::(cx) { Ok(v) => v, Err(_) => return Ok(Err(Self::Error::new())), @@ -282,9 +270,8 @@ impl<'cx> TryFromJs<'cx> for ArrayBuffer { from_js!(); } -fn is_null_or_undefined<'cx, C, V>(cx: &mut C, v: Handle) -> NeonResult +fn is_null_or_undefined<'cx, V>(cx: &mut Cx<'cx>, v: Handle) -> NeonResult where - C: Context<'cx>, V: Value, { let mut ty = sys::ValueType::Object; diff --git a/crates/neon/src/types_impl/extract/try_into_js.rs b/crates/neon/src/types_impl/extract/try_into_js.rs index cd783352c..126f9fde7 100644 --- a/crates/neon/src/types_impl/extract/try_into_js.rs +++ b/crates/neon/src/types_impl/extract/try_into_js.rs @@ -1,5 +1,5 @@ use crate::{ - context::Context, + context::{Context, Cx}, handle::Handle, result::{JsResult, ResultExt, Throw}, types::{ @@ -16,10 +16,7 @@ where { type Value = T; - fn try_into_js(self, _cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, _cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Ok(self) } } @@ -31,10 +28,7 @@ where { type Value = T::Value; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { match self { Ok(v) => v.try_into_js(cx), Err(err) => { @@ -49,10 +43,7 @@ where impl<'cx> TryIntoJs<'cx> for Throw { type Value = JsValue; - fn try_into_js(self, _cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, _cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Err(self) } } @@ -63,10 +54,7 @@ where { type Value = JsValue; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { if let Some(val) = self { val.try_into_js(cx).map(|v| v.upcast()) } else { @@ -80,10 +68,7 @@ macro_rules! impl_number { impl<'cx> TryIntoJs<'cx> for $ty { type Value = JsNumber; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Ok(cx.number(self)) } } @@ -101,10 +86,7 @@ impl_number!(u8, u16, u32, i8, i16, i32, f32, f64); impl<'cx> TryIntoJs<'cx> for String { type Value = JsString; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Ok(cx.string(self)) } } @@ -112,10 +94,7 @@ impl<'cx> TryIntoJs<'cx> for String { impl<'cx> TryIntoJs<'cx> for &'cx str { type Value = JsString; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Ok(cx.string(self)) } } @@ -127,10 +106,7 @@ where { type Value = JsTypedArray; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { JsTypedArray::from_slice(cx, &self) } } @@ -142,10 +118,7 @@ where { type Value = JsTypedArray; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { JsTypedArray::from_slice(cx, self) } } @@ -153,10 +126,7 @@ where impl<'cx> TryIntoJs<'cx> for bool { type Value = JsBoolean; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Ok(cx.boolean(self)) } } @@ -164,10 +134,7 @@ impl<'cx> TryIntoJs<'cx> for bool { impl<'cx> TryIntoJs<'cx> for () { type Value = JsUndefined; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { Ok(cx.undefined()) } } @@ -175,10 +142,7 @@ impl<'cx> TryIntoJs<'cx> for () { impl<'cx> TryIntoJs<'cx> for ArrayBuffer { type Value = JsArrayBuffer; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { JsArrayBuffer::from_slice(cx, &self.0) } } @@ -186,10 +150,7 @@ impl<'cx> TryIntoJs<'cx> for ArrayBuffer { impl<'cx> TryIntoJs<'cx> for Buffer { type Value = JsBuffer; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { JsBuffer::from_slice(cx, &self.0) } } @@ -197,10 +158,7 @@ impl<'cx> TryIntoJs<'cx> for Buffer { impl<'cx> TryIntoJs<'cx> for Date { type Value = JsDate; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { cx.date(self.0).or_throw(cx) } } diff --git a/crates/neon/src/types_impl/extract/with.rs b/crates/neon/src/types_impl/extract/with.rs index 01caba986..0f631fe8a 100644 --- a/crates/neon/src/types_impl/extract/with.rs +++ b/crates/neon/src/types_impl/extract/with.rs @@ -1,8 +1,4 @@ -use crate::{ - context::{Context, Cx}, - result::JsResult, - types::extract::TryIntoJs, -}; +use crate::{context::Cx, result::JsResult, types::extract::TryIntoJs}; /// Wraps a closure that will be lazily evaluated when [`TryIntoJs::try_into_js`] is /// called. @@ -47,11 +43,8 @@ where { type Value = O::Value; - fn try_into_js(self, cx: &mut C) -> JsResult<'cx, Self::Value> - where - C: Context<'cx>, - { - (self.0)(cx.cx_mut()).try_into_js(cx) + fn try_into_js(self, cx: &mut Cx<'cx>) -> JsResult<'cx, Self::Value> { + (self.0)(cx).try_into_js(cx) } } From 88581a08098c76bb003ab9d5a2432fa3908f97db Mon Sep 17 00:00:00 2001 From: "K.J. Valencik" Date: Tue, 3 Sep 2024 13:58:18 -0400 Subject: [PATCH 2/2] chore(neon): Convert examples to use Cx --- crates/neon/src/context/mod.rs | 2 +- crates/neon/src/thread/mod.rs | 2 +- crates/neon/src/types_impl/promise.rs | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/crates/neon/src/context/mod.rs b/crates/neon/src/context/mod.rs index 7bad93f4e..98b9b8bf5 100644 --- a/crates/neon/src/context/mod.rs +++ b/crates/neon/src/context/mod.rs @@ -500,7 +500,7 @@ pub trait Context<'a>: ContextInternal<'a> { /// /// ``` /// # use neon::prelude::*; - /// # fn get_array_global<'cx, C: Context<'cx>>(cx: &mut C) -> JsResult<'cx, JsFunction> { + /// # fn get_array_global<'cx>(cx: &mut Cx<'cx>) -> JsResult<'cx, JsFunction> { /// # let name = "Array"; /// # let v: Handle = /// { diff --git a/crates/neon/src/thread/mod.rs b/crates/neon/src/thread/mod.rs index 96b4adfaf..f4d7ad1e3 100644 --- a/crates/neon/src/thread/mod.rs +++ b/crates/neon/src/thread/mod.rs @@ -13,7 +13,7 @@ //! # use neon::thread::LocalKey; //! static THREAD_ID: LocalKey = LocalKey::new(); //! -//! pub fn thread_id<'cx, C: Context<'cx>>(cx: &mut C) -> NeonResult { +//! pub fn thread_id(cx: &mut Cx) -> NeonResult { //! THREAD_ID.get_or_try_init(cx, |cx| { //! let require: Handle = cx.global("require")?; //! let worker: Handle = require.call_with(cx) diff --git a/crates/neon/src/types_impl/promise.rs b/crates/neon/src/types_impl/promise.rs index 0f817854a..1d79735e5 100644 --- a/crates/neon/src/types_impl/promise.rs +++ b/crates/neon/src/types_impl/promise.rs @@ -453,7 +453,7 @@ impl Drop for Deferred { /// use tokio::runtime::Runtime; /// /// // Lazily allocate a Tokio runtime to use as the thread pool. -/// fn runtime<'a, C: Context<'a>>(cx: &mut C) -> NeonResult<&'static Runtime> { +/// fn runtime(cx: &mut Cx) -> NeonResult<&'static Runtime> { /// static RUNTIME: OnceCell = OnceCell::new(); /// /// RUNTIME