0
0
Fork 0
mirror of https://github.com/denoland/rusty_v8.git synced 2024-11-30 16:41:03 -05:00

Remove the 'Delete' trait, use regular 'Drop' instead (#353)

This commit is contained in:
Bert Belder 2020-04-16 03:59:08 +02:00
parent 256b6710d0
commit b85346047e
No known key found for this signature in database
GPG key ID: 7A77887B2E2ED461
6 changed files with 73 additions and 104 deletions

View file

@ -7,7 +7,6 @@ use std::ptr::null_mut;
use std::slice; use std::slice;
use crate::support::long; use crate::support::long;
use crate::support::Delete;
use crate::support::Opaque; use crate::support::Opaque;
use crate::support::Shared; use crate::support::Shared;
use crate::support::SharedRef; use crate::support::SharedRef;
@ -137,8 +136,8 @@ fn test_default_allocator() {
new_default_allocator(); new_default_allocator();
} }
impl Delete for Allocator { impl Drop for Allocator {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8__ArrayBuffer__Allocator__DELETE(self) }; unsafe { v8__ArrayBuffer__Allocator__DELETE(self) };
} }
} }
@ -212,8 +211,8 @@ impl DerefMut for BackingStore {
} }
} }
impl Delete for BackingStore { impl Drop for BackingStore {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8__BackingStore__DELETE(self) }; unsafe { v8__BackingStore__DELETE(self) };
} }
} }

View file

@ -16,7 +16,6 @@
use crate::scope_traits::InIsolate; use crate::scope_traits::InIsolate;
use crate::support::int; use crate::support::int;
use crate::support::CxxVTable; use crate::support::CxxVTable;
use crate::support::Delete;
use crate::support::FieldOffset; use crate::support::FieldOffset;
use crate::support::Opaque; use crate::support::Opaque;
use crate::support::RustVTable; use crate::support::RustVTable;
@ -583,8 +582,8 @@ impl V8InspectorSession {
} }
} }
impl Delete for V8InspectorSession { impl Drop for V8InspectorSession {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8_inspector__V8InspectorSession__DELETE(self) }; unsafe { v8_inspector__V8InspectorSession__DELETE(self) };
} }
} }
@ -615,8 +614,8 @@ impl StringBuffer {
} }
} }
impl Delete for StringBuffer { impl Drop for StringBuffer {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8_inspector__StringBuffer__DELETE(self) } unsafe { v8_inspector__StringBuffer__DELETE(self) }
} }
} }
@ -891,8 +890,8 @@ impl V8Inspector {
} }
} }
impl Delete for V8Inspector { impl Drop for V8Inspector {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8_inspector__V8Inspector__DELETE(self) }; unsafe { v8_inspector__V8Inspector__DELETE(self) };
} }
} }

View file

@ -3,7 +3,6 @@ use crate::array_buffer::Allocator;
use crate::external_references::ExternalReferences; use crate::external_references::ExternalReferences;
use crate::promise::PromiseRejectMessage; use crate::promise::PromiseRejectMessage;
use crate::support::intptr_t; use crate::support::intptr_t;
use crate::support::Delete;
use crate::support::Opaque; use crate::support::Opaque;
use crate::support::SharedRef; use crate::support::SharedRef;
use crate::support::UniqueRef; use crate::support::UniqueRef;
@ -575,8 +574,8 @@ impl CreateParams {
} }
} }
impl Delete for CreateParams { impl Drop for CreateParams {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8__Isolate__CreateParams__DELETE(self) } unsafe { v8__Isolate__CreateParams__DELETE(self) }
} }
} }

View file

