1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
//! Includes structs and functions to work with dumping.
//! For more details see [The Actoromicon](https://actoromicon.rs/ch05-03-dumping.md.html).

use serde::{Serialize, Serializer};

#[cfg(feature = "unstable")] // TODO: patch `stability`, again.
pub use self::{
    control::{CheckResult, DumpingControl},
    dump::{Direction, Dump, ErasedMessage, MessageKind, MessageName, Timestamp},
    dumper::Dumper,
    extract_name::{extract_name, extract_name_by_type},
    raw::Raw,
    recorder::{set_make_recorder, Recorder},
    sequence_no::SequenceNo,
};
#[cfg(not(feature = "unstable"))] // TODO: patch `stability`, again.
pub(crate) use self::{
    control::{CheckResult, DumpingControl},
    dump::{Direction, Dump, ErasedMessage, MessageKind, MessageName, Timestamp},
    dumper::Dumper,
    extract_name::{extract_name, extract_name_by_type},
    raw::Raw,
    recorder::{set_make_recorder, Recorder},
    sequence_no::SequenceNo,
};

pub(crate) use self::config::DumpingConfig;

#[cfg_attr(docsrs, doc(cfg(feature = "unstable")))]
#[stability::unstable]
pub const INTERNAL_CLASS: &str = "internal";

mod config;
mod control;
mod dump;
mod dumper;
mod extract_name;
mod raw;
mod recorder;
mod sequence_no;

/// Dumps a field as `<hidden>`.
pub fn hide<T: Serialize, S: Serializer>(value: &T, serializer: S) -> Result<S::Ok, S::Error> {
    if crate::scope::serde_mode() == crate::scope::SerdeMode::Dumping {
        serializer.serialize_str("<hidden>")
    } else {
        value.serialize(serializer)
    }
}