Merge pull request #10826 from ethereum/issue-10821

Fix missing error when accessing unintialized variables.
This commit is contained in:
chriseth 2021-01-26 09:16:13 +01:00 committed by GitHub
commit 9fc3d88617
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 61 additions and 1 deletions

View File

@ -32,6 +32,7 @@ Bugfixes:
* SMTChecker: Fix internal error on pushing string literal to ``bytes`` array.
* Type Checker: Fix internal error caused by constant structs containing mappings.
* Type System: Disallow implicit conversion from ``uintN`` to ``intM`` when ``M > N``, and by extension, explicit conversion between the same types is also disallowed.
* Control Flow Graph: Fix missing error caused by read from/write to uninitialized variables.
### 0.8.0 (2020-12-16)

View File

@ -110,7 +110,10 @@ void ControlFlowAnalyzer::checkUninitializedAccess(CFGNode const* _entry, CFGNod
// Propagate changes to all exits and queue them for traversal, if needed.
for (auto const& exit: currentNode->exits)
if (nodeInfos[exit].propagateFrom(nodeInfo))
if (
auto exists = valueOrNullptr(nodeInfos, exit);
nodeInfos[exit].propagateFrom(nodeInfo) || !exists
)
nodesToTraverse.insert(exit);
}

View File

@ -0,0 +1,9 @@
contract Test {
function testFunc() external {
for (;;) {}
bytes storage b;
b[0] = 0x42;
}
}
// ----
// TypeError 3464: (83-84): This variable is of storage pointer type and can be accessed without prior assignment, which would lead to undefined behaviour.

View File

@ -0,0 +1,13 @@
contract Test {
struct Sample { bool flag; }
Sample public s;
function testFunc() external {
if(true){}
Sample storage t;
t.flag=true;
}
}
// ----
// TypeError 3464: (155-156): This variable is of storage pointer type and can be accessed without prior assignment, which would lead to undefined behaviour.

View File

@ -0,0 +1,16 @@
contract Test {
struct Sample { bool flag; }
Sample public s;
modifier checkAddr(address _a){
require(_a!=address(0));
_;
}
function testFunc(address _a) external checkAddr(_a) {
Sample storage t;
t.flag=true;
}
}
// ----
// TypeError 3464: (237-238): This variable is of storage pointer type and can be accessed without prior assignment, which would lead to undefined behaviour.

View File

@ -0,0 +1,9 @@
contract Test {
function testFunc() external {
require(true);
bytes storage b;
b[0] = 0x42;
}
}
// ----
// TypeError 3464: (86-87): This variable is of storage pointer type and can be accessed without prior assignment, which would lead to undefined behaviour.

View File

@ -0,0 +1,9 @@
contract Test {
function testFunc() external {
while (true) {}
bytes storage b;
b[0] = 0x42;
}
}
// ----
// TypeError 3464: (87-88): This variable is of storage pointer type and can be accessed without prior assignment, which would lead to undefined behaviour.