@ -2,7 +2,6 @@ pub mod task;
pub use task::{Task, TaskBase, TaskImpl}; pub use task::{Task, TaskBase, TaskImpl};
use crate::support::Delete;
use crate::support::Opaque; use crate::support::Opaque;
use crate::support::UniquePtr; use crate::support::UniquePtr;
use crate::Isolate; use crate::Isolate;
@ -22,8 +21,8 @@ pub fn new_default_platform() -> UniquePtr<Platform> {
#[repr(C)] #[repr(C)]
pub struct Platform(Opaque); pub struct Platform(Opaque);
impl Delete for Platform { impl Drop for Platform {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8__Platform__DELETE(self) } unsafe { v8__Platform__DELETE(self) }
} }
} }

View file

@ -1,12 +1,12 @@
use std::mem::drop; use std::mem::drop;
use std::mem::forget; use std::mem::forget;
use std::mem::ManuallyDrop;
use crate::support::CxxVTable; use crate::support::CxxVTable;
use crate::support::Delete;
use crate::support::FieldOffset; use crate::support::FieldOffset;
use crate::support::Opaque; use crate::support::Opaque;
use crate::support::RustVTable; use crate::support::RustVTable;
use crate::support::UniquePtr; use crate::support::UniqueRef;
// class Task { // class Task {
// public: // public:
@ -41,8 +41,8 @@ impl Task {
} }
} }
impl Delete for Task { impl Drop for Task {
fn delete(&mut self) { fn drop(&mut self) {
unsafe { v8__Task__DELETE(self) } unsafe { v8__Task__DELETE(self) }
} }
} }
@ -52,13 +52,13 @@ pub trait AsTask {
fn as_task_mut(&mut self) -> &mut Task; fn as_task_mut(&mut self) -> &mut Task;
// TODO: this should be a trait in itself. // TODO: this should be a trait in itself.
fn into_unique_ptr(mut self: Box<Self>) -> UniquePtr<Task> fn into_unique_ref(mut self: Box<Self>) -> UniqueRef<Task>
where where
Self: 'static, Self: 'static,
{ {
let task = self.as_task_mut() as *mut Task; let task = self.as_task_mut() as *mut Task;
forget(self); forget(self);
unsafe { UniquePtr::from_raw(task) } unsafe { UniqueRef::from_raw(task) }
} }
} }
@ -90,23 +90,23 @@ pub trait TaskImpl: AsTask {
} }
pub struct TaskBase { pub struct TaskBase {
cxx_base: Task, cxx_base: ManuallyDrop<Task>,
offset_within_embedder: FieldOffset<Self>, offset_within_embedder: FieldOffset<Self>,
rust_vtable: RustVTable<&'static dyn TaskImpl>, rust_vtable: RustVTable<&'static dyn TaskImpl>,
} }
impl TaskBase { impl TaskBase {
fn construct_cxx_base() -> Task { fn construct_cxx_base() -> ManuallyDrop<Task> {
unsafe { unsafe {
let mut buf = std::mem::MaybeUninit::<Task>::uninit(); let mut buf = std::mem::MaybeUninit::<Task>::uninit();
v8__Task__BASE__CONSTRUCT(&mut buf); v8__Task__BASE__CONSTRUCT(&mut buf);
buf.assume_init() ManuallyDrop::new(buf.assume_init())
} }
} }
fn get_cxx_base_offset() -> FieldOffset<Task> { fn get_cxx_base_offset() -> FieldOffset<Task> {
let buf = std::mem::MaybeUninit::<Self>::uninit(); let buf = std::mem::MaybeUninit::<Self>::uninit();
FieldOffset::from_ptrs(buf.as_ptr(), unsafe { &(*buf.as_ptr()).cxx_base }) FieldOffset::from_ptrs(buf.as_ptr(), unsafe { &*(*buf.as_ptr()).cxx_base })
} }
fn get_offset_within_embedder<T>() -> FieldOffset<Self> fn get_offset_within_embedder<T>() -> FieldOffset<Self>
@ -208,17 +208,21 @@ mod tests {
} }
#[test] #[test]
fn test_task() { fn test_task_1() {
{ let mut task = TestTask::new();
TestTask::new().run(); task.run();
} drop(task);
assert_eq!(RUN_COUNT.swap(0, SeqCst), 1); assert_eq!(RUN_COUNT.swap(0, SeqCst), 1);
assert_eq!(DROP_COUNT.swap(0, SeqCst), 1); assert_eq!(DROP_COUNT.swap(0, SeqCst), 1);
{
Box::new(TestTask::new()).into_unique_ptr();
} }
assert_eq!(RUN_COUNT.swap(0, SeqCst), 0);
#[test]
fn test_task_2() {
let mut task = Box::new(TestTask::new()).into_unique_ref();
task.run();
task.run();
drop(task);
assert_eq!(RUN_COUNT.swap(0, SeqCst), 2);
assert_eq!(DROP_COUNT.swap(0, SeqCst), 1); assert_eq!(DROP_COUNT.swap(0, SeqCst), 1);
} }
} }

