use std::time::Duration;
use ffi_support::FfiStr;
use crate::{define_metric, handlemap_ext::HandleMapExtension, GLEAN};
define_metric!(TimespanMetric => TIMESPAN_METRICS {
new -> glean_new_timespan_metric(time_unit: i32),
test_get_num_recorded_errors -> glean_timespan_test_get_num_recorded_errors,
destroy -> glean_destroy_timespan_metric,
});
#[no_mangle]
pub extern "C" fn glean_timespan_set_start(glean_handle: u64, metric_id: u64, start_time: u64) {
GLEAN.call_infallible(glean_handle, |glean| {
TIMESPAN_METRICS.call_infallible_mut(metric_id, |metric| {
metric.set_start(glean, start_time);
})
})
}
#[no_mangle]
pub extern "C" fn glean_timespan_set_stop(glean_handle: u64, metric_id: u64, stop_time: u64) {
GLEAN.call_infallible(glean_handle, |glean| {
TIMESPAN_METRICS.call_infallible_mut(metric_id, |metric| {
metric.set_stop(glean, stop_time);
})
})
}
#[no_mangle]
pub extern "C" fn glean_timespan_cancel(metric_id: u64) {
TIMESPAN_METRICS.call_infallible_mut(metric_id, |metric| {
metric.cancel();
})
}
#[no_mangle]
pub extern "C" fn glean_timespan_set_raw_nanos(
glean_handle: u64,
metric_id: u64,
elapsed_nanos: u64,
) {
let elapsed = Duration::from_nanos(elapsed_nanos);
GLEAN.call_infallible(glean_handle, |glean| {
TIMESPAN_METRICS.call_infallible(metric_id, |metric| {
metric.set_raw(glean, elapsed, false);
})
})
}
#[no_mangle]
pub extern "C" fn glean_timespan_test_has_value(
glean_handle: u64,
metric_id: u64,
storage_name: FfiStr,
) -> u8 {
GLEAN.call_infallible(glean_handle, |glean| {
TIMESPAN_METRICS.call_infallible(metric_id, |metric| {
metric
.test_get_value(glean, storage_name.as_str())
.is_some()
})
})
}
#[no_mangle]
pub extern "C" fn glean_timespan_test_get_value(
glean_handle: u64,
metric_id: u64,
storage_name: FfiStr,
) -> u64 {
GLEAN.call_infallible(glean_handle, |glean| {
TIMESPAN_METRICS.call_infallible(metric_id, |metric| {
metric.test_get_value(glean, storage_name.as_str()).unwrap()
})
})
}