summaryrefslogtreecommitdiff
path: root/serde_v8/magic/external_pointer.rs
diff options
context:
space:
mode:
authorAapo Alasuutari <aapo.alasuutari@gmail.com>2023-02-22 19:32:38 +0200
committerGitHub <noreply@github.com>2023-02-22 19:32:38 +0200
commitb56b8c8a753442036ace3bb0f4403c952f18d408 (patch)
tree675c47da4847a754cf2cc3cb664dc8047944246d /serde_v8/magic/external_pointer.rs
parent2bd7482295daae4edfd367d84505bb43735cd410 (diff)
feat(ext/ffi): Replace pointer integers with v8::External objects (#16889)
Diffstat (limited to 'serde_v8/magic/external_pointer.rs')
-rw-r--r--serde_v8/magic/external_pointer.rs56
1 files changed, 56 insertions, 0 deletions
diff --git a/serde_v8/magic/external_pointer.rs b/serde_v8/magic/external_pointer.rs
new file mode 100644
index 000000000..fca6028d6
--- /dev/null
+++ b/serde_v8/magic/external_pointer.rs
@@ -0,0 +1,56 @@
+// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
+
+use std::ffi::c_void;
+
+use super::transl8::impl_magic;
+use super::transl8::FromV8;
+use super::transl8::ToV8;
+
+pub struct ExternalPointer(*mut c_void);
+
+// SAFETY: Nonblocking FFI is user controller and we must trust user to have it right.
+unsafe impl Send for ExternalPointer {}
+// SAFETY: Nonblocking FFI is user controller and we must trust user to have it right.
+unsafe impl Sync for ExternalPointer {}
+
+impl_magic!(ExternalPointer);
+
+impl ToV8 for ExternalPointer {
+ fn to_v8<'a>(
+ &mut self,
+ scope: &mut v8::HandleScope<'a>,
+ ) -> Result<v8::Local<'a, v8::Value>, crate::Error> {
+ if self.0.is_null() {
+ Ok(v8::null(scope).into())
+ } else {
+ Ok(v8::External::new(scope, self.0).into())
+ }
+ }
+}
+
+impl FromV8 for ExternalPointer {
+ fn from_v8(
+ _scope: &mut v8::HandleScope,
+ value: v8::Local<v8::Value>,
+ ) -> Result<Self, crate::Error> {
+ if value.is_null() {
+ Ok(ExternalPointer(std::ptr::null_mut()))
+ } else if let Ok(external) = v8::Local::<v8::External>::try_from(value) {
+ Ok(ExternalPointer(external.value()))
+ } else {
+ Err(crate::Error::ExpectedExternal)
+ }
+ }
+}
+
+impl From<*mut c_void> for ExternalPointer {
+ fn from(value: *mut c_void) -> Self {
+ ExternalPointer(value)
+ }
+}
+
+impl From<*const c_void> for ExternalPointer {
+ fn from(value: *const c_void) -> Self {
+ ExternalPointer(value as *mut c_void)
+ }
+}