-
Notifications
You must be signed in to change notification settings - Fork 220
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
Bugfix: Accessing storage struct members is always a storage read #1553
Bugfix: Accessing storage struct members is always a storage read #1553
Conversation
Signed-off-by: Cyrill Leutwiler <[email protected]>
Signed-off-by: Cyrill Leutwiler <[email protected]>
Signed-off-by: Cyrill Leutwiler <[email protected]>
Signed-off-by: xermicus <[email protected]>
Signed-off-by: xermicus <[email protected]>
src/sema/mutability.rs
Outdated
state | ||
.diagnostics | ||
.extend(state.per_statement_diagnostics.drain().map(|(_, v)| v)); |
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 are you restricting the diagnostics to only one per statement? Both the solc and Solang in the main branch detect multiple access violations in a single statement:
contract Test {
struct CC {
bytes name;
uint32 age;
}
CC vari;
uint32 cc;
function read() public pure returns (uint32) {
return vari.age + cc;
}
}
We detect the problem in vari.age
and in cc
, but your branch only finds cc
.
Two diagnostics for the same access level in a statement does not mean they refer to the same problem.
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 good point. I've analyzed the situation a bit further. There are situations where the same error will be reported twice, if Expression::StorageLoad
will be considered during expr recursing. If this can be made consistent somehow, there's no need to restrict diagnostics to a context.
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.
Just added the edge case for storageloads ond struct members
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 why is a storageload of a struct member an exception? Any storage load should require view mutability.
The comment just explains how struct member works but nothing about why this is an exception.
This is just an ugly hack, I am not going to approve it.
Signed-off-by: xermicus <[email protected]>
Co-authored-by: Lucas Steuernagel <[email protected]> Signed-off-by: Cyrill Leutwiler <[email protected]>
We discussed this in the standup a while ago. 🙂 So, why isn't there already a match arm covering any storage load. The problem is that we need to consider the context, as 2 subsequent expressions might emit the same error (although with slightly different locations). Which we don't want. Is there another solution? Maybe, however I explored different options which all didn't work. This is why I decided to just fix this bug in the end 🙂
I don't understand why you think this is an exception and why you think that the comment doesn't explain the match arm thoroughly enough 🙂 I think that the comment explaining that struct member accesses are only a Also, this is the only match arm with a comment anyways. My contribution being opposed to like this,, when there are usually not even comments or unreachable messages in the code base, makes me feel quite confused and makes for a unsatisfying contributor experience..
Could you please elaborate how you imagine the solution to look like without it being an ugly hack? #1544 was supposed to solve #1493, which states However, I still would like to get this bug fixed. Thus I kindly ask you to reconsider your previous review. And if you are still unhappy with it, I'm open for constructive input on
|
Let's go through the history of this PR:
I kept on saying you need to make It's fixed here #1563 |
No, I perceive that entirely different. The first and only time that was stated is after the last iteration of this PR 🙂 Neither was it mentioned in previous PRs attempting to "fix mutability checks". The opposite is the case: It was removed in #1544. And when I asked about it during the standup, I was told that having this leads to duplicate error messages, which we don't want. So I tried to find a different solution, based on the advice suggested to me initially. And then, the only thing that has been highlighted repeatedly in this PR (in various other PRs I made too btw) instead is that my comments are unsatisfactory, my function names are unsatisfactory, and calling my contribution an |
Fixes a bug:
StorageLoad
after a struct member access is a storage read, this case was not considered in the mutability check.The regression in the EVM test is fine; it's caused by a problem in solc