-
Notifications
You must be signed in to change notification settings - Fork 747
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
DeprecationInfo
Remove deprecated
attribute from generated code.
#6312
base: master
Are you sure you want to change the base?
Conversation
bot fmt |
@pkhry https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/7675374 was started for your command Comment |
@pkhry Command |
/cmd fmt |
Command "fmt" has started 🚀 See logs here |
Command "fmt" has finished ✅ See logs here |
bot update-ui |
@pkhry https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/7677803 was started for your command Comment |
@pkhry Command |
@@ -209,6 +210,8 @@ pub fn expand_call(def: &mut Def) -> proc_macro2::TokenStream { | |||
let return_type = | |||
&call.methods.get(i).expect("def should be consistent with item").return_type; | |||
|
|||
remove_deprecation_attribute(&mut method.attrs); |
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.
So this removes the deprecated attribute from the call?
I think it is not ideal, because we lose the deprecation of the call itself in rust code.
I think the ideal is to have the deprecation on the call function, also the deprecation on the call variant.
But then all usage of this call inside the macro should be used with #[allow(deprecated)]
on top of the instruction. (We should be careful not to have this #[allow(deprecated)]
for logic written by user).
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.
reverted this change
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.
I was thinking a more fine-grained implementation.
Like the dispatch_bypass_filter
would be implemented with #[allow(deprecated)]
just above the function call
<#pallet_ident<#type_use_gen>>::#fn_name(origin, #( #args_name, )* ) |
Same for all other types: when the macro use them we would write: #[allow(deprecated)]
.
But then we have to be careful not to write #[allow(deprecated)]
on top of blocks which include code written by user. So that user is still notified when they use deprecated elements in their own code.
If it is too difficult, maybe we can merge this PR, without the revert then.
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.
I've tried implementing it this morning, and i can't seem to understand how to propagate #[allow(deprecated)]
from defs inside #[pallet]
to expansion of construct_runtime!
. Ie if we deprecate an event or an error we dont have any attributes to include maybe_allow_attrs
inside code generated by construct_runtime!
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.
Yeah I agree here with @gui1117. Just removing the deprecation attribute, because it adds more noise is not the right way. The attribute is doing exactly for what it is designed for.
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.
I've tried implementing it this morning, and i can't seem to understand how to propagate
#[allow(deprecated)]
from defs inside#[pallet]
to expansion ofconstruct_runtime!
. Ie if we deprecate an event or an error we dont have any attributes to includemaybe_allow_attrs
inside code generated byconstruct_runtime!
about construct_runtime!
if the whole call or event or pallet is deprecated, then I think the writer of the construct_runtime!
should add #[allow(deprecated)]
on top of the pallet variant:
construct_runtime!{
struct Runtime {
#[allow(deprecated)]
MyPalletWithDeprecatedCall: my_pallet; // my pallet is using call implicitly here.
}
}
Otherwise it is fair to actually warn the runtime writer than one of the pallet he uses has actual deprecated elements.
Note that this should only happen when deprecating whole types like Event
or Call
or Pallet
, not when deprecating a single call inside the pallet Call
.
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.
Not sure what the purpose of deprecating these types would be. I mean I would understand if the entire pallet would be deprecated.
Command "fmt" has finished ✅ See logs here |
/cmd fmt |
Command "fmt" has started 🚀 See logs here |
Command "fmt" has finished ✅ See logs here |
All GitHub workflows were cancelled due to failure one of the required jobs. |
bot update-ui |
@pkhry https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/7871580 was started for your command Comment |
@pkhry Command |
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.
Some more comments, overall I think it is ok, do you think there is still time to not put some deprecate information in the metadata?
Like do you think it makes sense to reduce the scope of the deprecated information to only most relevant information?
But the PR should be good now.
@@ -82,6 +88,7 @@ pub fn expand_pallet_struct(def: &mut Def) -> proc_macro2::TokenStream { | |||
quote::quote_spanned!(def.pallet_struct.attr_span => | |||
impl<#type_impl_gen> #pallet_ident<#type_use_gen> #config_where_clause { | |||
#[doc(hidden)] | |||
#[allow(deprecated)] |
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.
This is only when the full error type is deprecated, I also would not handle this case personally. But it can be fine.
substrate/frame/support/procedural/src/pallet/expand/storage.rs
Outdated
Show resolved
Hide resolved
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 good to me
@@ -15,6 +15,8 @@ | |||
// See the License for the specific language governing permissions and | |||
// limitations under the License. | |||
|
|||
use crate::deprecation::extract_allow_attrs; | |||
|
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.
formatting will do: super then crate then other IIRC
# Description Updates scale-info to from 2.11.5 2.11.6, so that generated code is annotated with `allow(deprecated)` Pre-requisite for paritytech#6312
storage | ||
.attrs | ||
.iter() | ||
.filter(|attr| attr.path().is_ident("allow")) | ||
.collect::<Vec<_>>() |
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.
storage | |
.attrs | |
.iter() | |
.filter(|attr| attr.path().is_ident("allow")) | |
.collect::<Vec<_>>() | |
crate::deprecation::extract_allow_attrs(&storage.attrs) |
pub fn #getter() -> #query { | ||
#(#maybe_allow_attrs)* |
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.
#(#maybe_allow_attrs)* |
pub fn #getter<KArg>(k: KArg) -> #query where | ||
KArg: #frame_support::__private::codec::EncodeLike<#key>, | ||
{ | ||
#(#maybe_allow_attrs)* |
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.
#(#maybe_allow_attrs)* |
pub fn #getter<KArg>(k: KArg) -> #query where | ||
KArg: #frame_support::__private::codec::EncodeLike<#key>, | ||
{ | ||
// NOTE: we can't use any trait here because CountedStorageMap | ||
// doesn't implement any. | ||
#(#maybe_allow_attrs)* |
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.
#(#maybe_allow_attrs)* |
pub fn #getter<KArg1, KArg2>(k1: KArg1, k2: KArg2) -> #query where | ||
KArg1: #frame_support::__private::codec::EncodeLike<#key1>, | ||
KArg2: #frame_support::__private::codec::EncodeLike<#key2>, | ||
{ | ||
#(#maybe_allow_attrs)* |
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.
#(#maybe_allow_attrs)* |
pub fn #getter<KArg>(key: KArg) -> #query | ||
where | ||
KArg: #frame_support::storage::types::EncodeLikeTuple< | ||
<#keygen as #frame_support::storage::types::KeyGenerator>::KArg | ||
> | ||
+ #frame_support::storage::types::TupleToEncodedIter, | ||
{ | ||
#(#maybe_allow_attrs)* |
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.
#(#maybe_allow_attrs)* |
@@ -625,6 +643,7 @@ pub fn expand_storages(def: &mut Def) -> proc_macro2::TokenStream { | |||
{ | |||
// NOTE: we can't use any trait here because CountedStorageNMap | |||
// doesn't implement any. | |||
#(#maybe_allow_attrs)* |
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.
#(#maybe_allow_attrs)* |
@@ -67,13 +67,14 @@ sp_api::decl_runtime_apis! { | |||
/// | |||
/// Documentation on multiline. | |||
#[deprecated] | |||
#[allow(deprecated)] |
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.
Are all these deprecated
& allow(deprecated)
together just done for testing? Does standard rust accepts this as well?
.filter(|attr| attr.path().is_ident("allow")) | ||
.cloned() | ||
.collect::<Vec<_>>(); |
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.
.filter(|attr| attr.path().is_ident("allow")) | |
.cloned() | |
.collect::<Vec<_>>(); | |
.filter(|attr| attr.path().is_ident("allow")); |
pub fn extract_allow_attrs(items: &[syn::Attribute]) -> Vec<syn::Attribute> { | ||
items | ||
.iter() | ||
.filter(|attr| attr.path().is_ident("allow")) | ||
.cloned() | ||
.collect::<Vec<_>>() |
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.
pub fn extract_allow_attrs(items: &[syn::Attribute]) -> Vec<syn::Attribute> { | |
items | |
.iter() | |
.filter(|attr| attr.path().is_ident("allow")) | |
.cloned() | |
.collect::<Vec<_>>() | |
pub fn extract_allow_attrs(items: &[syn::Attribute]) -> impl Iterator<Item = &syn::Attribute> { | |
items | |
.iter() | |
.filter(|attr| attr.path().is_ident("allow")) |
Description
Removed
#[deprecated]
attribute from the generated code, so that code is not littered with useless warnings butDeprecationInfo
is still propagated inMetadataIr
see an example of warnings being too noisy: #6169
Review Notes
The change itself is just adding attribute removal code after specific steps during macro expansion.