mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Fix detection of recursive structs.
This commit is contained in:
parent
c42caedec2
commit
5bdadff0d8
@ -16,6 +16,7 @@ Bugfixes:
|
||||
* Commandline interface: Support ``--evm-version constantinople`` properly.
|
||||
* DocString Parser: Fix error message for empty descriptions.
|
||||
* Standard JSON: Support ``constantinople`` as ``evmVersion`` properly.
|
||||
* Type Checker: Fix detection of recursive structs.
|
||||
* Type System: Improve error message when attempting to shift by a fractional amount.
|
||||
* Type System: Make external library functions accessible.
|
||||
* Type System: Prevent encoding of weird types.
|
||||
|
@ -1972,9 +1972,12 @@ bool StructType::recursive() const
|
||||
if (!m_recursive.is_initialized())
|
||||
{
|
||||
set<StructDefinition const*> structsSeen;
|
||||
set<StructDefinition const*> structsProcessed;
|
||||
function<bool(StructType const*)> check = [&](StructType const* t) -> bool
|
||||
{
|
||||
StructDefinition const* str = &t->structDefinition();
|
||||
if (structsProcessed.count(str))
|
||||
return false;
|
||||
if (structsSeen.count(str))
|
||||
return true;
|
||||
structsSeen.insert(str);
|
||||
@ -1987,6 +1990,8 @@ bool StructType::recursive() const
|
||||
if (check(innerStruct))
|
||||
return true;
|
||||
}
|
||||
structsSeen.erase(str);
|
||||
structsProcessed.insert(str);
|
||||
return false;
|
||||
};
|
||||
m_recursive = check(this);
|
||||
|
@ -0,0 +1,15 @@
|
||||
pragma experimental ABIEncoderV2;
|
||||
|
||||
contract C {
|
||||
struct T { U u; V v; }
|
||||
|
||||
struct U { W w; }
|
||||
|
||||
struct V { W w; }
|
||||
|
||||
struct W { uint x; }
|
||||
|
||||
function f(T) public pure { }
|
||||
}
|
||||
// ----
|
||||
// Warning: Experimental features are turned on. Do not use experimental features on live deployments.
|
@ -0,0 +1,15 @@
|
||||
pragma experimental ABIEncoderV2;
|
||||
|
||||
contract TestContract
|
||||
{
|
||||
struct SubStruct {
|
||||
uint256 id;
|
||||
}
|
||||
struct TestStruct {
|
||||
SubStruct subStruct1;
|
||||
SubStruct subStruct2;
|
||||
}
|
||||
function addTestStruct(TestStruct) public pure {}
|
||||
}
|
||||
// ----
|
||||
// Warning: Experimental features are turned on. Do not use experimental features on live deployments.
|
Loading…
Reference in New Issue
Block a user