use crate::source_map::SourceMap; use std::borrow::Borrow; use rustc_data_structures::profiling::EventArgRecorder; /// Extension trait for self-profiling purposes: allows to record spans within a generic activity's /// event arguments. pub trait SpannedEventArgRecorder { /// Records the following event arguments within the current generic activity being profiled: /// - the provided `event_arg` /// - a string representation of the provided `span` /// /// Note: when self-profiling with costly event arguments, at least one argument /// needs to be recorded. A panic will be triggered if that doesn't happen. fn record_arg_with_span(&mut self, source_map: &SourceMap, event_arg: A, span: crate::Span) where A: Borrow + Into; } impl SpannedEventArgRecorder for EventArgRecorder<'_> { fn record_arg_with_span(&mut self, source_map: &SourceMap, event_arg: A, span: crate::Span) where A: Borrow + Into, { self.record_arg(event_arg); self.record_arg(source_map.span_to_embeddable_string(span)); } }