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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
pub use *;
pub use *;
/// Convert a byte slice into a string.
/// Includes printable ASCII characters as-is.
/// Converts non-printable or non-ASCII characters to strings like "\n" and "\x19".
///
/// Uses
/// [`core::ascii::escape_default`](https://doc.rust-lang.org/core/ascii/fn.escape_default.html)
/// internally to escape each byte.
///
/// This function is useful for comparing byte slices in tests.
///
/// # Example
/// ```
/// use applin::util::escape_ascii;
/// assert_eq!("abc", escape_ascii(b"abc"));
/// assert_eq!("abc\\n", escape_ascii(b"abc\n"));
/// assert_eq!(
/// "Euro sign: \\xe2\\x82\\xac",
/// escape_ascii("Euro sign: \u{20AC}".as_bytes())
/// );
/// assert_eq!("\\x01\\x02\\x03", escape_ascii(&[1, 2, 3]));
/// ```
/// Convert a byte slice into a string of limited length.
/// Includes printable ASCII characters as-is.
/// Converts non-printable or non-ASCII characters to strings like "\n" and "\x19".
///
/// Uses
/// [`core::ascii::escape_default`](https://doc.rust-lang.org/core/ascii/fn.escape_default.html)
/// internally to escape each byte.
///
/// This function is useful for printing byte slices to logs.
///
/// # Example
/// ```
/// use applin::util::escape_and_elide;
/// assert_eq!("abc", escape_and_elide(b"abc", 5));
/// assert_eq!("ab...", escape_and_elide(b"abcdefg", 5));
/// assert_eq!("abc\\n", escape_and_elide(b"abc\n", 5));
/// assert_eq!(
/// "Euro sign: \\xe2\\x82\\xac",
/// escape_and_elide("Euro sign: \u{20AC}".as_bytes(), 20)
/// );
/// assert_eq!("\\x01\\x02\\x03", escape_and_elide(&[1, 2, 3], 10));
/// ```