View file

@ -1,10 +1,12 @@
use std::cell::UnsafeCell; use std::cell::UnsafeCell;
use std::marker::PhantomData; use std::marker::PhantomData;
use std::mem::align_of;
use std::mem::forget; use std::mem::forget;
use std::mem::needs_drop;
use std::mem::size_of; use std::mem::size_of;
use std::mem::transmute;
use std::ops::Deref; use std::ops::Deref;
use std::ops::DerefMut; use std::ops::DerefMut;
use std::ptr::drop_in_place;
use std::ptr::null_mut; use std::ptr::null_mut;
use std::ptr::NonNull; use std::ptr::NonNull;
@ -19,28 +21,18 @@ pub use std::os::raw::c_long as long;
pub type Opaque = [u8; 0]; pub type Opaque = [u8; 0];
pub trait Delete
where
Self: Sized,
{
fn delete(&mut self) -> ();
}
/// Pointer to object allocated on the C++ heap. The pointer may be null. /// Pointer to object allocated on the C++ heap. The pointer may be null.
#[repr(transparent)] #[repr(transparent)]
pub struct UniquePtr<T>(Option<UniqueRef<T>>) pub struct UniquePtr<T>(Option<UniqueRef<T>>);
where
T: Delete;
impl<T> UniquePtr<T> impl<T> UniquePtr<T> {
where
T: Delete,
{
pub fn null() -> Self { pub fn null() -> Self {
assert_unique_type_compatible::<Self, T>();
Self(None) Self(None)
} }
pub unsafe fn from_raw(ptr: *mut T) -> Self { pub unsafe fn from_raw(ptr: *mut T) -> Self {
assert_unique_type_compatible::<Self, T>();
Self(UniqueRef::try_from_raw(ptr)) Self(UniqueRef::try_from_raw(ptr))
} }
@ -54,37 +46,22 @@ where
pub fn unwrap(self) -> UniqueRef<T> { pub fn unwrap(self) -> UniqueRef<T> {
self.0.unwrap() self.0.unwrap()
} }
unsafe fn _static_assert_has_pointer_repr() {
let dummy: fn() -> Self = || unimplemented!();
let _ptr: *mut T = transmute(dummy());
let _ref: &mut T = transmute(dummy());
}
} }
impl<T> From<UniqueRef<T>> for UniquePtr<T> impl<T> From<UniqueRef<T>> for UniquePtr<T> {
where
T: Delete,
{
fn from(unique_ref: UniqueRef<T>) -> Self { fn from(unique_ref: UniqueRef<T>) -> Self {
Self(Some(unique_ref)) Self(Some(unique_ref))
} }
} }
impl<T> Deref for UniquePtr<T> impl<T> Deref for UniquePtr<T> {
where
T: Delete,
{
type Target = Option<UniqueRef<T>>; type Target = Option<UniqueRef<T>>;
fn deref(&self) -> &Self::Target { fn deref(&self) -> &Self::Target {
&self.0 &self.0
} }
} }
impl<T> DerefMut for UniquePtr<T> impl<T> DerefMut for UniquePtr<T> {
where
T: Delete,
{
fn deref_mut(&mut self) -> &mut Self::Target { fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.0 &mut self.0
} }
@ -92,19 +69,12 @@ where
/// Pointer to object allocated on the C++ heap. The pointer may not be null. /// Pointer to object allocated on the C++ heap. The pointer may not be null.
#[repr(transparent)] #[repr(transparent)]
pub struct UniqueRef<T>(NonNull<T>) pub struct UniqueRef<T>(NonNull<T>);
where
T: Delete;
impl<T> UniqueRef<T> impl<T> UniqueRef<T> {
where unsafe fn try_from_raw(ptr: *mut T) -> Option<Self> {
T: Delete, assert_unique_type_compatible::<Self, T>();
{ NonNull::new(ptr).map(Self)
pub fn make_shared(self) -> SharedRef<T>
where
T: Shared,
{
self.into()
} }
pub unsafe fn from_raw(ptr: *mut T) -> Self { pub unsafe fn from_raw(ptr: *mut T) -> Self {
@ -117,48 +87,47 @@ where
ptr ptr
} }
unsafe fn try_from_raw(ptr: *mut T) -> Option<Self> { pub fn make_shared(self) -> SharedRef<T>
NonNull::new(ptr).map(Self)
}
unsafe fn _static_assert_has_pointer_repr() {
let dummy: fn() -> Self = || unimplemented!();
let _ptr: *mut T = transmute(dummy());
let _ref: &mut T = transmute(dummy());
}
}
impl<T> Deref for UniqueRef<T>
where where
T: Delete, T: Shared,
{ {
self.into()
}
}
impl<T> Deref for UniqueRef<T> {
type Target = T; type Target = T;
fn deref(&self) -> &Self::Target { fn deref(&self) -> &Self::Target {
unsafe { self.0.as_ref() } unsafe { self.0.as_ref() }
} }
} }
impl<T> DerefMut for UniqueRef<T> impl<T> DerefMut for UniqueRef<T> {
where
T: Delete,
{
fn deref_mut(&mut self) -> &mut Self::Target { fn deref_mut(&mut self) -> &mut Self::Target {
unsafe { self.0.as_mut() } unsafe { self.0.as_mut() }
} }
} }
impl<T> Drop for UniqueRef<T> impl<T> Drop for UniqueRef<T> {
where
T: Delete,
{
fn drop(&mut self) { fn drop(&mut self) {
Delete::delete(&mut **self) unsafe { drop_in_place(self.0.as_ptr()) }
} }
} }
fn assert_unique_type_compatible<U, T>() {
// Assert that `U` (a `UniqueRef` or `UniquePtr`) has the same memory layout
// as a pointer to `T`.
assert_eq!(size_of::<U>(), size_of::<*mut T>());
assert_eq!(align_of::<U>(), align_of::<*mut T>());
// Assert that `T` (probably) implements `Drop`. If it doesn't, a regular
// reference should be used instead of UniquePtr/UniqueRef.
assert!(needs_drop::<T>());
}
pub trait Shared pub trait Shared
where where
Self: Delete + 'static, Self: Sized,
{ {
fn clone(shared_ptr: *const SharedRef<Self>) -> SharedRef<Self>; fn clone(shared_ptr: *const SharedRef<Self>) -> SharedRef<Self>;
fn from_unique(unique: UniqueRef<Self>) -> SharedRef<Self>; fn from_unique(unique: UniqueRef<Self>) -> SharedRef<Self>;
@ -196,7 +165,7 @@ where
impl<T> From<UniqueRef<T>> for SharedRef<T> impl<T> From<UniqueRef<T>> for SharedRef<T>
where where
T: Delete + Shared, T: Shared,
{ {
fn from(unique: UniqueRef<T>) -> Self { fn from(unique: UniqueRef<T>) -> Self {
<T as Shared>::from_unique(unique) <T as Shared>::from_unique(unique)