-
Notifications
You must be signed in to change notification settings - Fork 4.5k
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
Program macro to generate helper fns and documentation #10826
Conversation
@garious , @jackcmay, one thing I wanted to run by you: I originally wrote the helper functions to use |
Codecov Report
@@ Coverage Diff @@
## master #10826 +/- ##
=========================================
- Coverage 81.8% 81.7% -0.2%
=========================================
Files 303 304 +1
Lines 71067 71406 +339
=========================================
+ Hits 58194 58389 +195
- Misses 12873 13017 +144 |
@CriesofCarrots @jstarry brought this up a while ago and contrary to my last comment in the issue I agree, the |
The custom |
8ddb5c2
to
0a1e297
Compare
Taking a |
Changing it to |
d6bc72b
to
07d8a07
Compare
@garious , this is updated. Please let me know if there's something else you'd like to see before review. |
pub enum TestInstruction { | ||
/// Transfer lamports | ||
#[accounts( | ||
from_account(SIGNER, WRITABLE, desc = "Funding account"), |
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.
Looking back at the proposal, I see this syntax made it in, but I still find it really confusing. Remind me why we can't write (from_account, SIGNER | WRITABLE, desc = "Funding account")
?
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 using the standard attribute syntax for a list (of accounts/names), which each carry a list of account attributes.
In addition to the "standardization" aspect, it's significantly easier to parse the attributes in the macro if they can be mapped into syn
library Meta
types.
But if you feel really strongly about this, I'll write a custom parser.
One thing that I'm not crazy about with your proposed syntax is the strict ordering that's required inside the parens in order to identify the account name. As it is, the account name is unambiguous, because it is the item Path
, and account attributes inside the parens can be listed in any order and remain parsable.
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'm looking for as little custom parsing as possible and that wherever possible, pass in Rust expressions. I don't want to learn a new DSL to annotate this enum.
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 this is possible?
use solana_sdk_program_macros::{SIGNER, WRITABLE};
...
#[accounts(
(from_account, SIGNER | WRITABLE, desc: "Funding account")
)]
So a tuple of an identifier, an expression that evaluates to a u64, and then key-value pairs that use the struct field syntax.
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.
Sure, it's possible. I think this is approx the same amount of extra handling as your previous version.
I'm not sure whether it's easy to actually evaluate the SIGNER | WRITABLE
expression in the macro. I'll have to look into that.
instruction::{AccountMeta, Instruction}, | ||
pubkey::Pubkey, | ||
}; | ||
use solana_sdk_program_macros::instructions; |
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.
Why no use solana_sdk_program_macros::{SIGNER, WRITABLE};
in here?
This reverts commit e104a09.
fcccd39
to
49f9c6f
Compare
This pull request has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. |
This pull request has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. |
This pull request has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. |
This stale pull request has been automatically closed. Thank you for your contributions. |
Problem
There's a lot of information duplicated between program instruction enums and helper functions that build Instructions. Also, it's difficult to parse on-chain instructions and get useful information about the expected accounts, as that information is buried in the documentation in the aforementioned enum. Design proposal #10763 suggests addressing both issues by adding a procedural macro that would parse an annotated Instruction enum to generate needed helper functions as well as a 2nd enum that exposes account information. This would also have the benefit of enforcing consistency across program Instruction enum docs.
Summary of Changes
instructions
attribute procedural macroToward #10476
Notes:
trybuild
is a neat tool for catching compilation failures and ensuring error messages are helpful and descriptive. However, it's possible there could be issues with our monorepo due to Ensure tests are built with same dependencies as parent crate dtolnay/trybuild#53. (I ran into those bincode errors we saw on master recently due to a newer version of bincode in my.cargo/registry/cache
being pulled into the trybuild compilation) If it seems flaky in CI or for devs, I'll removeskip
variant-level attribute