use base::cross_process_instant::CrossProcessInstant;
use dom_struct::dom_struct;
use time_03::Duration;
use super::performance::ToDOMHighResTimeStamp;
use crate::dom::bindings::codegen::Bindings::PerformanceBinding::DOMHighResTimeStamp;
use crate::dom::bindings::codegen::Bindings::PerformanceEntryBinding::PerformanceEntryMethods;
use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
use crate::dom::bindings::root::DomRoot;
use crate::dom::bindings::str::DOMString;
use crate::dom::globalscope::GlobalScope;
#[dom_struct]
pub struct PerformanceEntry {
reflector_: Reflector,
name: DOMString,
entry_type: DOMString,
#[no_trace]
start_time: Option<CrossProcessInstant>,
#[no_trace]
#[ignore_malloc_size_of = "No MallocSizeOf support for `time` crate"]
duration: Duration,
}
impl PerformanceEntry {
pub fn new_inherited(
name: DOMString,
entry_type: DOMString,
start_time: Option<CrossProcessInstant>,
duration: Duration,
) -> PerformanceEntry {
PerformanceEntry {
reflector_: Reflector::new(),
name,
entry_type,
start_time,
duration,
}
}
#[allow(crown::unrooted_must_root)]
pub fn new(
global: &GlobalScope,
name: DOMString,
entry_type: DOMString,
start_time: CrossProcessInstant,
duration: Duration,
) -> DomRoot<PerformanceEntry> {
let entry = PerformanceEntry::new_inherited(name, entry_type, Some(start_time), duration);
reflect_dom_object(Box::new(entry), global)
}
pub fn entry_type(&self) -> &DOMString {
&self.entry_type
}
pub fn name(&self) -> &DOMString {
&self.name
}
pub fn start_time(&self) -> Option<CrossProcessInstant> {
self.start_time
}
pub fn duration(&self) -> Duration {
self.duration
}
}
impl PerformanceEntryMethods for PerformanceEntry {
fn Name(&self) -> DOMString {
self.name.clone()
}
fn EntryType(&self) -> DOMString {
self.entry_type.clone()
}
fn StartTime(&self) -> DOMHighResTimeStamp {
self.global()
.performance()
.maybe_to_dom_high_res_time_stamp(self.start_time)
}
fn Duration(&self) -> DOMHighResTimeStamp {
self.duration.to_dom_high_res_time_stamp()
}
}