2014-10-13 16:22:15 +00:00
|
|
|
/*
|
2014-10-16 12:08:54 +00:00
|
|
|
This file is part of cpp-ethereum.
|
2014-10-13 16:22:15 +00:00
|
|
|
|
2014-10-16 12:08:54 +00:00
|
|
|
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.
|
2014-10-13 16:22:15 +00:00
|
|
|
|
2014-10-16 12:08:54 +00:00
|
|
|
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.
|
2014-10-13 16:22:15 +00:00
|
|
|
|
2014-10-16 12:08:54 +00:00
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>.
|
2014-10-13 16:22:15 +00:00
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @author Christian <c@ethdev.com>
|
|
|
|
* @date 2014
|
|
|
|
* Scope - object that holds declaration of names.
|
|
|
|
*/
|
|
|
|
|
2014-12-01 14:22:45 +00:00
|
|
|
#include <libsolidity/DeclarationContainer.h>
|
2014-10-13 16:22:15 +00:00
|
|
|
#include <libsolidity/AST.h>
|
2015-02-28 08:15:27 +00:00
|
|
|
#include <libsolidity/Types.h>
|
2014-10-13 16:22:15 +00:00
|
|
|
|
2015-04-20 12:57:56 +00:00
|
|
|
using namespace std;
|
|
|
|
using namespace dev;
|
|
|
|
using namespace dev::solidity;
|
2014-10-13 16:22:15 +00:00
|
|
|
|
2015-04-30 16:06:04 +00:00
|
|
|
Declaration const* DeclarationContainer::conflictingDeclaration(Declaration const& _declaration) const
|
|
|
|
{
|
|
|
|
ASTString const& name(_declaration.getName());
|
|
|
|
solAssert(!name.empty(), "");
|
|
|
|
vector<Declaration const*> declarations;
|
|
|
|
if (m_declarations.count(name))
|
|
|
|
declarations += m_declarations.at(name);
|
|
|
|
if (m_invisibleDeclarations.count(name))
|
|
|
|
declarations += m_invisibleDeclarations.at(name);
|
|
|
|
if (dynamic_cast<FunctionDefinition const*>(&_declaration))
|
|
|
|
{
|
|
|
|
// check that all other declarations with the same name are functions
|
|
|
|
for (Declaration const* declaration: declarations)
|
|
|
|
if (!dynamic_cast<FunctionDefinition const*>(declaration))
|
|
|
|
return declaration;
|
|
|
|
}
|
|
|
|
else if (!declarations.empty())
|
|
|
|
return declarations.front();
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2015-02-13 23:43:02 +00:00
|
|
|
bool DeclarationContainer::registerDeclaration(Declaration const& _declaration, bool _invisible, bool _update)
|
2014-10-13 16:22:15 +00:00
|
|
|
{
|
2015-02-13 23:43:02 +00:00
|
|
|
ASTString const& name(_declaration.getName());
|
|
|
|
if (name.empty())
|
2015-02-09 01:06:30 +00:00
|
|
|
return true;
|
|
|
|
|
2015-04-15 15:40:50 +00:00
|
|
|
if (_update)
|
|
|
|
{
|
|
|
|
solAssert(!dynamic_cast<FunctionDefinition const*>(&_declaration), "Attempt to update function definition.");
|
2015-04-21 17:04:08 +00:00
|
|
|
m_declarations.erase(name);
|
|
|
|
m_invisibleDeclarations.erase(name);
|
2015-04-15 15:40:50 +00:00
|
|
|
}
|
2015-04-30 16:06:04 +00:00
|
|
|
else if (conflictingDeclaration(_declaration))
|
|
|
|
return false;
|
2015-02-13 23:43:02 +00:00
|
|
|
|
|
|
|
if (_invisible)
|
2015-04-15 15:40:50 +00:00
|
|
|
m_invisibleDeclarations[name].insert(&_declaration);
|
2015-02-13 23:43:02 +00:00
|
|
|
else
|
2015-04-15 15:40:50 +00:00
|
|
|
m_declarations[name].insert(&_declaration);
|
2015-02-28 08:15:27 +00:00
|
|
|
|
2014-10-13 16:22:15 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2015-04-20 12:57:56 +00:00
|
|
|
set<Declaration const*> DeclarationContainer::resolveName(ASTString const& _name, bool _recursive) const
|
2014-10-13 16:22:15 +00:00
|
|
|
{
|
2015-02-09 01:06:30 +00:00
|
|
|
solAssert(!_name.empty(), "Attempt to resolve empty name.");
|
2014-10-13 16:22:15 +00:00
|
|
|
auto result = m_declarations.find(_name);
|
|
|
|
if (result != m_declarations.end())
|
|
|
|
return result->second;
|
2014-12-01 14:22:45 +00:00
|
|
|
if (_recursive && m_enclosingContainer)
|
|
|
|
return m_enclosingContainer->resolveName(_name, true);
|
2015-04-20 12:57:56 +00:00
|
|
|
return set<Declaration const*>({});
|
2014-10-16 12:08:54 +00:00
|
|
|
}
|