mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-07 03:19:43 +00:00
macro docs, fixes
This commit is contained in:
parent
5cf2c875d7
commit
f69b830f89
3 changed files with 147 additions and 95 deletions
|
@ -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,
|
||||||
|
|
|
@ -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_monero_rpc_struct;
|
pub(crate) use define_request_and_response_doc;
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------- Documentation macros
|
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in a new issue