nautilus_core/ffi/
datetime.rs

1// -------------------------------------------------------------------------------------------------
2//  Copyright (C) 2015-2025 Posei Systems Pty Ltd. All rights reserved.
3//  https://poseitrader.io
4//
5//  Licensed under the GNU Lesser General Public License Version 3.0 (the "License");
6//  You may not use this file except in compliance with the License.
7//  You may obtain a copy of the License at https://www.gnu.org/licenses/lgpl-3.0.en.html
8//
9//  Unless required by applicable law or agreed to in writing, software
10//  distributed under the License is distributed on an "AS IS" BASIS,
11//  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//  See the License for the specific language governing permissions and
13//  limitations under the License.
14// -------------------------------------------------------------------------------------------------
15
16//! Thin FFI wrappers around the date/time conversion utilities in `nautilus-core`.
17//!
18//! The Rust implementation already lives in `crate::datetime`; this module simply exposes the
19//! conversions to C (and, by extension, to Python via Cython) while keeping the behaviour and the
20//! documentation in one place.  Each exported function forwards directly to its Rust counterpart
21//! and therefore inherits the same semantics and safety guarantees.
22
23use std::ffi::c_char;
24
25use crate::{
26    datetime::{unix_nanos_to_iso8601, unix_nanos_to_iso8601_millis},
27    ffi::string::str_to_cstr,
28};
29
30/// Converts a UNIX nanoseconds timestamp to an ISO 8601 (RFC 3339) format C string pointer.
31#[cfg(feature = "ffi")]
32#[unsafe(no_mangle)]
33pub extern "C" fn unix_nanos_to_iso8601_cstr(timestamp_ns: u64) -> *const c_char {
34    str_to_cstr(&unix_nanos_to_iso8601(timestamp_ns.into()))
35}
36
37/// Converts a UNIX nanoseconds timestamp to an ISO 8601 (RFC 3339) format C string pointer
38/// with millisecond precision.
39#[cfg(feature = "ffi")]
40#[unsafe(no_mangle)]
41pub extern "C" fn unix_nanos_to_iso8601_millis_cstr(timestamp_ns: u64) -> *const c_char {
42    str_to_cstr(&unix_nanos_to_iso8601_millis(timestamp_ns.into()))
43}
44/// Converts seconds to nanoseconds (ns).
45#[cfg(feature = "ffi")]
46#[unsafe(no_mangle)]
47pub extern "C" fn secs_to_nanos(secs: f64) -> u64 {
48    crate::datetime::secs_to_nanos(secs)
49}
50
51/// Converts seconds to milliseconds (ms).
52#[cfg(feature = "ffi")]
53#[unsafe(no_mangle)]
54pub extern "C" fn secs_to_millis(secs: f64) -> u64 {
55    crate::datetime::secs_to_millis(secs)
56}
57
58/// Converts milliseconds (ms) to nanoseconds (ns).
59#[cfg(feature = "ffi")]
60#[unsafe(no_mangle)]
61pub extern "C" fn millis_to_nanos(millis: f64) -> u64 {
62    crate::datetime::millis_to_nanos(millis)
63}
64
65/// Converts microseconds (μs) to nanoseconds (ns).
66#[cfg(feature = "ffi")]
67#[unsafe(no_mangle)]
68pub extern "C" fn micros_to_nanos(micros: f64) -> u64 {
69    crate::datetime::micros_to_nanos(micros)
70}
71
72/// Converts nanoseconds (ns) to seconds.
73#[cfg(feature = "ffi")]
74#[unsafe(no_mangle)]
75pub extern "C" fn nanos_to_secs(nanos: u64) -> f64 {
76    crate::datetime::nanos_to_secs(nanos)
77}
78
79/// Converts nanoseconds (ns) to milliseconds (ms).
80#[cfg(feature = "ffi")]
81#[unsafe(no_mangle)]
82pub const extern "C" fn nanos_to_millis(nanos: u64) -> u64 {
83    crate::datetime::nanos_to_millis(nanos)
84}
85
86/// Converts nanoseconds (ns) to microseconds (μs).
87#[cfg(feature = "ffi")]
88#[unsafe(no_mangle)]
89pub const extern "C" fn nanos_to_micros(nanos: u64) -> u64 {
90    crate::datetime::nanos_to_micros(nanos)
91}