diff options
author | Christian <c@ethdev.com> | 2014-12-01 22:22:45 +0800 |
---|---|---|
committer | Christian <c@ethdev.com> | 2014-12-02 00:33:21 +0800 |
commit | 9e91596c8d5683e79314fcd53a18e0e3df7b3390 (patch) | |
tree | 403740e7f56b4f6fc9d7b49b1c7383f5cdb99a5f /DeclarationContainer.cpp | |
parent | 3fc2708d657525162567b663a07cf8cb5b1c59aa (diff) | |
download | dexon-solidity-9e91596c8d5683e79314fcd53a18e0e3df7b3390.tar.gz dexon-solidity-9e91596c8d5683e79314fcd53a18e0e3df7b3390.tar.zst dexon-solidity-9e91596c8d5683e79314fcd53a18e0e3df7b3390.zip |
Save the scope for every declaration.
Diffstat (limited to 'DeclarationContainer.cpp')
-rw-r--r-- | DeclarationContainer.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/DeclarationContainer.cpp b/DeclarationContainer.cpp new file mode 100644 index 00000000..6ea9c28c --- /dev/null +++ b/DeclarationContainer.cpp @@ -0,0 +1,50 @@ +/* + This file is part of cpp-ethereum. + + cpp-ethereum is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + cpp-ethereum is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>. +*/ +/** + * @author Christian <c@ethdev.com> + * @date 2014 + * Scope - object that holds declaration of names. + */ + +#include <libsolidity/DeclarationContainer.h> +#include <libsolidity/AST.h> + +namespace dev +{ +namespace solidity +{ + +bool DeclarationContainer::registerDeclaration(Declaration& _declaration) +{ + if (m_declarations.find(_declaration.getName()) != m_declarations.end()) + return false; + m_declarations[_declaration.getName()] = &_declaration; + return true; +} + +Declaration* DeclarationContainer::resolveName(ASTString const& _name, bool _recursive) const +{ + auto result = m_declarations.find(_name); + if (result != m_declarations.end()) + return result->second; + if (_recursive && m_enclosingContainer) + return m_enclosingContainer->resolveName(_name, true); + return nullptr; +} + +} +} |