use crate::rng64::Threefish256;
use std::slice::from_raw_parts_mut;
#[unsafe(no_mangle)]
pub extern "C" fn threefish256_new(seed: u64) -> *mut Threefish256 {
Box::into_raw(Box::new(Threefish256::new(seed)))
}
#[unsafe(no_mangle)]
pub extern "C" fn threefish256_free(ptr: *mut Threefish256) {
if !ptr.is_null() {
unsafe { drop(Box::from_raw(ptr)) };
}
}
#[unsafe(no_mangle)]
pub extern "C" fn threefish256_next_u64s(ptr: *mut Threefish256, out: *mut u64, count: usize) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
let mut i = 0;
while i < count {
let out_arr = rng.nextu();
let limit = (count - i).min(4);
buffer[i..i + limit].copy_from_slice(&out_arr[..limit]);
i += 4;
}
}
}
#[unsafe(no_mangle)]
pub extern "C" fn threefish256_next_f64s(ptr: *mut Threefish256, out: *mut f64, count: usize) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
let mut i = 0;
while i < count {
let out_arr = rng.nextf();
let limit = (count - i).min(4);
buffer[i..i + limit].copy_from_slice(&out_arr[..limit]);
i += 4;
}
}
}
#[unsafe(no_mangle)]
pub extern "C" fn threefish256_rand_i64s(
ptr: *mut Threefish256,
out: *mut i64,
count: usize,
min: i64,
max: i64,
) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
let mut i = 0;
while i < count {
let out_arr = rng.randi(min, max);
let limit = (count - i).min(4);
buffer[i..i + limit].copy_from_slice(&out_arr[..limit]);
i += 4;
}
}
}
#[unsafe(no_mangle)]
pub extern "C" fn threefish256_rand_f64s(
ptr: *mut Threefish256,
out: *mut f64,
count: usize,
min: f64,
max: f64,
) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
let mut i = 0;
while i < count {
let out_arr = rng.randf(min, max);
let limit = (count - i).min(4);
buffer[i..i + limit].copy_from_slice(&out_arr[..limit]);
i += 4;
}
}
}