diff options
author | Aaron O'Mullan <aaron.omullan@gmail.com> | 2022-03-24 11:23:40 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-03-24 11:23:40 +0100 |
commit | 6516130b0138ef382a0588f983287fb463222086 (patch) | |
tree | f250150295fb4d7a023c1fa7d92da621ac804340 /serde_v8/magic/value.rs | |
parent | c52d72e8e115f30be32cbb2a91a4c3aa117c328c (diff) |
chore: drop src/ in bench_util & serde_v8 (#14097)
To align with conventions used in our other crates
Diffstat (limited to 'serde_v8/magic/value.rs')
-rw-r--r-- | serde_v8/magic/value.rs | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/serde_v8/magic/value.rs b/serde_v8/magic/value.rs new file mode 100644 index 000000000..5d844fbda --- /dev/null +++ b/serde_v8/magic/value.rs @@ -0,0 +1,48 @@ +// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license. + +use crate::magic::transl8::impl_magic; +use crate::magic::transl8::FromV8; +use crate::magic::transl8::ToV8; +use std::mem::transmute; + +/// serde_v8::Value allows passing through `v8::Value`s untouched +/// when de/serializing & allows mixing rust & v8 values in structs, tuples... +// +// SAFETY: caveat emptor, the rust-compiler can no longer link lifetimes to their +// original scope, you must take special care in ensuring your handles don't outlive their scope +pub struct Value<'s> { + pub v8_value: v8::Local<'s, v8::Value>, +} +impl_magic!(Value<'_>); + +impl<'s> From<v8::Local<'s, v8::Value>> for Value<'s> { + fn from(v8_value: v8::Local<'s, v8::Value>) -> Self { + Self { v8_value } + } +} + +impl<'s> From<Value<'s>> for v8::Local<'s, v8::Value> { + fn from(v: Value<'s>) -> Self { + v.v8_value + } +} + +impl ToV8 for Value<'_> { + fn to_v8<'a>( + &self, + _scope: &mut v8::HandleScope<'a>, + ) -> Result<v8::Local<'a, v8::Value>, crate::Error> { + // SAFETY: not fully safe, since lifetimes are detached from original scope + Ok(unsafe { transmute(self.v8_value) }) + } +} + +impl FromV8 for Value<'_> { + fn from_v8( + _scope: &mut v8::HandleScope, + value: v8::Local<v8::Value>, + ) -> Result<Self, crate::Error> { + // SAFETY: not fully safe, since lifetimes are detached from original scope + Ok(unsafe { transmute::<Value, Value>(value.into()) }) + } +} |