forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of rust-lang#18227 - davidbarsky:davidbarsky/push-lmntvwvz…
…nyyx, r=davidbarsky internal: add json `tracing` Layer for profiling startup On `buck2/integrations/rust-project`, this results in the following being printed: ```json {"name":"discover_command","elapsed_ms":18703} {"name":"parallel_prime_caches","elapsed_ms":0} {"name":"vfs_load","elapsed_ms":5895} {"name":"vfs_load","elapsed_ms":547} {"name":"parallel_prime_caches","elapsed_ms":23} {"name":"parallel_prime_caches","elapsed_ms":84} {"name":"parallel_prime_caches","elapsed_ms":5819} ```
- Loading branch information
Showing
8 changed files
with
190 additions
and
62 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
90 changes: 90 additions & 0 deletions
90
src/tools/rust-analyzer/crates/rust-analyzer/src/tracing/json.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
//! A [tracing_subscriber::layer::Layer] that exports new-line delinated JSON. | ||
//! | ||
//! Usage: | ||
//! | ||
//! ```rust | ||
//! let layer = json::TimingLayer::new(std::io::stderr); | ||
//! Registry::default().with(layer).init(); | ||
//! ``` | ||
use std::{io::Write as _, marker::PhantomData, time::Instant}; | ||
|
||
use ide_db::FxHashSet; | ||
use tracing::{ | ||
span::{Attributes, Id}, | ||
Event, Subscriber, | ||
}; | ||
use tracing_subscriber::{fmt::MakeWriter, layer::Context, registry::LookupSpan, Layer}; | ||
|
||
struct JsonData { | ||
name: &'static str, | ||
start: std::time::Instant, | ||
} | ||
|
||
impl JsonData { | ||
fn new(name: &'static str) -> Self { | ||
Self { name, start: Instant::now() } | ||
} | ||
} | ||
|
||
#[derive(Debug)] | ||
pub(crate) struct TimingLayer<S, W> { | ||
writer: W, | ||
_inner: PhantomData<fn(S)>, | ||
} | ||
|
||
impl<S, W> TimingLayer<S, W> { | ||
pub(crate) fn new(writer: W) -> Self { | ||
Self { writer, _inner: PhantomData } | ||
} | ||
} | ||
|
||
impl<S, W> Layer<S> for TimingLayer<S, W> | ||
where | ||
S: Subscriber + for<'span> LookupSpan<'span>, | ||
W: for<'writer> MakeWriter<'writer> + Send + Sync + 'static, | ||
{ | ||
fn on_new_span(&self, attrs: &Attributes<'_>, id: &Id, ctx: Context<'_, S>) { | ||
let span = ctx.span(id).unwrap(); | ||
|
||
let data = JsonData::new(attrs.metadata().name()); | ||
span.extensions_mut().insert(data); | ||
} | ||
|
||
fn on_event(&self, _event: &Event<'_>, _ctx: Context<'_, S>) {} | ||
|
||
fn on_close(&self, id: Id, ctx: Context<'_, S>) { | ||
#[derive(serde::Serialize)] | ||
struct JsonDataInner { | ||
name: &'static str, | ||
elapsed_ms: u128, | ||
} | ||
|
||
let span = ctx.span(&id).unwrap(); | ||
let Some(data) = span.extensions_mut().remove::<JsonData>() else { | ||
return; | ||
}; | ||
|
||
let data = JsonDataInner { name: data.name, elapsed_ms: data.start.elapsed().as_millis() }; | ||
let mut out = serde_json::to_string(&data).expect("Unable to serialize data"); | ||
out.push('\n'); | ||
self.writer.make_writer().write_all(out.as_bytes()).expect("Unable to write data"); | ||
} | ||
} | ||
|
||
#[derive(Default, Clone, Debug)] | ||
pub(crate) struct JsonFilter { | ||
pub(crate) allowed_names: Option<FxHashSet<String>>, | ||
} | ||
|
||
impl JsonFilter { | ||
pub(crate) fn from_spec(spec: &str) -> Self { | ||
let allowed_names = if spec == "*" { | ||
None | ||
} else { | ||
Some(FxHashSet::from_iter(spec.split('|').map(String::from))) | ||
}; | ||
|
||
Self { allowed_names } | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters