-
Notifications
You must be signed in to change notification settings - Fork 23
Expand file tree
/
Copy pathmeasurement.rs
More file actions
73 lines (67 loc) · 1.67 KB
/
measurement.rs
File metadata and controls
73 lines (67 loc) · 1.67 KB
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
71
72
73
use std::ffi::CString;
use crate::request::{send_client_request, ClientRequest, Value};
#[inline(always)]
pub fn is_instrumented() -> bool {
let valgrind_depth = unsafe {
send_client_request(
0,
&[ClientRequest::RunningOnValgrind as Value, 0, 0, 0, 0, 0],
)
};
valgrind_depth > 0
}
#[inline(always)]
pub fn set_metadata() {
let full_metadata = CString::new(format!(
"Metadata: codspeed-rust {}",
env!("CARGO_PKG_VERSION")
))
.expect("CString::new failed");
unsafe {
send_client_request(
0,
&[
ClientRequest::DumpStatisticsAt as Value,
full_metadata.as_ptr() as Value,
0,
0,
0,
0,
],
);
}
}
#[inline(always)]
pub fn toggle_collect() {
unsafe { send_client_request(0, &[ClientRequest::ToggleCollect as Value, 0, 0, 0, 0, 0]) };
}
#[inline(always)]
pub fn start() {
unsafe {
send_client_request(0, &[ClientRequest::ZeroStatistics as Value, 0, 0, 0, 0, 0]);
send_client_request(
0,
&[ClientRequest::StartInstrumentation as Value, 0, 0, 0, 0, 0],
);
}
}
#[inline(always)]
pub fn stop(name: &CString) {
unsafe {
send_client_request(
0,
&[ClientRequest::StopInstrumentation as Value, 0, 0, 0, 0, 0],
);
send_client_request(
0,
&[
ClientRequest::DumpStatisticsAt as Value,
name.as_ptr() as Value,
0,
0,
0,
0,
],
);
}
}