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
74
75
76
//! Debug and tracing subsystem.
//!
//! Linux equivalent: `kernel/trace/`
//!
//! Provides tracing infrastructure, metrics collection, and profiling.
//!
//! # Architecture
//!
//! ```text
//! ┌─────────────────────────────────────────────────────────────┐
//! │ Debug Subsystem │
//! │ │
//! │ ┌─────────────────┐ ┌─────────────────┐ │
//! │ │ Tracing │ │ Metrics │ │
//! │ │ (trace points, │ │ (counters, │ │
//! │ │ events, sinks) │ │ histograms) │ │
//! │ └─────────────────┘ └─────────────────┘ │
//! │ │
//! │ ┌─────────────────┐ │
//! │ │ Profiler │ │
//! │ │ (RAII guards, │ │
//! │ │ scope timing) │ │
//! │ └─────────────────┘ │
//! │ │
//! └─────────────────────────────────────────────────────────────┘
//! ```
//!
//! # Components
//!
//! - [`trace`] - Trace points and event emission
//! - [`metrics`] - Counters and histograms for performance monitoring
//! - [`profiler`] - RAII-based scope timing
//!
//! # Example
//!
//! ```ignore
//! use reovim_kernel::debug::{TracePoint, ProfileGuard, metrics};
//!
//! // Define a trace point
//! static TP_BUFFER_OP: TracePoint = TracePoint::new("buffer_op", "mm");
//!
//! fn process_buffer() {
//! // Profile the function
//! let _profile = ProfileGuard::new("process_buffer");
//!
//! // Emit trace event
//! if TP_BUFFER_OP.is_enabled() {
//! // trace event...
//! }
//!
//! // Increment a counter (returns Arc<Counter>)
//! metrics().counter("buffer_ops").increment();
//! }
//! ```
// Re-export tracing types
pub use ;
// Re-export metrics types
pub use ;
// Re-export profiler types
pub use ;