macro docs, fixes

This commit is contained in:
hinto.janai 2024-06-16 21:06:54 -04:00
parent 5cf2c875d7
commit f69b830f89
No known key found for this signature in database
GPG key ID: D47CE05FA175A499
3 changed files with 147 additions and 95 deletions

View file

@ -3,10 +3,16 @@
//! <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/daemon_messages.h>. //! <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/daemon_messages.h>.
//---------------------------------------------------------------------------------------------------- Import //---------------------------------------------------------------------------------------------------- Import
use crate::macros::define_monero_rpc_struct; use crate::macros::define_request_and_response;
//---------------------------------------------------------------------------------------------------- Struct definitions //---------------------------------------------------------------------------------------------------- Struct definitions
define_monero_rpc_struct! { // This generates 2 structs:
//
// - `GetBlockCountRequest`
// - `GetBlockCountResponse`
//
// with some interconnected documentation.
define_request_and_response! {
// The markdown tag for Monero RPC documentation. Not necessarily the endpoint. // The markdown tag for Monero RPC documentation. Not necessarily the endpoint.
get_block_count, get_block_count,
@ -14,35 +20,36 @@ define_monero_rpc_struct! {
// the Monero codebase in the `rpc/` directory, followed by the specific lines. // the Monero codebase in the `rpc/` directory, followed by the specific lines.
cc73fe71162d564ffda8e549b79a350bca53c454 => core_rpc_server_commands_defs.h => 919..=933, cc73fe71162d564ffda8e549b79a350bca53c454 => core_rpc_server_commands_defs.h => 919..=933,
// The actual type definitions. // The base type name.
// If there are any additional attributes (`/// docs` or `#[derive]`s) GetBlockCount,
// for the struct, they go here, e.g.:
// #[derive(MyCustomDerive)]
GetBlockCount, // The type name.
Request /* The request type */ { // The request type.
Request {
// This request type requires no inputs, // This request type requires no inputs,
// so it is left empty. Leaving this empty // so it is left empty. Leaving this empty
// will cause the macro to generate a type // will cause the macro to generate a type
// alias to `()` instead of a `struct`. // alias to `()` instead of a `struct`.
}, },
// The response type.
//
// If there are any additional attributes (`/// docs` or `#[derive]`s)
// for the struct, they go here, e.g.:
#[derive(Copy)] #[derive(Copy)]
Response /* The response type */ { Response {
// Within the `{}` is an infinite matching pattern of: // Within the `{}` is an infinite matching pattern of:
// ``` // ```
// $ATTRIBUTES // $ATTRIBUTES
// $FIELD_NAME: $FIELD_TYPE, // $FIELD_NAME: $FIELD_TYPE,
// ``` // ```
// The struct generated and all fields are `pub`. // The struct generated and all fields are `pub`.
count: u64, count: u64,
status: crate::Status, status: crate::Status,
untrusted: bool, untrusted: bool,
} }
} }
define_monero_rpc_struct! { define_request_and_response! {
on_get_block_hash, on_get_block_hash,
cc73fe71162d564ffda8e549b79a350bca53c454 => cc73fe71162d564ffda8e549b79a350bca53c454 =>
core_rpc_server_commands_defs.h => 935..=939, core_rpc_server_commands_defs.h => 935..=939,
@ -56,7 +63,7 @@ define_monero_rpc_struct! {
} }
} }
define_monero_rpc_struct! { define_request_and_response! {
get_block_template, get_block_template,
cc73fe71162d564ffda8e549b79a350bca53c454 => cc73fe71162d564ffda8e549b79a350bca53c454 =>
core_rpc_server_commands_defs.h => 943..=994, core_rpc_server_commands_defs.h => 943..=994,

View file

@ -1,16 +1,46 @@
//! Macros. //! Macros.
//!
//! These generate repetitive documentation, tests, etc.
//---------------------------------------------------------------------------------------------------- Struct definition //---------------------------------------------------------------------------------------------------- Struct definition
/// A template for generating a `struct` with a bunch of information filled out. /// A template for generating 2 `struct`s with a bunch of information filled out.
///
/// These are the RPC request and response `struct`s.
/// ///
/// It's best to see the output of this macro via the documentation /// It's best to see the output of this macro via the documentation
/// of the generated structs via `cargo doc`s to see which parts /// of the generated structs via `cargo doc`s to see which parts
/// generate which docs. /// generate which docs.
/// ///
/// See [`crate::json::GetHeight`] for example usage. /// See the [`crate::json`] module for example usage.
macro_rules! define_monero_rpc_struct { ///
/// # Macro internals
/// This macro has 2 branches with almost the same output:
/// 1. An empty `Request` type
/// 2. An `Request` type with fields
///
/// The first branch is the same as the second with the exception
/// that if the caller of this macro provides no fields, it will
/// generate:
/// ```
/// pub type Request = ();
/// ```
/// instead of:
/// ```
/// pub struct Request {/* fields */}
/// ```
///
/// This is because having a bunch of types that are all empty structs
/// means they are not compatible and it makes it cumbersome for end-users.
/// Really, they semantically are empty types, so `()` is used.
///
/// Again, other than this, the 2 branches do (should) not differ.
///
/// FIXME: there's probably a less painful way to branch here on input
/// without having to duplicate 80% of the macro. Sub-macros were attempted
/// but they ended up unreadable. So for now, make sure to fix the other
/// branch as well when making changes. The only de-duplicated part is
/// the doc generation with [`define_request_and_response_doc`].
macro_rules! define_request_and_response {
//------------------------------------------------------------------------------
// This version of the macro expects a `Request` type with no fields, i.e. `Request {}`.
( (
// The markdown tag for Monero RPC documentation. Not necessarily the endpoint. // The markdown tag for Monero RPC documentation. Not necessarily the endpoint.
$monero_daemon_rpc_doc_link:ident, $monero_daemon_rpc_doc_link:ident,
@ -23,10 +53,13 @@ macro_rules! define_monero_rpc_struct {
$monero_code_line_start:literal..= $monero_code_line_start:literal..=
$monero_code_line_end:literal, $monero_code_line_end:literal,
// The actual request `struct` name and any doc comments, derives, etc. // The base `struct` name.
$type_name:ident, $type_name:ident,
// The empty unit request type.
Request {}, Request {},
// The actual `struct` name and any doc comments, derives, etc.
// The response type (and any doc comments, derives, etc).
$( #[$response_type_attr:meta] )* $( #[$response_type_attr:meta] )*
Response { Response {
// And any fields. // And any fields.
@ -36,24 +69,15 @@ macro_rules! define_monero_rpc_struct {
)* )*
} }
) => { paste::paste! { ) => { paste::paste! {
#[doc = concat!( #[doc = $crate::macros::define_request_and_response_doc!(
"", "response",
"[Definition](", $monero_daemon_rpc_doc_link,
"https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/", $monero_code_commit,
stringify!($monero_code_filename), $monero_code_filename,
".", $monero_code_filename_extension,
stringify!($monero_code_filename_extension), $monero_code_line_start,
"#L", $monero_code_line_end,
stringify!($monero_code_line_start), [<$type_name Request>],
"-L",
stringify!($monero_code_line_end),
"), [documentation](",
"https://www.getmonero.org/resources/developer-guides/daemon-rpc.html",
"#",
stringify!($monero_daemon_rpc_doc_link),
"), [response](",
stringify!([<$type_name Response>]),
")."
)] )]
/// ///
/// This request has no inputs. /// This request has no inputs.
@ -64,26 +88,15 @@ macro_rules! define_monero_rpc_struct {
#[derive(serde::Serialize, serde::Deserialize)] #[derive(serde::Serialize, serde::Deserialize)]
#[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)] #[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
$( #[$response_type_attr] )* $( #[$response_type_attr] )*
#[doc = concat!( #[doc = $crate::macros::define_request_and_response_doc!(
"", "request",
"[Definition](", $monero_daemon_rpc_doc_link,
"https://github.com/monero-project/monero/blob/", $monero_code_commit,
stringify!($monero_code_commit), $monero_code_filename,
"/src/rpc/", $monero_code_filename_extension,
stringify!($monero_code_filename), $monero_code_line_start,
".", $monero_code_line_end,
stringify!($monero_code_filename_extension), [<$type_name Response>],
"#L",
stringify!($monero_code_line_start),
"-L",
stringify!($monero_code_line_end),
"), [documentation](",
"https://www.getmonero.org/resources/developer-guides/daemon-rpc.html",
"#",
stringify!($monero_daemon_rpc_doc_link),
"), [request](",
stringify!([<$type_name Request>]),
")."
)] )]
pub struct [<$type_name Response>] { pub struct [<$type_name Response>] {
$( $(
@ -92,6 +105,9 @@ macro_rules! define_monero_rpc_struct {
)* )*
} }
}}; }};
//------------------------------------------------------------------------------
// This version of the macro expects a `Request` type with fields.
( (
// The markdown tag for Monero RPC documentation. Not necessarily the endpoint. // The markdown tag for Monero RPC documentation. Not necessarily the endpoint.
$monero_daemon_rpc_doc_link:ident, $monero_daemon_rpc_doc_link:ident,
@ -104,8 +120,10 @@ macro_rules! define_monero_rpc_struct {
$monero_code_line_start:literal..= $monero_code_line_start:literal..=
$monero_code_line_end:literal, $monero_code_line_end:literal,
// The actual request `struct` name and any doc comments, derives, etc. // The base `struct` name.
$type_name:ident, $type_name:ident,
// The request type (and any doc comments, derives, etc).
$( #[$request_type_attr:meta] )* $( #[$request_type_attr:meta] )*
Request { Request {
// And any fields. // And any fields.
@ -115,7 +133,7 @@ macro_rules! define_monero_rpc_struct {
)* )*
}, },
// The actual `struct` name and any doc comments, derives, etc. // The response type (and any doc comments, derives, etc).
$( #[$response_type_attr:meta] )* $( #[$response_type_attr:meta] )*
Response { Response {
// And any fields. // And any fields.
@ -130,26 +148,15 @@ macro_rules! define_monero_rpc_struct {
#[derive(serde::Serialize, serde::Deserialize)] #[derive(serde::Serialize, serde::Deserialize)]
#[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)] #[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
$( #[$request_type_attr] )* $( #[$request_type_attr] )*
#[doc = concat!( #[doc = $crate::macros::define_request_and_response_doc!(
"", "response",
"[Definition](", $monero_daemon_rpc_doc_link,
"https://github.com/monero-project/monero/blob/", $monero_code_commit,
stringify!($monero_code_commit), $monero_code_filename,
"/src/rpc/", $monero_code_filename_extension,
stringify!($monero_code_filename), $monero_code_line_start,
".", $monero_code_line_end,
stringify!($monero_code_filename_extension), [<$type_name Request>],
"#L",
stringify!($monero_code_line_start),
"-L",
stringify!($monero_code_line_end),
"), [documentation](",
"https://www.getmonero.org/resources/developer-guides/daemon-rpc.html",
"#",
stringify!($monero_daemon_rpc_doc_link),
"), [response](",
stringify!([<$type_name Response>]),
")."
)] )]
pub struct [<$type_name Request>] { pub struct [<$type_name Request>] {
$( $(
@ -163,7 +170,51 @@ macro_rules! define_monero_rpc_struct {
#[derive(serde::Serialize, serde::Deserialize)] #[derive(serde::Serialize, serde::Deserialize)]
#[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)] #[derive(Clone, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
$( #[$response_type_attr] )* $( #[$response_type_attr] )*
#[doc = concat!( #[doc = $crate::macros::define_request_and_response_doc!(
"request",
$monero_daemon_rpc_doc_link,
$monero_code_commit,
$monero_code_filename,
$monero_code_filename_extension,
$monero_code_line_start,
$monero_code_line_end,
[<$type_name Response>],
)]
pub struct [<$type_name Response>] {
$(
$( #[$response_field_attr] )*
pub $response_field: $response_field_type,
)*
}
}};
}
pub(crate) use define_request_and_response;
/// Generate documentation for the types generated
/// by the [`define_request_and_response`] macro.
///
/// See it for more info on inputs.
macro_rules! define_request_and_response_doc {
(
// This labels the last `[request]` or `[response]`
// hyperlink in documentation. Input is either:
// - "request"
// - "response"
//
// Remember this is linking to the _other_ type,
// so if defining a `Request` type, input should
// be "response".
$request_or_response:literal,
$monero_daemon_rpc_doc_link:ident,
$monero_code_commit:ident,
$monero_code_filename:ident,
$monero_code_filename_extension:ident,
$monero_code_line_start:literal,
$monero_code_line_end:literal,
$type_name:ident,
) => {
concat!(
"", "",
"[Definition](", "[Definition](",
"https://github.com/monero-project/monero/blob/", "https://github.com/monero-project/monero/blob/",
@ -180,18 +231,12 @@ macro_rules! define_monero_rpc_struct {
"https://www.getmonero.org/resources/developer-guides/daemon-rpc.html", "https://www.getmonero.org/resources/developer-guides/daemon-rpc.html",
"#", "#",
stringify!($monero_daemon_rpc_doc_link), stringify!($monero_daemon_rpc_doc_link),
"), [request](", "), [",
stringify!([<$type_name Request>]), $request_or_response,
"](",
stringify!($type_name),
")." ")."
)] )
pub struct [<$type_name Response>] { };
$(
$( #[$response_field_attr] )*
pub $response_field: $response_field_type,
)*
} }
}}; pub(crate) use define_request_and_response_doc;
}
pub(crate) use define_monero_rpc_struct;
//---------------------------------------------------------------------------------------------------- Documentation macros

View file

@ -3,10 +3,10 @@
//! <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/daemon_messages.h>. //! <https://github.com/monero-project/monero/blob/cc73fe71162d564ffda8e549b79a350bca53c454/src/rpc/daemon_messages.h>.
//---------------------------------------------------------------------------------------------------- Import //---------------------------------------------------------------------------------------------------- Import
use crate::macros::define_monero_rpc_struct; use crate::macros::define_request_and_response;
//---------------------------------------------------------------------------------------------------- TODO //---------------------------------------------------------------------------------------------------- TODO
define_monero_rpc_struct! { define_request_and_response! {
save_bc, save_bc,
cc73fe71162d564ffda8e549b79a350bca53c454 => cc73fe71162d564ffda8e549b79a350bca53c454 =>
core_rpc_server_commands_defs.h => 898..=916, core_rpc_server_commands_defs.h => 898..=916,