aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian <c@ethdev.com>2015-01-26 17:20:46 +0800
committerChristian <c@ethdev.com>2015-01-26 17:20:46 +0800
commitfe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c (patch)
tree19e682c64d71156624b71cbad652adde89e5bcd6
parent570e49c03ab9e09d538218839696fc6159b0a2f1 (diff)
downloaddexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.tar
dexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.tar.gz
dexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.tar.bz2
dexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.tar.lz
dexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.tar.xz
dexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.tar.zst
dexon-solidity-fe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c.zip
Reverse order of inheritance in base list.
-rw-r--r--NameAndTypeResolver.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/NameAndTypeResolver.cpp b/NameAndTypeResolver.cpp
index ba5ca134..c67cd727 100644
--- a/NameAndTypeResolver.cpp
+++ b/NameAndTypeResolver.cpp
@@ -111,7 +111,7 @@ void NameAndTypeResolver::linearizeBaseContracts(ContractDefinition& _contract)
{
// order in the lists is from derived to base
// list of lists to linearize, the last element is the list of direct bases
- list<list<ContractDefinition const*>> input(1, {&_contract});
+ list<list<ContractDefinition const*>> input(1, {});
for (ASTPointer<InheritanceSpecifier> const& baseSpecifier: _contract.getBaseContracts())
{
ASTPointer<Identifier> baseName = baseSpecifier->getName();
@@ -119,14 +119,15 @@ void NameAndTypeResolver::linearizeBaseContracts(ContractDefinition& _contract)
baseName->getReferencedDeclaration());
if (!base)
BOOST_THROW_EXCEPTION(baseName->createTypeError("Contract expected."));
- // "push_back" has the effect that bases mentioned earlier can overwrite members of bases
- // mentioned later
- input.back().push_back(base);
+ // "push_front" has the effect that bases mentioned later can overwrite members of bases
+ // mentioned earlier
+ input.back().push_front(base);
vector<ContractDefinition const*> const& basesBases = base->getLinearizedBaseContracts();
if (basesBases.empty())
BOOST_THROW_EXCEPTION(baseName->createTypeError("Definition of base has to precede definition of derived contract"));
input.push_front(list<ContractDefinition const*>(basesBases.begin(), basesBases.end()));
}
+ input.back().push_front(&_contract);
vector<ContractDefinition const*> result = cThreeMerge(input);
if (result.empty())
BOOST_THROW_EXCEPTION(_contract.createTypeError("Linearization of inheritance graph impossible"));