diff options
author | chriseth <c@ethdev.com> | 2015-03-02 19:59:12 +0800 |
---|---|---|
committer | chriseth <c@ethdev.com> | 2015-03-02 19:59:12 +0800 |
commit | 32e210eccad6ea951feaa3441a6aefb9938f8a90 (patch) | |
tree | 372ced6ce92be6a7a9d52bfc8ba2dfb371fbac23 /AST.h | |
parent | 346d87cc6347b8f6bd309b8f0dfc4a446adc7973 (diff) | |
parent | 4f13859f8c010410b7497ed860c409a8b899538c (diff) | |
download | dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.tar dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.tar.gz dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.tar.bz2 dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.tar.lz dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.tar.xz dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.tar.zst dexon-solidity-32e210eccad6ea951feaa3441a6aefb9938f8a90.zip |
Merge pull request #1146 from LefterisJP/sol_fixBaseClassAccessors
Sol fix accessing public variable of base class
Diffstat (limited to 'AST.h')
-rw-r--r-- | AST.h | 11 |
1 files changed, 10 insertions, 1 deletions
@@ -144,7 +144,7 @@ public: Visibility getVisibility() const { return m_visibility == Visibility::Default ? getDefaultVisibility() : m_visibility; } bool isPublic() const { return getVisibility() >= Visibility::Public; } bool isVisibleInContract() const { return getVisibility() != Visibility::External; } - bool isVisibleInDerivedContracts() const { return isVisibleInContract() && getVisibility() >= Visibility::Internal; } + virtual bool isVisibleInDerivedContracts() const { return isVisibleInContract() && getVisibility() >= Visibility::Internal; } /// @returns the scope this declaration resides in. Can be nullptr if it is the global scope. /// Available only after name and type resolution step. @@ -247,6 +247,9 @@ public: /// as intended for use by the ABI. std::map<FixedHash<4>, FunctionTypePointer> getInterfaceFunctions() const; + /// @returns a list of the inheritable members of this contract + 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 std::vector<ContractDefinition const*> const& getLinearizedBaseContracts() const { return m_linearizedBaseContracts; } @@ -273,6 +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<Declaration const*>> m_inheritableMembers; }; class InheritanceSpecifier: public ASTNode @@ -405,6 +409,11 @@ public: ASTPointer<ParameterList> const& getReturnParameterList() const { return m_returnParameters; } Block const& getBody() const { return *m_body; } + virtual bool isVisibleInDerivedContracts() const override + { + return !isConstructor() && !getName().empty() && isVisibleInContract() && + getVisibility() >= Visibility::Internal; + } virtual TypePointer getType(ContractDefinition const*) const override; /// Checks that all parameters have allowed types and calls checkTypeRequirements on the body. |