From 5009bf3cf4bbe489dfa5d8be949c16a93f256626 Mon Sep 17 00:00:00 2001 From: Justus Adam Date: Wed, 10 Jan 2024 12:23:25 -0800 Subject: [PATCH] Add docs for `visit` option Summary: I noticed that the docs for the `visit` option were missing so I provided some. X-link: https://github.com/facebookexperimental/allocative/pull/9 Reviewed By: JakobDegen Differential Revision: D51388673 Pulled By: stepancheg fbshipit-source-id: 35fad2d9ef107abd8a34afb560f66b831699910b --- allocative/allocative/src/allocative_trait.rs | 37 +++++++++++++++++++ 1 file changed, 37 insertions(+) diff --git a/allocative/allocative/src/allocative_trait.rs b/allocative/allocative/src/allocative_trait.rs index 1d9ff0fc3..fe83aad43 100644 --- a/allocative/allocative/src/allocative_trait.rs +++ b/allocative/allocative/src/allocative_trait.rs @@ -98,6 +98,43 @@ use crate::Visitor; /// ... /// } /// ``` +/// +/// ## `#[allocative(visit = ...)]` +/// +/// This annotation is used to provide a custom visit method for a given field. This +/// is especially useful if the type of the field does not implement `Allocative`. +/// +/// The annotation takes the path to a method with a signature `for<'a, 'b>(&T, &'a +/// mut allocative::Visitor<'b>)` where `T` is the type of the field. The function +/// you provide is basically the same as if you implemented [`Allocative::visit`]. +/// +/// As an example +/// +/// ``` +/// use allocative::Allocative; +/// use allocative::Key; +/// use allocative::Visitor; +/// // use third_party_lib::Unsupported; +/// # struct Unsupported(T); +/// # impl Unsupported { +/// # fn iter_elems(&self) -> &[T] { &[] } +/// # } +/// +/// #[derive(Allocative)] +/// struct Bar { +/// #[allocative(visit = visit_unsupported)] +/// unsupported: Unsupported, +/// } +/// +/// fn visit_unsupported<'a, 'b>(u: &Unsupported, visitor: &'a mut Visitor<'b>) { +/// const ELEM_KEY: Key = Key::new("elements"); +/// let mut visitor = visitor.enter_self(u); +/// for element in u.iter_elems() { +/// visitor.visit_field(ELEM_KEY, element); +/// } +/// visitor.exit() +/// } +/// ``` pub trait Allocative { fn visit<'a, 'b: 'a>(&self, visitor: &'a mut Visitor<'b>); }