mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-26 12:26:12 +00:00
add macros.rs
; conditional logging macros
This commit is contained in:
parent
78f87e7b37
commit
59f936593a
3 changed files with 166 additions and 6 deletions
|
@ -9,6 +9,7 @@ repository = "https://github.com/Cuprate/cuprate/tree/main/database"
|
||||||
keywords = ["cuprate", "database"]
|
keywords = ["cuprate", "database"]
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
|
# default = ["heed", "redb", "service", "tracing"]
|
||||||
default = ["heed", "redb", "service"]
|
default = ["heed", "redb", "service"]
|
||||||
# default = ["redb", "service"]
|
# default = ["redb", "service"]
|
||||||
# default = ["redb-memory", "service"]
|
# default = ["redb-memory", "service"]
|
||||||
|
@ -33,7 +34,6 @@ monero-serai = { workspace = true, features = ["std"] }
|
||||||
paste = { workspace = true }
|
paste = { workspace = true }
|
||||||
page_size = { version = "0.6.0" } # Needed for database resizes, they must be a multiple of the OS page size.
|
page_size = { version = "0.6.0" } # Needed for database resizes, they must be a multiple of the OS page size.
|
||||||
thiserror = { workspace = true }
|
thiserror = { workspace = true }
|
||||||
tracing = { workspace = true }
|
|
||||||
|
|
||||||
# `service` feature.
|
# `service` feature.
|
||||||
crossbeam = { workspace = true, features = ["std"], optional = true }
|
crossbeam = { workspace = true, features = ["std"], optional = true }
|
||||||
|
@ -48,6 +48,7 @@ rayon = { workspace = true, optional = true }
|
||||||
heed = { version = "0.20.0", features = ["read-txn-no-tls"], optional = true }
|
heed = { version = "0.20.0", features = ["read-txn-no-tls"], optional = true }
|
||||||
redb = { version = "2.1.0", optional = true }
|
redb = { version = "2.1.0", optional = true }
|
||||||
serde = { workspace = true, optional = true }
|
serde = { workspace = true, optional = true }
|
||||||
|
tracing = { workspace = true, optional = true }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
bytemuck = { version = "1.14.3", features = ["must_cast", "derive", "min_const_generics", "extern_crate_alloc"] }
|
bytemuck = { version = "1.14.3", features = ["must_cast", "derive", "min_const_generics", "extern_crate_alloc"] }
|
||||||
|
|
|
@ -58,6 +58,7 @@
|
||||||
//!
|
//!
|
||||||
//! `ConcreteEnv` invariants you can rely on:
|
//! `ConcreteEnv` invariants you can rely on:
|
||||||
//! - It implements [`Env`]
|
//! - It implements [`Env`]
|
||||||
|
//! - It implements [`Debug`]
|
||||||
//! - Upon [`Drop::drop`], all database data will sync to disk
|
//! - Upon [`Drop::drop`], all database data will sync to disk
|
||||||
//!
|
//!
|
||||||
//! Note that `ConcreteEnv` itself is not a clonable type,
|
//! Note that `ConcreteEnv` itself is not a clonable type,
|
||||||
|
@ -78,8 +79,9 @@
|
||||||
//!
|
//!
|
||||||
//! The default is `heed`.
|
//! The default is `heed`.
|
||||||
//!
|
//!
|
||||||
//! `tracing` is always enabled and cannot be disabled via feature-flag.
|
//! Logging with [`tracing`](https://docs.rs/tracing)
|
||||||
//! <!-- FIXME: tracing should be behind a feature flag -->
|
//! can be enabled with the `tracing` feature flag,
|
||||||
|
//! this is disabled by default.
|
||||||
//!
|
//!
|
||||||
//! # Invariants when not using `service`
|
//! # Invariants when not using `service`
|
||||||
//! `cuprate_database` can be used without the `service` feature enabled but
|
//! `cuprate_database` can be used without the `service` feature enabled but
|
||||||
|
@ -274,6 +276,8 @@ pub mod resize;
|
||||||
mod key;
|
mod key;
|
||||||
pub use key::Key;
|
pub use key::Key;
|
||||||
|
|
||||||
|
mod macros;
|
||||||
|
|
||||||
mod storable;
|
mod storable;
|
||||||
pub use storable::{Storable, StorableBytes, StorableVec};
|
pub use storable::{Storable, StorableBytes, StorableVec};
|
||||||
|
|
||||||
|
|
155
database/src/macros.rs
Normal file
155
database/src/macros.rs
Normal file
|
@ -0,0 +1,155 @@
|
||||||
|
//! General macros.
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------- Logging
|
||||||
|
// The below macros/types/functions allow for conditional
|
||||||
|
// logging with `tracing` depending on if the feature flag
|
||||||
|
// is enabled or not.
|
||||||
|
//
|
||||||
|
// These macros (e.g. [`info2`]) are used instead of the tracing macro directly.
|
||||||
|
// #[tracing::instrument] will still need to be handled by us by using `#[cfg_attr]`.
|
||||||
|
|
||||||
|
/// Dummy structure with methods that copy the ones on [`tracing::Span`].
|
||||||
|
///
|
||||||
|
/// This is used when "tracing" is disabled such that span functions:
|
||||||
|
/// ```rust,ignore
|
||||||
|
/// let span: DummySpan = info_span2!("span");
|
||||||
|
/// let _guard = span.enter();
|
||||||
|
/// ```
|
||||||
|
/// will still work as this struct will just be returned, then
|
||||||
|
/// [`DummySpan::enter`] will be called instead, which is just a dummy method.
|
||||||
|
pub(crate) struct DummySpan;
|
||||||
|
|
||||||
|
impl DummySpan {
|
||||||
|
/// Emulates [`tracing::Span::enter`].
|
||||||
|
#[inline]
|
||||||
|
pub(crate) const fn enter(&self) -> &Self {
|
||||||
|
self
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Drop impl is needed to satisfy clippy.
|
||||||
|
impl Drop for DummySpan {
|
||||||
|
#[inline]
|
||||||
|
fn drop(&mut self) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// [`tracing::warn_span`].
|
||||||
|
macro_rules! warn_span2 {
|
||||||
|
($($token:tt)*) => {{
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(feature = "tracing")] {
|
||||||
|
tracing::warn_span!($($token)*)
|
||||||
|
} else {
|
||||||
|
$crate::macros::DummySpan
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
pub(crate) use warn_span2;
|
||||||
|
|
||||||
|
/// [`tracing::warn`].
|
||||||
|
macro_rules! warn2 {
|
||||||
|
($($token:tt)*) => {
|
||||||
|
#[cfg(feature = "tracing")]
|
||||||
|
tracing::warn!($($token)*)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
pub(crate) use warn2;
|
||||||
|
|
||||||
|
/// [`tracing::trace_span`].
|
||||||
|
macro_rules! trace_span2 {
|
||||||
|
($($token:tt)*) => {{
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(feature = "tracing")] {
|
||||||
|
tracing::trace_span!($($token)*)
|
||||||
|
} else {
|
||||||
|
$crate::macros::DummySpan
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
pub(crate) use trace_span2;
|
||||||
|
|
||||||
|
/// [`tracing::trace`].
|
||||||
|
macro_rules! trace2 {
|
||||||
|
($($token:tt)*) => {
|
||||||
|
#[cfg(feature = "tracing")]
|
||||||
|
tracing::trace!($($token)*)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
pub(crate) use trace2;
|
||||||
|
|
||||||
|
/// [`tracing::info_span`].
|
||||||
|
macro_rules! info_span2 {
|
||||||
|
($($token:tt)*) => {{
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(feature = "tracing")] {
|
||||||
|
tracing::info_span!($($token)*)
|
||||||
|
} else {
|
||||||
|
$crate::macros::DummySpan
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
pub(crate) use info_span2;
|
||||||
|
|
||||||
|
/// [`tracing::info`].
|
||||||
|
macro_rules! info2 {
|
||||||
|
($($token:tt)*) => {
|
||||||
|
#[cfg(feature = "tracing")]
|
||||||
|
tracing::info!($($token)*)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
pub(crate) use info2;
|
||||||
|
|
||||||
|
/// [`tracing::error_span`].
|
||||||
|
macro_rules! error_span2 {
|
||||||
|
($($token:tt)*) => {{
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(feature = "tracing")] {
|
||||||
|
tracing::error_span!($($token)*)
|
||||||
|
} else {
|
||||||
|
$crate::macros::DummySpan
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
pub(crate) use error_span2;
|
||||||
|
|
||||||
|
/// [`tracing::error`].
|
||||||
|
macro_rules! error2 {
|
||||||
|
($($token:tt)*) => {
|
||||||
|
#[cfg(feature = "tracing")]
|
||||||
|
tracing::error!($($token)*)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
pub(crate) use error2;
|
||||||
|
|
||||||
|
/// [`tracing::debug_span`].
|
||||||
|
macro_rules! debug_span2 {
|
||||||
|
($($token:tt)*) => {{
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(feature = "tracing")] {
|
||||||
|
tracing::debug_span!($($token)*)
|
||||||
|
} else {
|
||||||
|
$crate::macros::DummySpan
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
pub(crate) use debug_span2;
|
||||||
|
|
||||||
|
/// [`tracing::debug`].
|
||||||
|
macro_rules! debug2 {
|
||||||
|
($($token:tt)*) => {
|
||||||
|
#[cfg(feature = "tracing")]
|
||||||
|
tracing::debug!($($token)*)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
pub(crate) use debug2;
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------- Tests
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
// use super::*;
|
||||||
|
}
|
Loading…
Reference in a new issue