risingwave_hummock_trace/lib.rs
1// Copyright 2025 RisingWave Labs
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15#![feature(cursor_split)]
16#![feature(trait_alias)]
17#![feature(coroutines)]
18
19mod collector;
20mod error;
21mod opts;
22mod read;
23mod record;
24mod replay;
25mod write;
26use std::future::Future;
27
28pub use collector::*;
29pub use error::*;
30pub use opts::*;
31pub use read::*;
32pub use record::*;
33pub use replay::*;
34pub(crate) use write::*;
35
36pub fn hummock_trace_scope<F: Future>(f: F) -> impl Future<Output = F::Output> {
37 let id = CONCURRENT_ID.next();
38 LOCAL_ID.scope(id, f)
39}