From 21911153355b4bf9612c38f5ac92562aec02ffd9 Mon Sep 17 00:00:00 2001 From: HampusM Date: Sun, 19 Mar 2023 12:36:01 +0100 Subject: docs: add documentation comments --- macros/Cargo.toml | 3 +++ macros/src/lib.rs | 34 +++++++++++++++++++++++++++++++++- src/lib.rs | 3 ++- 3 files changed, 38 insertions(+), 2 deletions(-) diff --git a/macros/Cargo.toml b/macros/Cargo.toml index 00efccf..818cf8c 100644 --- a/macros/Cargo.toml +++ b/macros/Cargo.toml @@ -11,3 +11,6 @@ quote = "1.0.26" syn = { version = "1.0.109", features = ["full", "printing"] } proc-macro-error = "1.0.4" proc-macro2 = "1.0.52" + +[dev-dependencies] +ridicule = { version = "0.1.0", path = ".." } diff --git a/macros/src/lib.rs b/macros/src/lib.rs index 8106a8c..f11c064 100644 --- a/macros/src/lib.rs +++ b/macros/src/lib.rs @@ -1,4 +1,5 @@ -#![deny(clippy::all, clippy::pedantic)] +//! Macros for Ridicule, a mocking library supporting non-static generics. +#![deny(clippy::all, clippy::pedantic, missing_docs)] use proc_macro::TokenStream; use proc_macro_error::{proc_macro_error, ResultExt}; use quote::{format_ident, quote}; @@ -14,6 +15,37 @@ mod mock_input; mod syn_ext; mod util; +/// Creates a mock. +/// +/// # Examples +/// ``` +/// use ridicule::mock; +/// +/// trait Foo +/// { +/// fn bar(&self, a: A) -> B; +/// } +/// +/// mock! { +/// MockFoo {} +/// +/// impl Foo for MockFoo +/// { +/// fn bar(&self, a: A) -> B; +/// } +/// } +/// +/// fn main() +/// { +/// let mut mock_foo = MockFoo::new(); +/// +/// mock_foo +/// .expect_bar() +/// .returning(|foo, a: u32| format!("Hello {a}")); +/// +/// assert_eq!(mock_foo.bar::(123), "Hello 123"); +/// } +/// ``` #[proc_macro] #[proc_macro_error] pub fn mock(input_stream: TokenStream) -> TokenStream diff --git a/src/lib.rs b/src/lib.rs index 45aea03..3011354 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,4 +1,5 @@ -#![deny(clippy::all, clippy::pedantic)] +//! Mocking library supporting non-static generics. +#![deny(clippy::all, clippy::pedantic, missing_docs)] pub use ridicule_macros::mock; -- cgit v1.2.3-18-g5258