Add skeletal macro definition to parse Rustdoc comments

This commit is contained in:
yeastplume 2024-10-01 17:34:18 +00:00
parent b7104cd654
commit bb123b5ead
5 changed files with 137 additions and 1 deletions

9
Cargo.lock generated
View file

@ -1520,6 +1520,15 @@ dependencies = [
"uuid",
]
[[package]]
name = "grin_wallet_doc"
version = "5.4.0-alpha.1"
dependencies = [
"proc-macro2 1.0.86",
"quote 1.0.37",
"syn 2.0.77",
]
[[package]]
name = "grin_wallet_impls"
version = "5.4.0-alpha.1"

View file

@ -16,7 +16,7 @@ name = "grin-wallet"
path = "src/bin/grin-wallet.rs"
[workspace]
members = ["api", "config", "controller", "impls", "libwallet", "util"]
members = ["api", "config", "controller", "impls", "libwallet", "util", "doc"]
exclude = ["integration"]
[dependencies]

19
doc/Cargo.toml Normal file
View file

@ -0,0 +1,19 @@
[package]
name = "grin_wallet_doc"
version = "5.4.0-alpha.1"
authors = ["Grin Developers <mimblewimble@lists.launchpad.net>"]
description = "Grin Wallet Documentation Macros"
license = "Apache-2.0"
repository = "https://github.com/mimblewimble/grin-wallet"
keywords = [ "crypto", "grin", "mimblewimble" ]
exclude = ["**/*.grin", "**/*.grin2"]
edition = "2018"
[lib]
proc-macro = true
[dependencies]
proc-macro2 = "1.0"
syn = { version = "2.0", features = ["full", "extra-traits"] }
quote = "1.0"

54
doc/src/lib.rs Normal file
View file

@ -0,0 +1,54 @@
// Copyright 2024 The Grin Developers
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//! proc-macro crate to generate OpenAPI documentation for specified functions
#![deny(non_upper_case_globals)]
#![deny(non_camel_case_types)]
#![deny(non_snake_case)]
#![deny(unused_mut)]
#![warn(missing_docs)]
mod openapi_fn;
use proc_macro::TokenStream;
use proc_macro2::{Group, Ident, Punct, Span, TokenStream as TokenStream2};
use quote::ToTokens;
use syn::{
bracketed,
parse::{Parse, ParseStream},
punctuated::Punctuated,
token::Bracket,
DeriveInput, ExprPath, GenericParam, ItemFn, Lit, LitStr, Member, Token,
};
use openapi_fn::{OpenAPIFn, OpenAPIFnAttr};
#[proc_macro_attribute]
pub fn derive_openapi_fn(input: TokenStream, item: TokenStream) -> TokenStream {
let fn_attribute = syn::parse_macro_input!(input as OpenAPIFnAttr);
let ast_fn = match syn::parse::<ItemFn>(item) {
Ok(ast_fn) => ast_fn,
Err(error) => return error.into_compile_error().into_token_stream().into(),
};
let path = OpenAPIFn::new(fn_attribute, &ast_fn.sig.ident)
.doc_comments(CommentAttributes::from(&ast_fn.attrs).0);
let handler = path::handler::Handler {
path,
handler_fn: &ast_fn,
};
handler.to_token_stream().into()
}

54
doc/src/openapi_fn.rs Normal file
View file

@ -0,0 +1,54 @@
// Copyright 2024 The Grin Developers
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//! Definitions to generate OpenAPI documentation for specified functions
use proc_macro2::Ident;
use syn::{
bracketed,
parse::{Parse, ParseStream},
LitStr,
};
#[derive(Default, Debug)]
pub struct OpenAPIFnAttr {}
impl OpenAPIFnAttr {
pub fn new(params: String) -> Self {
OpenAPIFnAttr {}
}
}
pub struct OpenAPIFn<'p> {
openapi_fn_attr: OpenAPIFnAttr,
fn_ident: &'p Ident,
}
impl<'p> OpenAPIFn<'p> {
pub fn new(openapi_fn_attr: OpenAPIFnAttr, fn_ident: &'p Ident) -> Self {
OpenAPIFn {
openapi_fn_attr,
fn_ident,
}
}
}
impl Parse for OpenAPIFnAttr {
fn parse(input: ParseStream) -> syn::Result<Self> {
let content;
let _ = bracketed!(content in input);
let fn_attr = OpenAPIFnAttr::default();
Ok(fn_attr)
}
}