1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
use crate::containers::MaybePtr;
#[cfg(not(feature = "c-structures"))]
pub(crate) mod rust {
pub type Ptr<T> = Box<T>;
use super::IntoMaybePtr;
impl<T: std::fmt::Debug> IntoMaybePtr<T> for Ptr<T> {
fn into_maybe_ptr(self) -> crate::containers::MaybePtr<T> {
Some(self)
}
}
use super::UnPtr;
impl<T> UnPtr<T> for Ptr<T> {
fn unptr(self) -> T {
*self
}
}
}
#[cfg(feature = "c-structures")]
pub(crate) mod c {
use super::MaybePtr;
use std::ops::Deref;
#[repr(C)]
pub struct Ptr<T: std::fmt::Debug> {
ptr: *mut T,
}
impl<T: std::fmt::Debug> Drop for Ptr<T> {
fn drop(&mut self) {
if self.ptr.is_null() {
return;
}
drop(unsafe { Box::from_raw(self.ptr) });
self.ptr = std::ptr::null_mut();
}
}
impl<T> std::fmt::Debug for Ptr<T>
where
T: std::fmt::Debug,
{
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
std::fmt::Debug::fmt(&**self, f)
}
}
impl<T> PartialEq for Ptr<T>
where
T: PartialEq + std::fmt::Debug,
{
fn eq(&self, other: &Self) -> bool {
PartialEq::eq(self.as_ref(), other.as_ref())
}
}
impl<T> Clone for Ptr<T>
where
T: Clone + std::fmt::Debug,
{
fn clone(&self) -> Self {
let value = self.as_ref().clone();
Self::new(value)
}
}
impl<T: std::fmt::Debug> Deref for Ptr<T> {
type Target = T;
fn deref(&self) -> &Self::Target {
unsafe { &*self.ptr }
}
}
impl<T: std::fmt::Debug> AsRef<T> for Ptr<T> {
fn as_ref(&self) -> &T {
unsafe { self.ptr.as_ref().unwrap() }
}
}
use super::IntoMaybePtr;
impl<T: std::fmt::Debug> IntoMaybePtr<T> for Ptr<T> {
fn into_maybe_ptr(self) -> MaybePtr<T> {
MaybePtr::from_raw(self.into_raw())
}
}
impl<T: std::fmt::Debug> Ptr<T> {
pub fn new(t: T) -> Self {
let ptr = Box::into_raw(Box::new(t));
Self::from_raw(ptr)
}
pub fn from_raw(ptr: *mut T) -> Self {
debug_assert!(!ptr.is_null());
Self { ptr }
}
pub fn into_raw(mut self) -> *mut T {
let ptr = self.ptr;
self.ptr = std::ptr::null_mut();
ptr
}
}
impl<T: std::fmt::Debug> From<Box<T>> for Ptr<T> {
fn from(boxed: Box<T>) -> Self {
Self::from_raw(Box::into_raw(boxed))
}
}
use super::UnPtr;
impl<T: Sized + std::fmt::Debug> UnPtr<T> for Ptr<T> {
fn unptr(self) -> T {
*unsafe { Box::from_raw(self.into_raw()) }
}
}
}
pub trait IntoMaybePtr<T: std::fmt::Debug> {
fn into_maybe_ptr(self) -> MaybePtr<T>
where
Self: Sized;
}
pub(crate) trait UnPtr<T: Sized> {
fn unptr(self) -> T
where
Self: Sized;
}