-
Notifications
You must be signed in to change notification settings - Fork 1.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
refactor: clean up LedgerEntry.cpp
#5199
Conversation
{ | ||
if (context.params.isMember("params") && |
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 was only used for the CLI, so the CLI logic was moved to RPCCall
instead, where it's cleaner and easier to read.
checkErrorValue(jrr, "malformedRequest", ""); | ||
} | ||
// check both aliases | ||
for (auto const& fieldName : {jss::ripple_state, jss::state}) |
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.
These tests were only updated to cover the two aliases, and are otherwise completely unchanged.
using FunctionType = | ||
std::function<std::optional<uint256>(Json::Value const&, Json::Value&)>; |
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 don't think you need runtime polymorphism here.
using FunctionType = | |
std::function<std::optional<uint256>(Json::Value const&, Json::Value&)>; | |
using FunctionType = | |
std::optional<uint256>(*)(Json::Value const&, Json::Value&); |
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 unfamiliar with the pros and cons of std::function
vs C-style pointers, I just assumed the norm was the more modern option.
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 like a huge improvement @mvadari , well done! 🥇
I left a few nits. In general any of them could be left for another PR - as you wish.
Other than the ones I mentioned, i'd like to see const
applied everywhere it can be. I'd also prefer to see some more spacing lines between if
statements and stuff like that. Big if
conditions could be broken down to helper functions/lambdas and/or constants. Some of them are pretty hard to read as they are now but I understand that's old code, not new one.
return uNodeIndex; | ||
} | ||
// clang-format off | ||
if ( |
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 can be improved by splitting to some constants and/or helper function(s) 👍 Can be done in a later PR though.
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.
Any cleanup in the individual parsers (more than just adding const
s) I would prefer to save for a future PR, to make this one easier to review.
// four strings defining the bridge (locking_chain_door, | ||
// locking_chain_issue, issuing_chain_door, issuing_chain_issue) | ||
// and the claim id sequence number. | ||
auto lockingChainDoor = parseBase58<AccountID>( |
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 be const
?
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.
Fixed in 3d5ef0f
} | ||
if (valid && claim_id[jss::xchain_owned_claim_id].isIntegral()) | ||
{ | ||
auto seq = claim_id[jss::xchain_owned_claim_id].asUInt(); |
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.
Can be const
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.
Fixed in 3d5ef0f
if (!lpLedger) | ||
return jvResult; | ||
|
||
static LedgerEntry ledgerEntryParsers[] = { |
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.
nit: Consider using std::array
over C-arrays
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.
Fixed in 3d5ef0f - not sure I like it, though
@@ -837,43 +889,51 @@ doLedgerEntry(RPC::JsonContext& context) | |||
// For apiVersion 2 onwards, any parsing failures that throw | |||
// this |
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.
nit: Looks like a formatting issue, maybe due to clang-format
and column width limit changes in the past
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.
Fixed in 3d5ef0f
6053af1
to
3d5ef0f
Compare
Thanks for the review! I added more spacing and I think I added Definitely plan on adding more helper functions (every individual parser was written sort of individually, and had to reinvent a lot of wheels, and I think helper functions would do a lot to unify a lot of that). But wanted to save that for a separate PR to make this PR easier to review (since that code is already being moved around pretty significantly). |
static LedgerEntry ledgerEntryParsers[] = { | ||
{jss::index, parseIndex, ltANY}, | ||
{jss::account_root, parseAccountRoot, ltACCOUNT_ROOT}, | ||
static std::array<LedgerEntry, 21> ledgerEntryParsers = { |
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.
You can totally avoid specifying the size here like so: https://godbolt.org/z/6jETseadE
The downside is that you need to wrap each entry with its type (LedgerEntry{...}).
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.
Fixed in c255d46
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## develop #5199 +/- ##
=========================================
- Coverage 77.9% 77.9% -0.0%
=========================================
Files 784 784
Lines 66681 66679 -2
Branches 8157 8118 -39
=========================================
- Hits 51923 51919 -4
- Misses 14758 14760 +2
|
static std::array<LedgerEntry, 21> ledgerEntryParsers = { | ||
LedgerEntry{jss::index, parseIndex, ltANY}, | ||
LedgerEntry{jss::account_root, parseAccountRoot, ltACCOUNT_ROOT}, | ||
static auto ledgerEntryParsers = std::to_array<LedgerEntry>({ |
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.
Awesome 👍
High Level Overview of Change
This PR heavily restructures
LedgerEntry.cpp
to make it easier to read and understand.Instead of having a nested series of if-elses, which is very difficult to parse, each object now has 3 elements in an array: the parameter name, a parsing function, and the expected ledger entry type.
This allows the parsing logic to be greatly simplified by returning early in each of the parsing functions, instead of needing to fall through with a lot of else statements - and this also avoids a lot of extra indenting (which in turn makes the code easier to read). It also makes it easier to audit what ledger entries are missing (e.g. NFT Offers are missing right now), and avoids bugs from forgetting to specify the expected ledger entry type.
It does not change any of the individual ledger entry parsing code, to make this PR easier to follow and review.
Context of Change
LedgerEntry.cpp
was a very messy file. I caught a bug in a PR that would have been avoided by this sort of structure.Type of Change
API Impact
No change in functionality.
Test Plan
Tests remained mostly unchanged. We may want some basic performance regression tests, but the performance effect should be pretty minimal.
Future Tasks