summaryrefslogtreecommitdiffstats
path: root/third_party/rust/bytes-0.4.12/src/debug.rs
blob: f8b830a24110d3e6173679ff51268239f8aaa238 (plain)
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
use std::fmt;

/// Alternative implementation of `fmt::Debug` for byte slice.
///
/// Standard `Debug` implementation for `[u8]` is comma separated
/// list of numbers. Since large amount of byte strings are in fact
/// ASCII strings or contain a lot of ASCII strings (e. g. HTTP),
/// it is convenient to print strings as ASCII when possible.
///
/// This struct wraps `&[u8]` just to override `fmt::Debug`.
///
/// `BsDebug` is not a part of public API of bytes crate.
pub struct BsDebug<'a>(pub &'a [u8]);

impl<'a> fmt::Debug for BsDebug<'a> {
    fn fmt(&self, fmt: &mut fmt::Formatter) -> Result<(), fmt::Error> {
        try!(write!(fmt, "b\""));
        for &c in self.0 {
            // https://doc.rust-lang.org/reference.html#byte-escapes
            if c == b'\n' {
                try!(write!(fmt, "\\n"));
            } else if c == b'\r' {
                try!(write!(fmt, "\\r"));
            } else if c == b'\t' {
                try!(write!(fmt, "\\t"));
            } else if c == b'\\' || c == b'"' {
                try!(write!(fmt, "\\{}", c as char));
            } else if c == b'\0' {
                try!(write!(fmt, "\\0"));
            // ASCII printable
            } else if c >= 0x20 && c < 0x7f {
                try!(write!(fmt, "{}", c as char));
            } else {
                try!(write!(fmt, "\\x{:02x}", c));
            }
        }
        try!(write!(fmt, "\""));
        Ok(())
    }
}