Skip to content

Commit

Permalink
rename value::Visit to value::Visitor
Browse files Browse the repository at this point in the history
  • Loading branch information
KodrAus committed Jan 28, 2024
1 parent dbc0a3f commit fdc1c6e
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 12 deletions.
17 changes: 13 additions & 4 deletions src/kv/mod.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
//! **UNSTABLE:** Structured key-value pairs.
//! **UNSTABLE:** Structured logging.
//!
//! This module is unstable and breaking changes may be made
//! at any time. See [the tracking issue](https://github.com/rust-lang-nursery/log/issues/328)
Expand Down Expand Up @@ -62,11 +62,20 @@
//! ```
//!
//! Visitors on values are lightweight and suitable for detecting primitive types.
//! To serialize a value, you can also use either `serde` or `sval`. If you're
//! in a no-std environment, you can use `sval`. In other cases, you can use `serde`.
//! To serialize a value, you can also use either `serde` or `sval`:
//!
//! ```
//! ..
//! ```
//!
//! If you're in a no-std environment, you can use `sval`. In other cases, you can use `serde`.
//!
//! Values can also always be formatted using the standard `Debug` and `Display`
//! traits.
//! traits:
//!
//! ```
//! ..
//! ```
mod error;
mod key;
Expand Down
3 changes: 3 additions & 0 deletions src/kv/source.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
//! Sources for user-defined attributes.
//!
//! This module defines the [`Source`] type and supporting APIs for
//! working with collections of attributes.
use crate::kv::{Error, Key, ToKey, ToValue, Value};
use std::fmt;
Expand Down
27 changes: 19 additions & 8 deletions src/kv/value.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
//! Structured values.
//!
//! This module defines the [`Value`] type and supporting APIs for
//! capturing and serializing them.
use std::fmt;

Expand Down Expand Up @@ -89,6 +92,14 @@ impl<'v> ToValue for Value<'v> {
/// For more complex types one of the following traits can be used:
/// * [`sval::Value`], requires the `kv_unstable_sval` feature.
/// * [`serde::Serialize`], requires the `kv_unstable_serde` feature.
///
/// You don't need a [`Visit`] to serialize values.
///
/// A value can always be serialized using any supported framework, regardless
/// of how it was captured. If, for example, a value was captured using its
/// `Display` implementation, it will serialize as a string. If it was captured
/// as a struct using its `serde::Serialize`, it will also serialize as a struct
/// through `sval`, or be formatted using a `Debug`-compatible representation.
pub struct Value<'v> {
inner: ValueBag<'v>,
}
Expand Down Expand Up @@ -180,12 +191,12 @@ impl<'v> Value<'v> {
///
/// When the `kv_unstable_serde` or `kv_unstable_sval` features are enabled, you can also
/// serialize a value using its `Serialize` or `Value` implementation.
pub fn visit(&self, visitor: impl Visit<'v>) -> Result<(), Error> {
pub fn visit(&self, visitor: impl Visitor<'v>) -> Result<(), Error> {
struct Visitor<V>(V);

impl<'v, V> value_bag::visit::Visit<'v> for Visitor<V>
impl<'v, V> value_bag::visit::Visitor<'v> for Visitor<V>
where
V: Visit<'v>,
V: Visitor<'v>,
{
fn visit_any(&mut self, value: ValueBag) -> Result<(), value_bag::Error> {
self.0
Expand Down Expand Up @@ -521,7 +532,7 @@ mod std_support {
/// Also see [`Value`'s documentation on seralization].
///
/// [`Value`'s documentation on seralization]: Value#serialization
pub trait Visit<'v> {
pub trait Visitor<'v> {
/// Visit a `Value`.
///
/// This is the only required method on `Visit` and acts as a fallback for any
Expand Down Expand Up @@ -592,9 +603,9 @@ pub trait Visit<'v> {
}
}

impl<'a, 'v, T: ?Sized> Visit<'v> for &'a mut T
impl<'a, 'v, T: ?Sized> Visitor<'v> for &'a mut T
where
T: Visit<'v>,
T: Visitor<'v>,
{
fn visit_any(&mut self, value: Value) -> Result<(), Error> {
(**self).visit_any(value)
Expand Down Expand Up @@ -821,7 +832,7 @@ pub(crate) mod tests {
fn test_visit_integer() {
struct Extract(Option<u64>);

impl<'v> Visit<'v> for Extract {
impl<'v> Visitor<'v> for Extract {
fn visit_any(&mut self, value: Value) -> Result<(), Error> {
unimplemented!("unexpected value: {value:?}")
}
Expand All @@ -843,7 +854,7 @@ pub(crate) mod tests {
fn test_visit_borrowed_str() {
struct Extract<'v>(Option<&'v str>);

impl<'v> Visit<'v> for Extract<'v> {
impl<'v> Visitor<'v> for Extract<'v> {
fn visit_any(&mut self, value: Value) -> Result<(), Error> {
unimplemented!("unexpected value: {value:?}")
}
Expand Down
2 changes: 2 additions & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,8 @@
//! # #[cfg(not(feature = "kv_unstable_serde"))]
//! # fn main() {}
//! ```
//!
//! See the [`kv`] module documentation for more details.
//!
//! # Available logging implementations
//!
Expand Down

0 comments on commit fdc1c6e

Please sign in to comment.