Skip to content

Commit

Permalink
subscriber: use display_timestamp and display_level in `Json::for…
Browse files Browse the repository at this point in the history
…mat_event` (#1463)

## Motivation

It should be possible to remove `timestamp` and `level` fields when
using json formatting.

As of now this has no effect:

```rs
let subscriber = tracing_subscriber::fmt()
    .with_level(false)
    .without_time()
    .json()
    .finish();
```

## Solution

Use the existing `display_timestamp` and `display_level` fields to
conditionally serialize `timestamp` and `level`.
lerouxrgd authored Jul 12, 2021
1 parent a74a047 commit c848820
Showing 1 changed file with 7 additions and 2 deletions.
9 changes: 7 additions & 2 deletions tracing-subscriber/src/fmt/format/json.rs
Original file line number Diff line number Diff line change
@@ -204,8 +204,13 @@ where

let mut serializer = serializer.serialize_map(None)?;

serializer.serialize_entry("timestamp", &timestamp)?;
serializer.serialize_entry("level", &meta.level().as_serde())?;
if self.display_timestamp {
serializer.serialize_entry("timestamp", &timestamp)?;
}

if self.display_level {
serializer.serialize_entry("level", &meta.level().as_serde())?;
}

let format_field_marker: std::marker::PhantomData<N> = std::marker::PhantomData;

0 comments on commit c848820

Please sign in to comment.