GP_Image_Test/extern/bindings/src/lib.rs

63 lines
1.7 KiB
Rust
Raw Normal View History

2024-01-29 11:00:53 -05:00
#![crate_type="cdylib"]
#[no_mangle]
pub extern "C" fn test() {
println!("Hello");
}
2024-01-29 15:55:28 -05:00
#[repr(C)]
#[derive(Default)]
pub struct Bruh {
error: i8,
estimate: f64,
p_value: f64,
weights: Option<std::ptr::NonNull<f64>>,
weights_len: usize,
weights_capacity: usize,
}
#[no_mangle]
pub extern "C-unwind" fn willbert(data: *const f64, len: usize) -> Bruh {
use stattest::test::{ShapiroWilkError, ShapiroWilkStatus};
let slice = unsafe { std::slice::from_raw_parts(data, len) };
let result = stattest::test::ShapiroWilkTest::new(slice);
match result {
Ok(results) => {
let (weights, weights_len, weights_capacity) = {
let ptr = results.weights.as_ptr();
let len = results.weights.len();
let capacity = results.weights.capacity();
std::mem::forget(results.weights);
(std::ptr::NonNull::new(ptr.cast_mut()), len, capacity)
};
Bruh {
error: match results.status {
ShapiroWilkStatus::Ok => 0,
ShapiroWilkStatus::TooMany => 1,
},
estimate: results.estimate,
p_value: results.p_value,
weights,
weights_capacity,
weights_len,
}
}
Err(error) => {
let error = match error {
ShapiroWilkError::TooFew => -1,
ShapiroWilkError::NoDifference => -2,
ShapiroWilkError::CannotMakeDistribution => -3,
};
Bruh {
error,
..Default::default()
}
}
}
}