#raw-pointers #pointers #raw

no-std rawpointer

Extra methods for raw pointers and NonNull<T>. For example .post_inc() and .pre_dec() (c.f. ptr++ and --ptr), offset and add for NonNull<T>, and the function ptrdistance.

3 unstable releases

Uses old Rust 2015

0.2.1 Sep 12, 2019
0.2.0 Sep 8, 2019
0.1.0 Dec 15, 2016

#682 in Rust patterns

Download history 309852/week @ 2024-10-07 307431/week @ 2024-10-14 326499/week @ 2024-10-21 299814/week @ 2024-10-28 314523/week @ 2024-11-04 297850/week @ 2024-11-11 311621/week @ 2024-11-18 294654/week @ 2024-11-25 332583/week @ 2024-12-02 327721/week @ 2024-12-09 315746/week @ 2024-12-16 146557/week @ 2024-12-23 176236/week @ 2024-12-30 325660/week @ 2025-01-06 456190/week @ 2025-01-13 350644/week @ 2025-01-20

1,324,680 downloads per month
Used in 2,796 crates (11 directly)

MIT/Apache

9KB
140 lines

rawpointer

Please read the API documentation here

build_status

Recent Changes

  • 0.2.0
    • Add support for NonNull<T>
    • Added more documentation and an example
    • Now requires Rust 1.26 or later
  • 0.1.0
    • Initial release

lib.rs:

Rawpointer adds extra utility methods to raw pointers *const T, *mut T and NonNull<T>.

Features include:

  • Strided offsets - .stride_offset(stride, index) make it easy to compute pointer offsets where the index is unsigned and the stride is signed.

  • Offsetting methods in general for NonNull, since it does not have these from libcore

  • Post- and preincrement and post- and predecrement methods

use rawpointer::PointerExt;

unsafe {
    // In this example:
    // Use .post_inc() to iterate and overwrite the first four
    // elements of the array.

    let mut xs = [0; 16];
    let mut ptr = xs.as_mut_ptr();
    let end = ptr.offset(4);
    let mut i = 0;
    while ptr != end {
        *ptr.post_inc() = i;
        i += 1;
    }
    assert_eq!(&xs[..8], &[0, 1, 2, 3, 0, 0, 0, 0]);
}

Safety

See the Rust core::ptr documentation for more information.

Rust Version

This version of the crate requires Rust 1.26 or later

No runtime deps