aboutsummaryrefslogtreecommitdiffstats
path: root/DeclarationContainer.cpp
diff options
context:
space:
mode:
authorChristian <c@ethdev.com>2014-12-01 22:22:45 +0800
committerChristian <c@ethdev.com>2014-12-02 00:33:21 +0800
commit9e91596c8d5683e79314fcd53a18e0e3df7b3390 (patch)
tree403740e7f56b4f6fc9d7b49b1c7383f5cdb99a5f /DeclarationContainer.cpp
parent3fc2708d657525162567b663a07cf8cb5b1c59aa (diff)
downloaddexon-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.cpp50
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;
+}
+
+}
+}