1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
use crate::raw;
use std::ffi::{CStr, CString};
use std::os::raw::c_int;
pub fn house_name(hsys: char) -> String {
unsafe {
CString::from(CStr::from_ptr(raw::swe_house_name(hsys as c_int)))
.to_str()
.unwrap()
.to_string()
}
}
#[derive(Debug, Clone)]
pub struct HousesResult {
pub cusps: Vec<f64>,
pub ascmc: [f64; 10],
pub result: i32,
}
pub fn houses(
tjd_ut: f64,
geolat: f64,
geolong: f64,
hsys: char,
) -> HousesResult {
let mut cusps = [0.0; 37];
let mut ascmc = [0.0; 10];
let result: i32 = unsafe {
let p_cuspsw = cusps.as_mut_ptr();
let p_ascmc = ascmc.as_mut_ptr();
raw::swe_houses_ex(
tjd_ut,
0,
geolat,
geolong,
hsys as c_int,
p_cuspsw,
p_ascmc,
)
};
HousesResult {
cusps: cusps.to_vec(),
ascmc: ascmc,
result: result,
}
}