2018-08-30 14:18:55 +02:00
|
|
|
//@ run-pass
|
2024-03-06 12:44:54 -08:00
|
|
|
//@ ignore-wasm32 wasi-libc does not have lgamma
|
2019-04-24 09:26:33 -07:00
|
|
|
//@ ignore-sgx no libc
|
2015-03-05 18:33:58 -08:00
|
|
|
|
2024-04-14 16:23:07 -04:00
|
|
|
use std::ffi::{c_double, c_int};
|
2020-09-01 17:12:52 -04:00
|
|
|
use std::mem;
|
2012-06-21 16:50:45 -07:00
|
|
|
|
2015-03-25 17:06:52 -07:00
|
|
|
fn to_c_int(v: &mut isize) -> &mut c_int {
|
2020-09-01 17:12:52 -04:00
|
|
|
unsafe { mem::transmute_copy(&v) }
|
2012-08-02 14:23:04 -07:00
|
|
|
}
|
|
|
|
|
2015-03-25 17:06:52 -07:00
|
|
|
fn lgamma(n: c_double, value: &mut isize) -> c_double {
|
2013-01-23 16:29:31 -08:00
|
|
|
unsafe {
|
|
|
|
return m::lgamma(n, to_c_int(value));
|
|
|
|
}
|
2012-06-21 16:50:45 -07:00
|
|
|
}
|
|
|
|
|
2013-03-05 14:42:58 -08:00
|
|
|
mod m {
|
2024-04-14 16:23:07 -04:00
|
|
|
use std::ffi::{c_double, c_int};
|
2020-09-01 17:12:52 -04:00
|
|
|
extern "C" {
|
2020-10-27 13:10:31 +00:00
|
|
|
#[cfg(all(unix, not(target_os = "vxworks")))]
|
2013-03-05 14:42:58 -08:00
|
|
|
#[link_name="lgamma_r"]
|
|
|
|
pub fn lgamma(n: c_double, sign: &mut c_int) -> c_double;
|
|
|
|
#[cfg(windows)]
|
2020-09-01 17:12:52 -04:00
|
|
|
#[link_name = "lgamma"]
|
2013-03-05 14:42:58 -08:00
|
|
|
pub fn lgamma(n: c_double, sign: &mut c_int) -> c_double;
|
2019-07-31 17:09:07 -07:00
|
|
|
#[cfg(target_os = "vxworks")]
|
2020-09-01 17:12:52 -04:00
|
|
|
#[link_name = "lgamma"]
|
2019-07-31 17:09:07 -07:00
|
|
|
pub fn lgamma(n: c_double, sign: &mut c_int) -> c_double;
|
2013-03-05 14:42:58 -08:00
|
|
|
}
|
2012-06-21 16:50:45 -07:00
|
|
|
}
|
|
|
|
|
2013-02-01 19:43:17 -08:00
|
|
|
pub fn main() {
|
2020-09-01 17:12:52 -04:00
|
|
|
let mut y: isize = 5;
|
|
|
|
let x: &mut isize = &mut y;
|
|
|
|
assert_eq!(lgamma(1.0 as c_double, x), 0.0 as c_double);
|
2012-12-13 13:05:22 -08:00
|
|
|
}
|