forked from ethereum/solidity
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request ethereum#3352 from ethereum/movability
Movability check
- Loading branch information
Showing
7 changed files
with
176 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
/*( | ||
This file is part of solidity. | ||
solidity 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. | ||
solidity 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 solidity. If not, see <http://www.gnu.org/licenses/>. | ||
*/ | ||
/** | ||
* Specific AST walkers that collect semantical facts. | ||
*/ | ||
|
||
#include <libjulia/optimiser/Semantics.h> | ||
|
||
#include <libsolidity/inlineasm/AsmData.h> | ||
|
||
#include <libevmasm/SemanticInformation.h> | ||
|
||
#include <libdevcore/CommonData.h> | ||
|
||
using namespace std; | ||
using namespace dev; | ||
using namespace dev::julia; | ||
|
||
MovableChecker::MovableChecker(Expression const& _expression) | ||
{ | ||
visit(_expression); | ||
} | ||
|
||
void MovableChecker::operator()(Identifier const& _identifier) | ||
{ | ||
ASTWalker::operator()(_identifier); | ||
m_variableReferences.insert(_identifier.name); | ||
} | ||
|
||
void MovableChecker::operator()(FunctionalInstruction const& _instr) | ||
{ | ||
if (!eth::SemanticInformation::movable(_instr.instruction)) | ||
m_movable = false; | ||
else | ||
ASTWalker::operator()(_instr); | ||
} | ||
|
||
void MovableChecker::operator()(FunctionCall const&) | ||
{ | ||
m_movable = false; | ||
} | ||
|
||
void MovableChecker::visit(Statement const&) | ||
{ | ||
solAssert(false, "Movability for statement requested."); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
/* | ||
This file is part of solidity. | ||
solidity 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. | ||
solidity 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 solidity. If not, see <http://www.gnu.org/licenses/>. | ||
*/ | ||
/** | ||
* Specific AST walkers that collect semantical facts. | ||
*/ | ||
|
||
#pragma once | ||
|
||
#include <libjulia/optimiser/ASTWalker.h> | ||
|
||
#include <string> | ||
#include <map> | ||
#include <set> | ||
|
||
namespace dev | ||
{ | ||
namespace julia | ||
{ | ||
|
||
/** | ||
* Specific AST walker that determines whether an expression is movable. | ||
*/ | ||
class MovableChecker: public ASTWalker | ||
{ | ||
public: | ||
MovableChecker() = default; | ||
explicit MovableChecker(Expression const& _expression); | ||
|
||
virtual void operator()(Identifier const& _identifier) override; | ||
virtual void operator()(FunctionalInstruction const& _functionalInstruction) override; | ||
virtual void operator()(FunctionCall const& _functionCall) override; | ||
|
||
/// Disallow visiting anything apart from Expressions (this throws). | ||
virtual void visit(Statement const&) override; | ||
using ASTWalker::visit; | ||
|
||
bool movable() const { return m_movable; } | ||
std::set<std::string> const& referencedVariables() const { return m_variableReferences; } | ||
|
||
private: | ||
/// Which variables the current expression references. | ||
std::set<std::string> m_variableReferences; | ||
/// Is the current expression movable or not. | ||
bool m_movable = true; | ||
}; | ||
|
||
} | ||
} |