Skip to main content

Unique

Struct Unique 

Source
pub struct Unique<T: ?Sized>(/* private fields */);
Expand description

A wrapper around a raw non-null *const T that indicates that the possessor of this wrapper owns the referent. Usefor building abstractions like Box<T>, Vec<T>, String, and HashMap<K, V>.

Unlike *mut T, Unique<T> behaves “as if” it were an instance of T. It implements Send/Sync if T is Send/Sync. It also implies the kind of strong aliasing guarantees an instance of T can expect: the referent of the pointer should not be modified without a unique path to its owning Unique.

If you’re uncertain of whether it’s correct to use Unique for your purposes, consider using NonNull, which has weaker semantics.

Unlike *mut T, the pointer must always be non-null, even if the pointer is never dereferenced. This is so that enums may use this forbidden value as a discriminant – Option<Unique<T>> has the same size as Unique<T>. However the pointer may still dangle if it isn’t dereferenced.

use fdf::Unique;
assert_eq!(size_of::<Unique<u8>>(), size_of::<Option<Unique<u8>>>());
assert_eq!(size_of::<Unique<u8>>(), size_of::<*const u8>());
assert_eq!(size_of::<Unique<usize>>(), size_of::<usize>());

Unlike *mut T, Unique<T> is covariant over T. This should always be correct for any type which upholds Unique’s aliasing requirements.

Implementations§

Source§

impl<T: Sized> Unique<T>

Source

pub const fn dangling() -> Self

Creates a new Unique that is dangling, but well-aligned.

This is useful for initializing types which lazily allocate, like Vec::new does.

Note that the pointer value may potentially represent a valid pointer to a T, which means this must not be used as a “not yet initialized” sentinel value. Types that lazily allocate must track initialization by some other means.

Source§

impl<T: ?Sized> Unique<T>

Source

pub const unsafe fn new_unchecked(ptr: *const T) -> Self

Creates a new Unique.

§Safety

ptr must be non-null.

Source

pub const fn new(ptr: *const T) -> Option<Self>

Creates a new Unique if ptr is non-null.

Source

pub const fn as_ptr(self) -> *const T

Acquires the underlying *const pointer.

Source

pub const fn as_non_null_ptr(self) -> NonNull<T>

Source

pub const unsafe fn as_ref(&self) -> &T

Dereferences the content.

The resulting lifetime is bound to self so this behaves “as if” it were actually an instance of T that is getting borrowed. If a longer (unbound) lifetime is needed, use &*my_ptr.as_ptr().

§Safety

the caller must guarantee that this object meets all the meets all the requirements for a reference.

Source

pub const fn cast<U>(self) -> Unique<U>

Casts to a pointer of another type.

Source§

impl Unique<dirent64>

Source

pub const fn d_ino(self) -> u64

Returns the inode of the dirent64, returns 0 if d_ino is not a struct member on your OS.

Source

pub const fn d_type(self) -> u8

Returns the libc equivalent of the type as eg DT_BLK from libc Follow the link for GNU documentation

Returns DT_UNKNOWN for systems without d_type (eg Solaris/Illumos)

Source

pub fn d_name_slice<'pointer>(self) -> &'pointer [u8]

Returns a slice reference to the d_name, not including null terminator.

Source

pub fn d_name_slice_c_str<'pointer>(self) -> &'pointer CStr

Returns a CStr reference to the d_name, (including null terminator.)

Source

pub const fn d_name(self) -> *const c_char

Access the pointer to d_name, note that d-name is not a [ u8/i8;255] array, it can be greater, So careful attention has to be paid

Source

pub fn name_length(self) -> usize

Returns the length of the d_name but, like strlen, it doesn’t include the null terminator.

Trait Implementations§

Source§

impl<T: ?Sized> Clone for Unique<T>

Source§

fn clone(&self) -> Self

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: ?Sized> Debug for Unique<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: ?Sized> From<&mut T> for Unique<T>

Source§

fn from(reference: &mut T) -> Self

Converts to this type from the input type.
Source§

impl<T: ?Sized> From<Unique<T>> for NonNull<T>

Source§

fn from(unique: Unique<T>) -> Self

Converts to this type from the input type.
Source§

impl<T: ?Sized> Pointer for Unique<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: ?Sized> Copy for Unique<T>

Source§

impl<T: Send + ?Sized> Send for Unique<T>

SAFETY: Unique pointers are Send if T is Send because the data they reference is unaliased. Note that this aliasing invariant is unenforced by the type system; the abstraction using the Unique must enforce it.

Source§

impl<T: Sync + ?Sized> Sync for Unique<T>

SAFETY: Unique pointers are Sync if T is Sync because the data they reference is unaliased. Note that this aliasing invariant is unenforced by the type system; the abstraction using the Unique must enforce it.

Auto Trait Implementations§

§

impl<T> Freeze for Unique<T>
where T: ?Sized,

§

impl<T> RefUnwindSafe for Unique<T>
where T: RefUnwindSafe + ?Sized,

§

impl<T> Unpin for Unique<T>
where T: Unpin + ?Sized,

§

impl<T> UnsafeUnpin for Unique<T>
where T: ?Sized,

§

impl<T> UnwindSafe for Unique<T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.