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
use crate::extensions::prelude::*;
use core::ptr::NonNull;
use std::num::NonZeroU32;
pub(crate) trait PointerExt<T>: Sized {
fn non_null(self) -> NonNull<T>;
fn add_bytes(self, offset: usize) -> Self;
#[inline(always)]
fn add_bytes_u32(self, offset: u32) -> Self {
self.add_bytes(offset as usize)
}
#[inline(always)]
fn add_bytes_non_zero_u32(self, offset: NonZeroU32) -> Self {
self.add_bytes_u32(offset.get())
}
fn to_usize(self) -> usize;
fn is_not_null(self) -> bool;
fn reference<'a>(self) -> &'a T;
}
impl<T> PointerExt<T> for *const T {
#[inline(always)]
fn non_null(self) -> NonNull<T> {
non_null_pointer(self as *mut T)
}
#[inline(always)]
fn add_bytes(self, offset: usize) -> Self {
((self as usize) + offset) as *const T
}
#[inline(always)]
fn to_usize(self) -> usize {
self as usize
}
#[inline(always)]
fn is_not_null(self) -> bool {
!self.is_null()
}
#[inline(always)]
fn reference<'a>(self) -> &'a T {
debug_assert!(self.is_not_null(), "null pointers can not be derefenced");
unsafe { &*self }
}
}
impl<T> PointerExt<T> for *mut T {
#[inline(always)]
fn non_null(self) -> NonNull<T> {
non_null_pointer(self)
}
#[inline(always)]
fn add_bytes(self, offset: usize) -> Self {
((self as usize) + offset) as *mut T
}
#[inline(always)]
fn to_usize(self) -> usize {
self as usize
}
#[inline(always)]
fn is_not_null(self) -> bool {
!self.is_null()
}
#[inline(always)]
fn reference<'a>(self) -> &'a T {
debug_assert!(self.is_not_null(), "null pointers can not be derefenced");
unsafe { &*self }
}
}