-
Notifications
You must be signed in to change notification settings - Fork 789
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
propagate #[allow(deprecated)]
attribute into the generated code.
#6312
Open
pkhry
wants to merge
31
commits into
master
Choose a base branch
from
pkhry/silent-deprecation-attr
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 4 commits
Commits
Show all changes
31 commits
Select commit
Hold shift + click to select a range
01f3639
remove deprecation attribute before code expansion
pkhry 524fffa
prdoc
pkhry f199b9f
fixup api
pkhry 71e89d4
".git/.scripts/commands/update-ui/update-ui.sh"
eb8077c
review comments
pkhry 74c7b9f
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry 6fe881a
rever change
pkhry c9eed15
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry 0978bff
update scale-info
pkhry acd6c55
move to allow(deprecated) propagation instead
pkhry f87b3e7
Merge branch 'pkhry/update-frame' into pkhry/silent-deprecation-attr
pkhry 4e638d6
merge issue
pkhry 5714f3c
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry 9ada2aa
review
pkhry 39ee4cc
review
pkhry 99c0436
remove expansion file
pkhry 38affa5
review comments
pkhry b1c426a
fixup try_runtime! codegen contents
pkhry 5f9a1df
fix clippy
pkhry 377981c
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry a23571b
fixup test
pkhry b9c70c2
".git/.scripts/commands/update-ui/update-ui.sh"
7e0712d
review comments
pkhry a1a14ab
more review comments
pkhry d6b3b9b
Apply suggestions from code review
pkhry 4bfc2ba
fixup suggestions
pkhry 34b8468
Update from pkhry running command 'fmt'
d3f7769
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry 4cfa648
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry a5259eb
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry 73187e9
Merge branch 'master' into pkhry/silent-deprecation-attr
pkhry File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# Schema: Polkadot SDK PRDoc Schema (prdoc) v1.0.0 | ||
# See doc at https://raw.githubusercontent.com/paritytech/polkadot-sdk/master/prdoc/schema_user.json | ||
|
||
title: DeprecationInfo Remove deprecated attribute from generated code. | ||
|
||
doc: | ||
- audience: | ||
- Runtime dev | ||
- Runtime user | ||
description: | | ||
filters out `deprecated` attribute from code generated by macros | ||
|
||
crates: | ||
- name: frame-support-procedural | ||
bump: none | ||
- name: frame-support | ||
bump: none | ||
- name: sp-api-proc-macro | ||
bump: none | ||
- name: sp-api | ||
bump: none |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -15,7 +15,10 @@ | |
// See the License for the specific language governing permissions and | ||
// limitations under the License. | ||
|
||
use crate::pallet::Def; | ||
use crate::{ | ||
deprecation::remove_deprecation_attribute, | ||
pallet::{parse::helper::MutItemAttrs, Def}, | ||
}; | ||
use proc_macro2::TokenStream; | ||
use quote::quote; | ||
use syn::{parse_quote, Item}; | ||
|
@@ -47,6 +50,10 @@ Consequently, a runtime that wants to include this pallet must implement this tr | |
] | ||
), | ||
); | ||
config_item.attrs.retain(|attr| !attr.path().is_ident("deprecated")); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't mind this. Thinking back I think it was overkill to allow deprecating the config in the first place. I wouldn't mind also just letting the flag there, and have deprecated warning everywhere. |
||
for item in config_item.items.iter_mut() { | ||
item.mut_item_attrs().map(remove_deprecation_attribute); | ||
} | ||
|
||
// we only emit `DefaultConfig` if there are trait items, so an empty `DefaultConfig` is | ||
// impossible consequently. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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 callpolkadot-sdk/substrate/frame/support/procedural/src/pallet/expand/call.rs
Line 460 in 74c7b9f
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 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!
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.
about
construct_runtime!
if the whole call or event or pallet is deprecated, then I think the writer of theconstruct_runtime!
should add#[allow(deprecated)]
on top of the pallet variant: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
orCall
orPallet
, not when deprecating a single call inside the palletCall
.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.