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
use sentry_core::protocol::{Frame, Stacktrace};
use crate::utils::function_starts_with;
lazy_static::lazy_static! {
static ref WELL_KNOWN_SYS_MODULES: Vec<&'static str> = vec![
"std::",
"core::",
"alloc::",
"backtrace::",
"sentry::",
"sentry_core::",
"sentry_types::",
"__rust_",
"___rust_",
"anyhow::",
"log::",
];
static ref WELL_KNOWN_BORDER_FRAMES: Vec<&'static str> = vec![
"std::panicking::begin_panic",
"core::panicking::panic",
"anyhow::",
"<sentry_log::Logger as log::Log>::log",
];
}
pub fn trim_stacktrace<F>(stacktrace: &mut Stacktrace, f: F)
where
F: Fn(&Frame, &Stacktrace) -> bool,
{
let known_cutoff = stacktrace
.frames
.iter()
.rev()
.position(|frame| match frame.function {
Some(ref func) => is_well_known(func) || f(frame, stacktrace),
None => false,
});
if let Some(cutoff) = known_cutoff {
let trunc = stacktrace.frames.len() - cutoff - 1;
stacktrace.frames.truncate(trunc);
}
}
pub fn is_sys_function(func: &str) -> bool {
WELL_KNOWN_SYS_MODULES
.iter()
.any(|m| function_starts_with(func, m))
}
fn is_well_known(func: &str) -> bool {
WELL_KNOWN_BORDER_FRAMES
.iter()
.any(|m| function_starts_with(func, m))
}