aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/inlineasm
diff options
context:
space:
mode:
authorwinsvega <winsvega@mail.ru>2016-04-06 18:54:18 +0800
committerwinsvega <winsvega@mail.ru>2016-04-06 18:54:18 +0800
commit737623cd0c437bda2707a22ef17a637fbfcd7916 (patch)
tree5d4c899f7a970ebf091694632a872cb1c4733079 /libsolidity/inlineasm
parent12797ed6c9afacd7f5a2b8538ccf0032bbc15a19 (diff)
parentd2cee6f9c6babdf8c857e9860d68b6876d71a7eb (diff)
downloaddexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.tar
dexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.tar.gz
dexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.tar.bz2
dexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.tar.lz
dexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.tar.xz
dexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.tar.zst
dexon-solidity-737623cd0c437bda2707a22ef17a637fbfcd7916.zip
Merge pull request #471 from winsvega/libevmcore
move libevmcore to solidity
Diffstat (limited to 'libsolidity/inlineasm')
-rw-r--r--libsolidity/inlineasm/AsmCodeGen.cpp11
-rw-r--r--libsolidity/inlineasm/AsmData.h4
-rw-r--r--libsolidity/inlineasm/AsmParser.cpp23
3 files changed, 19 insertions, 19 deletions
diff --git a/libsolidity/inlineasm/AsmCodeGen.cpp b/libsolidity/inlineasm/AsmCodeGen.cpp
index 89e95bc1..5fa04087 100644
--- a/libsolidity/inlineasm/AsmCodeGen.cpp
+++ b/libsolidity/inlineasm/AsmCodeGen.cpp
@@ -25,6 +25,7 @@
#include <functional>
#include <libevmasm/Assembly.h>
#include <libevmasm/SourceLocation.h>
+#include <libevmasm/Instruction.h>
#include <libsolidity/inlineasm/AsmParser.h>
#include <libsolidity/inlineasm/AsmData.h>
@@ -116,7 +117,7 @@ public:
m_identifierAccess = [](assembly::Identifier const&, eth::Assembly&, CodeGenerator::IdentifierContext) { return false; };
}
- void operator()(Instruction const& _instruction)
+ void operator()(dev::solidity::assembly::Instruction const& _instruction)
{
m_state.assembly.append(_instruction.instruction);
}
@@ -145,7 +146,7 @@ public:
"Variable inaccessible, too deep inside stack (" + boost::lexical_cast<string>(heightDiff) + ")"
);
else
- m_state.assembly.append(eth::dupInstruction(heightDiff));
+ m_state.assembly.append(solidity::dupInstruction(heightDiff));
return;
}
else if (eth::AssemblyItem const* label = m_state.findLabel(_identifier.name))
@@ -196,7 +197,7 @@ public:
//@TODO check height before and after
while (m_state.variables.size() > numVariables)
{
- m_state.assembly.append(eth::Instruction::POP);
+ m_state.assembly.append(solidity::Instruction::POP);
m_state.variables.pop_back();
}
}
@@ -215,8 +216,8 @@ private:
);
else
{
- m_state.assembly.append(eth::swapInstruction(heightDiff));
- m_state.assembly.append(eth::Instruction::POP);
+ m_state.assembly.append(solidity::swapInstruction(heightDiff));
+ m_state.assembly.append(solidity::Instruction::POP);
}
return;
}
diff --git a/libsolidity/inlineasm/AsmData.h b/libsolidity/inlineasm/AsmData.h
index 0361a4c2..42f0ae31 100644
--- a/libsolidity/inlineasm/AsmData.h
+++ b/libsolidity/inlineasm/AsmData.h
@@ -23,7 +23,7 @@
#pragma once
#include <boost/variant.hpp>
-#include <libevmcore/Instruction.h>
+#include <libevmasm/Instruction.h>
namespace dev
{
@@ -35,7 +35,7 @@ namespace assembly
/// What follows are the AST nodes for assembly.
/// Direct EVM instruction (except PUSHi and JUMPDEST)
-struct Instruction { eth::Instruction instruction; };
+struct Instruction { solidity::Instruction instruction; };
/// Literal number or string (up to 32 bytes)
struct Literal { bool isNumber; std::string value; };
/// External / internal identifier or label reference
diff --git a/libsolidity/inlineasm/AsmParser.cpp b/libsolidity/inlineasm/AsmParser.cpp
index 124a5d26..68050733 100644
--- a/libsolidity/inlineasm/AsmParser.cpp
+++ b/libsolidity/inlineasm/AsmParser.cpp
@@ -23,7 +23,6 @@
#include <libsolidity/inlineasm/AsmParser.h>
#include <ctype.h>
#include <algorithm>
-#include <libevmcore/Instruction.h>
#include <libsolidity/parsing/Scanner.h>
using namespace std;
@@ -121,17 +120,17 @@ assembly::Statement Parser::parseExpression()
assembly::Statement Parser::parseElementaryOperation(bool _onlySinglePusher)
{
// Allowed instructions, lowercase names.
- static map<string, eth::Instruction> s_instructions;
+ static map<string, dev::solidity::Instruction> s_instructions;
if (s_instructions.empty())
- for (auto const& instruction: eth::c_instructions)
+ for (auto const& instruction: solidity::c_instructions)
{
if (
- instruction.second == eth::Instruction::JUMPDEST ||
- (eth::Instruction::PUSH1 <= instruction.second && instruction.second <= eth::Instruction::PUSH32)
+ instruction.second == solidity::Instruction::JUMPDEST ||
+ (solidity::Instruction::PUSH1 <= instruction.second && instruction.second <= solidity::Instruction::PUSH32)
)
continue;
string name = instruction.first;
- if (instruction.second == eth::Instruction::SUICIDE)
+ if (instruction.second == solidity::Instruction::SUICIDE)
name = "selfdestruct";
transform(name.begin(), name.end(), name.begin(), [](unsigned char _c) { return tolower(_c); });
s_instructions[name] = instruction.second;
@@ -152,10 +151,10 @@ assembly::Statement Parser::parseElementaryOperation(bool _onlySinglePusher)
// first search the set of instructions.
if (s_instructions.count(literal))
{
- eth::Instruction const& instr = s_instructions[literal];
+ dev::solidity::Instruction const& instr = s_instructions[literal];
if (_onlySinglePusher)
{
- eth::InstructionInfo info = eth::instructionInfo(instr);
+ InstructionInfo info = dev::solidity::instructionInfo(instr);
if (info.ret != 1)
fatalParserError("Instruction " + info.name + " not allowed in this context.");
}
@@ -200,11 +199,11 @@ FunctionalInstruction Parser::parseFunctionalInstruction(assembly::Statement con
{
if (_instruction.type() != typeid(Instruction))
fatalParserError("Assembly instruction required in front of \"(\")");
- eth::Instruction instr = boost::get<Instruction>(_instruction).instruction;
- eth::InstructionInfo instrInfo = eth::instructionInfo(instr);
- if (eth::Instruction::DUP1 <= instr && instr <= eth::Instruction::DUP16)
+ solidity::Instruction instr = boost::get<solidity::assembly::Instruction>(_instruction).instruction;
+ InstructionInfo instrInfo = instructionInfo(instr);
+ if (solidity::Instruction::DUP1 <= instr && instr <= solidity::Instruction::DUP16)
fatalParserError("DUPi instructions not allowed for functional notation");
- if (eth::Instruction::SWAP1 <= instr && instr <= eth::Instruction::SWAP16)
+ if (solidity::Instruction::SWAP1 <= instr && instr <= solidity::Instruction::SWAP16)
fatalParserError("SWAPi instructions not allowed for functional notation");
expectToken(Token::LParen);