aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLefteris Karapetsas <lefteris@refu.co>2015-03-02 19:08:32 +0800
committerLefteris Karapetsas <lefteris@refu.co>2015-03-02 19:08:32 +0800
commit4f13859f8c010410b7497ed860c409a8b899538c (patch)
treee116266ccf1a717b8c76e4f3c36a06b495debeb1
parentbbaa9fef6c8272c567af49ecea4f68c59c335778 (diff)
downloaddexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.tar
dexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.tar.gz
dexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.tar.bz2
dexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.tar.lz
dexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.tar.xz
dexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.tar.zst
dexon-solidity-4f13859f8c010410b7497ed860c409a8b899538c.zip
Using normal pointer in getInheritableMembers()
-rw-r--r--AST.cpp12
-rw-r--r--AST.h4
-rw-r--r--Types.cpp2
3 files changed, 9 insertions, 9 deletions
diff --git a/AST.cpp b/AST.cpp
index e5aef4cb..4c6db6a2 100644
--- a/AST.cpp
+++ b/AST.cpp
@@ -209,13 +209,13 @@ vector<pair<FixedHash<4>, FunctionTypePointer>> const& ContractDefinition::getIn
return *m_interfaceFunctionList;
}
-vector<ASTPointer<Declaration>> const& ContractDefinition::getInheritableMembers() const
+vector<Declaration const*> const& ContractDefinition::getInheritableMembers() const
{
if (!m_inheritableMembers)
{
set<string> memberSeen;
- m_inheritableMembers.reset(new vector<ASTPointer<Declaration>>());
- auto addInheritableMember = [&](ASTPointer<Declaration> const& _decl)
+ m_inheritableMembers.reset(new vector<Declaration const*>());
+ auto addInheritableMember = [&](Declaration const* _decl)
{
if (memberSeen.count(_decl->getName()) == 0 && _decl->isVisibleInDerivedContracts())
{
@@ -225,13 +225,13 @@ vector<ASTPointer<Declaration>> const& ContractDefinition::getInheritableMembers
};
for (ASTPointer<FunctionDefinition> const& f: getDefinedFunctions())
- addInheritableMember(f);
+ addInheritableMember(f.get());
for (ASTPointer<VariableDeclaration> const& v: getStateVariables())
- addInheritableMember(v);
+ addInheritableMember(v.get());
for (ASTPointer<StructDefinition> const& s: getDefinedStructs())
- addInheritableMember(s);
+ addInheritableMember(s.get());
}
return *m_inheritableMembers;
}
diff --git a/AST.h b/AST.h
index 97e85927..d028e8a7 100644
--- a/AST.h
+++ b/AST.h
@@ -248,7 +248,7 @@ public:
std::map<FixedHash<4>, FunctionTypePointer> getInterfaceFunctions() const;
/// @returns a list of the inheritable members of this contract
- std::vector<ASTPointer<Declaration>> const& getInheritableMembers() const;
+ std::vector<Declaration const*> const& getInheritableMembers() const;
/// List of all (direct and indirect) base contracts in order from derived to base, including
/// the contract itself. Available after name resolution
@@ -276,7 +276,7 @@ private:
std::vector<ContractDefinition const*> m_linearizedBaseContracts;
mutable std::unique_ptr<std::vector<std::pair<FixedHash<4>, FunctionTypePointer>>> m_interfaceFunctionList;
mutable std::unique_ptr<std::vector<ASTPointer<EventDefinition>>> m_interfaceEvents;
- mutable std::unique_ptr<std::vector<ASTPointer<Declaration>>> m_inheritableMembers;
+ mutable std::unique_ptr<std::vector<Declaration const*>> m_inheritableMembers;
};
class InheritanceSpecifier: public ASTNode
diff --git a/Types.cpp b/Types.cpp
index 84e02926..dc72dcc4 100644
--- a/Types.cpp
+++ b/Types.cpp
@@ -1024,7 +1024,7 @@ MemberList const& TypeType::getMembers() const
if (find(currentBases.begin(), currentBases.end(), &contract) != currentBases.end())
// We are accessing the type of a base contract, so add all public and protected
// members. Note that this does not add inherited functions on purpose.
- for (ASTPointer<Declaration> const& decl: contract.getInheritableMembers())
+ for (Declaration const* decl: contract.getInheritableMembers())
members.push_back(make_pair(decl->getName(), decl->getType()));
}
else if (m_actualType->getCategory() == Category::Enum)