21 stable releases

Uses old Rust 2015

2.0.0 Sep 25, 2020
1.3.3 May 1, 2019
1.3.2 Aug 2, 2018
1.3.1 Jun 16, 2018
1.0.10 Mar 25, 2015

#463 in Algorithms

Download history 6675/week @ 2023-10-18 5664/week @ 2023-10-25 5755/week @ 2023-11-01 6883/week @ 2023-11-08 5235/week @ 2023-11-15 4826/week @ 2023-11-22 5183/week @ 2023-11-29 3615/week @ 2023-12-06 4372/week @ 2023-12-13 2550/week @ 2023-12-20 2349/week @ 2023-12-27 3828/week @ 2024-01-03 4787/week @ 2024-01-10 4943/week @ 2024-01-17 4192/week @ 2024-01-24 2620/week @ 2024-01-31

17,215 downloads per month
Used in 89 crates (9 directly)

Apache-2.0/MIT

34KB
493 lines

c_vec Build Status

Structures to wrap C arrays. Here's a little example:

extern crate libc;
extern crate c_vec;

use c_vec::{CVec, CSlice};

fn some_func(cvec: *mut libc::c_int, len: libc::c_uint) {
    // safe wrapper, you can pass a destructor with new_with_dtor() method
    let v = unsafe { CVec::new(cvec, len as usize) };
    // unsafe wrapper with no destructor
    let mut s = unsafe { CSlice::new(cvec, len as usize) };

    println!("cvec:   converted from c array: {:?}", v.as_ref());
    println!("cslice: converted from c array: {:?}", s.as_mut());
}

Usage

You can use it directly by adding this line to your Cargo.toml file:

[dependencies]
c_vec = "^1.0.0"

Here's the crates.io page for c_vec.

License

This project is under the MIT and Apache 2.0 licenses. Please take a look at the license files for more information.

No runtime deps