#ephemeris #astrology #zodiac #astronomy

sys libswisseph-sys

Rust system wrapper for swisseph C library

3 releases

0.1.2 Aug 10, 2024
0.1.1 Aug 2, 2024
0.1.0 Jul 27, 2024

#203 in Geospatial

Download history 26/week @ 2024-09-11 23/week @ 2024-09-18 15/week @ 2024-09-25 2/week @ 2024-10-02 1/week @ 2024-10-09 12/week @ 2024-11-27 113/week @ 2024-12-04 79/week @ 2024-12-11 18/week @ 2024-12-18 7/week @ 2024-12-25

226 downloads per month
Used in swisseph

AGPL-3.0-only

2MB
36K SLoC

C 33K SLoC // 0.2% comments Rust 2K SLoC // 0.4% comments M4 382 SLoC // 0.0% comments Perl 134 SLoC // 0.3% comments Shell 70 SLoC // 0.1% comments GDB Script 4 SLoC GNU Style Assembly 3 SLoC

libswisseph-sys

Rust system wrapper for the swisseph C library

Usage

By default, the main pub export will be the raw bindgen generated files. These bindings require the user to know what types the functions expect as many of the functions take pointers to arrays of varying sizes.

use libswisseph_sys::*;

TODO: in progress

Also included is a tuple_result mod that provides functions where all the return data is created and returned from the function itself. Error codes are also checked and the entire calculation is wrapped in a Result type so rust users can do a standard check for Ok or Err.

use libswisseph_sys::tuple_result::*;

Ephemeris files

Ephemeris files are excluded from this crate so that it fits on crates.io. There are standard standard ephemeris files located in the swisseph c library and there are many more that can be included depending on the desired calculation. For example: astroids, JPL, etc.

The ephemeris path with default to and can be set as described in the swisseph C library. See https://github.com/aloistr/swisseph/ for further details.

Example usage

use libswisseph_sys::*;
let mut xx: [f64; 6] = [0.0; 6];
let mut serr = [0; 256];

let y = 2002;
let m = 1;
let d = 1;
let h = 0.0;
let i_flag = SE_GREG_CAL as i32;

let tjd_ut = swe_julday(y, m, d, h, i_flag);
let ipl = SE_SUN as i32;
swe_calc_ut(
    tjd_ut, 
    ipl, 
    SEFLG_SPEED as i32, 
    xx.as_mut_ptr(), 
    serr.as_mut_ptr(),
);

let _lng = xx[0];
let _lat = xx[1];
let _speed = xx[3];

TODO

  • See if bindgen can generate more ergonomic integer types. There is some discrepancy between signed and unsigned types for functions and constants. For example, SE_ERR is -1 and it generates a i32, but SE_OK is 0 so a u32 is generated.

swisseph docs

https://www.astro.com/swisseph/swephprg.htm https://www.astro.com/ftp/swisseph/doc/swisseph.pdf

Credits

  • Astrodienst / @aloistr for swisseph
  • Stéphane Bressani / @stephaneworkspace for work on his wrapper and rust project

Notes

u128 warnings

Rustc u128 is not ffi safe. Any functions that reference u128 have been ignored to prevent compilation errors.

Added the swisseph c lib as submodule

git submodule add https://github.com/aloistr/swisseph.git libswisseph/

Functions not included

There is some functionality provided by the Swiss Ephemeris that are not referenced in header files and thus will not be included. Several of the files include main function, for example the swevents does event calculation and outputs to local file.

swedates also has overlapping types that causes errors so it has not been included.

Dependencies