aboutsummaryrefslogtreecommitdiffstats
path: root/CompilerContext.cpp
diff options
context:
space:
mode:
authorGav Wood <g@ethdev.com>2015-01-27 07:01:25 +0800
committerGav Wood <g@ethdev.com>2015-01-27 07:01:25 +0800
commit8d09d8deb75a28b43a493d8afee5e743a3b201bb (patch)
treeb99e93e50d7203026cfad74e0e70ac6de654f6b1 /CompilerContext.cpp
parentfe37aad4d52f2ddd3d9fd6f6249a9a94394eaf1c (diff)
parentf59cda76def4b1d24236e5a110bfebbd688c5d1a (diff)
downloaddexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.tar
dexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.tar.gz
dexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.tar.bz2
dexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.tar.lz
dexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.tar.xz
dexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.tar.zst
dexon-solidity-8d09d8deb75a28b43a493d8afee5e743a3b201bb.zip
Merge pull request #856 from chriseth/sol_modifiers
Function modifiers.
Diffstat (limited to 'CompilerContext.cpp')
-rw-r--r--CompilerContext.cpp28
1 files changed, 20 insertions, 8 deletions
diff --git a/CompilerContext.cpp b/CompilerContext.cpp
index 27ec3efd..ad1877ba 100644
--- a/CompilerContext.cpp
+++ b/CompilerContext.cpp
@@ -43,10 +43,11 @@ void CompilerContext::addStateVariable(VariableDeclaration const& _declaration)
m_stateVariablesSize += _declaration.getType()->getStorageSize();
}
-void CompilerContext::addVariable(VariableDeclaration const& _declaration)
+void CompilerContext::addVariable(VariableDeclaration const& _declaration,
+ unsigned _offsetToCurrent)
{
- m_localVariables[&_declaration] = m_localVariablesSize;
- m_localVariablesSize += _declaration.getType()->getSizeOnStack();
+ solAssert(m_asm.deposit() >= 0 && unsigned(m_asm.deposit()) >= _offsetToCurrent, "");
+ m_localVariables[&_declaration] = unsigned(m_asm.deposit()) - _offsetToCurrent;
}
void CompilerContext::addAndInitializeVariable(VariableDeclaration const& _declaration)
@@ -56,7 +57,6 @@ void CompilerContext::addAndInitializeVariable(VariableDeclaration const& _decla
int const size = _declaration.getType()->getSizeOnStack();
for (int i = 0; i < size; ++i)
*this << u256(0);
- m_asm.adjustDeposit(-size);
}
void CompilerContext::addFunction(FunctionDefinition const& _function)
@@ -66,6 +66,11 @@ void CompilerContext::addFunction(FunctionDefinition const& _function)
m_virtualFunctionEntryLabels.insert(make_pair(_function.getName(), tag));
}
+void CompilerContext::addModifier(ModifierDefinition const& _modifier)
+{
+ m_functionModifiers.insert(make_pair(_modifier.getName(), &_modifier));
+}
+
bytes const& CompilerContext::getCompiledContract(const ContractDefinition& _contract) const
{
auto ret = m_compiledContracts.find(&_contract);
@@ -75,7 +80,7 @@ bytes const& CompilerContext::getCompiledContract(const ContractDefinition& _con
bool CompilerContext::isLocalVariable(Declaration const* _declaration) const
{
- return m_localVariables.count(_declaration) > 0;
+ return m_localVariables.count(_declaration);
}
eth::AssemblyItem CompilerContext::getFunctionEntryLabel(FunctionDefinition const& _function) const
@@ -92,21 +97,28 @@ eth::AssemblyItem CompilerContext::getVirtualFunctionEntryLabel(FunctionDefiniti
return res->second.tag();
}
+ModifierDefinition const& CompilerContext::getFunctionModifier(string const& _name) const
+{
+ auto res = m_functionModifiers.find(_name);
+ solAssert(res != m_functionModifiers.end(), "Function modifier override not found.");
+ return *res->second;
+}
+
unsigned CompilerContext::getBaseStackOffsetOfVariable(Declaration const& _declaration) const
{
auto res = m_localVariables.find(&_declaration);
solAssert(res != m_localVariables.end(), "Variable not found on stack.");
- return m_localVariablesSize - res->second - 1;
+ return res->second;
}
unsigned CompilerContext::baseToCurrentStackOffset(unsigned _baseOffset) const
{
- return _baseOffset + m_asm.deposit();
+ return m_asm.deposit() - _baseOffset - 1;
}
unsigned CompilerContext::currentToBaseStackOffset(unsigned _offset) const
{
- return -baseToCurrentStackOffset(-_offset);
+ return m_asm.deposit() - _offset - 1;
}
u256 CompilerContext::getStorageLocationOfVariable(const Declaration& _declaration) const