-
Notifications
You must be signed in to change notification settings - Fork 257
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use scale-typegen
as a backend for the codegen
#1260
Use scale-typegen
as a backend for the codegen
#1260
Conversation
7db70a1
to
03591a6
Compare
* lightclient: Close wasm socket while dropping from connecting state Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Construct one time only closures Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * testing: Enable console logs for lightclient WASM testing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Separate wakes and check connectivity on poll_read Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Close the socket depending on internal state Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Revert "lightclient: Separate wakes and check connectivity on poll_read" This reverts commit 8660940. * lightclient: Return pending if socket is opening from poll_read Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Close the socket on `poll_close` Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Reset closures on Drop to avoid recursive invokation Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Close the socket if not already closing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> --------- Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
* cli: Add chainSpec command Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli/chainSpec: Move to dedicated module Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Compute the state root hash Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Remove code substitutes Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * artifacts: Update polkadot.json Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * scripts: Generate the chain spec Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Remove testing artifacts Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Fix clippy Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Apply rustfmt Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Introduce feature flag for smoldot dependency Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * cli: Rename chain-spec to chain-spec-pruning Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * scripts: Update chain-spec command Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> --------- Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
* update crypto dependencies, adjust keypair * add scale_info::TypeInfo derive in some places * add multi signature derive
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems that the changes have not affected the aliases and other code generations (except for additional docs, which should be fine). Just to double check, is this file generated from the latest polkadot with all the code changes included right? 🤔
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, I ran the polkadot.rs
file generation command after implementing all the code changes in this PR. :)
@@ -167,8 +167,16 @@ impl CodegenBuilder { | |||
&mut self, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We'd need to adjust the docs of this function a bit, the warning section specifically
@@ -181,11 +189,19 @@ impl CodegenBuilder { | |||
&mut self, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same doc adjustment here, since we now have the recursive parameter
@@ -168,7 +168,8 @@ fn codegen( | |||
.map_err(|e| eyre!("Cannot parse derive for type {ty_str}: {e}"))?; | |||
let derive = syn::parse_str(&derive) | |||
.map_err(|e| eyre!("Cannot parse derive for type {ty_str}: {e}"))?; | |||
codegen.add_derives_for_type(ty, std::iter::once(derive)); | |||
// Note: recursive derives and attributes not supported in the CLI => recursive: false |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would we want to support recursive derives in the CLI? Might be worth a separate issue to remind us of it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm, maybe. Or maybe we just make everything recursive by default in the CLI, I think it is already quite hard to specify derives in the CLI.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would be great if you could open an issue for it :)
.iter() | ||
.map(|(name, field)| { | ||
let call_arg = if field.is_boxed() { | ||
// Note: fn_arg_type this is relative the type path of the type alias when prefixed with `types::`, e.g. `set_max_code_size::New` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could there be a variant of the metadata where this does not correspond to the expected alias? Or it would be different from the previous format_ident!("{}", name.to_string().to_upper_camel_case())
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good question, when calling generate_structs_from_variants
, which calls generate_type_alias_mod
for each such composite, for each field, the field.type_path is replaced by #alias_mod_name::#alias_name
, where alias_name
is either format_ident!("{}", name.to_string().to_upper_camel_case())
(named fields) or format_ident!("Field{}", i)
for unnamed fields, so the logic should be very similar to what you implemented before. I cannot think of a case right now where this is not fulfilled.
codegen/src/api/errors.rs
Outdated
let error_type = type_gen.resolve_type_path(error_ty); | ||
let error_ty = type_gen.resolve_type(error_ty); | ||
let error_type = type_gen.resolve_type_path(error_ty)?; | ||
let error_ty = type_gen.resolve_type(error_ty)?; | ||
let docs = &error_ty.docs; | ||
let docs = should_gen_docs |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could this be infered from the type_gen.settings()
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh, totally! Good catch!
derives: DerivesRegistry, | ||
type_substitutes: TypeSubstitutes, | ||
derives: scale_typegen::DerivesRegistry, | ||
type_substitutes: scale_typegen::TypeSubstitutes, | ||
crate_path: syn::Path, | ||
should_gen_docs: bool, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there any particular reason for having this? It is only passed to the error generation, while others use the type_gen
settings
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What do you mean? Having scale_typegen::DerivesRegistry
specified fully, is not necassary, I should just import DerivesRegistry
. Maybe I understand the question wrong.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ops, I forgot to type should_gen_docs
. I do like having the scale_typegen::
prefix 👍
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah okay, the should_gen_docs
we actually need because the typegen settings are not built up yet. They are only built in this very function using the crate_path
, should_gen_docs
, substitutes and derives :)
The code looks clean and simplifies the code quite a lot! Nice one! 👍 Just some nits about the documentation and inferring the type alias paths |
@@ -12,20 +12,20 @@ mod events; | |||
mod runtime_apis; | |||
mod storage; | |||
|
|||
use scale_typegen::typegen::ir::type_ir::{CompositeFieldIR, CompositeIR, CompositeIRKind}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
would be nice to export all these types from the root in scale_typegen
all the types are already unique and I don't think for instance scale_typegen::typegen::ir::type_ir::CompositeFieldIR
is necessary, thus scale_typegen::CompositeFieldIR
or ``scale_typegen::ir::CompositeFieldIR` would be sufficient.
Nothing to address here just a comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good point! We already expose some other types at the root, I did not anticipate that we would need easy access to these structs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks great to me
cli/src/commands/diff.rs
Outdated
@@ -309,12 +309,12 @@ fn storage_differences<'a>( | |||
|e| { | |||
pallet_metadata_1 | |||
.storage_hash(e.name()) | |||
.expect("storage entry should be present") | |||
.expect("storage entry is in medadata; qed") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
.expect("storage entry is in medadata; qed") | |
.expect("storage entry is in metadata; qed") |
cli/src/commands/diff.rs
Outdated
}, | ||
|e| { | ||
pallet_metadata_2 | ||
.storage_hash(e.name()) | ||
.expect("storage entry should be present") | ||
.expect("storage entry is in medadata; qed") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
.expect("storage entry is in medadata; qed") | |
.expect("storage entry is in metadata; qed") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice one! 👍
This PR uses
scale-typegen
to generate theruntime_types
module and structs for calls, events, etc.Let's see if the pipeline works, I manually checked the differences in the
polkadot.rs
file to make sure the differences are valid (almost none).Recursive Derives
PR also includes adjustments to the subxt macro to allow for recursive derives. Shown in the
setup_config_custom.rs
example.Fixes #1268
Fixes #1247 (indirectly)
Type Aliases
I tried to reconcile the conflicts between the master and this branch, and implemented the alias modules a bit differently, I hope it does not break anything.