diff options
author | chriseth <chris@ethereum.org> | 2017-06-24 00:55:47 +0800 |
---|---|---|
committer | chriseth <chris@ethereum.org> | 2017-06-24 02:12:22 +0800 |
commit | 5a75581f6643a229ab12a861d0b0663ea3e5158e (patch) | |
tree | 729d81a12ee3aefe88a41abfc9d890f30a35edde /libsolidity/codegen/ContractCompiler.cpp | |
parent | b83f77e0e567b58c2ada831e526ad5bacfed8b40 (diff) | |
download | dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.tar dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.tar.gz dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.tar.bz2 dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.tar.lz dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.tar.xz dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.tar.zst dexon-solidity-5a75581f6643a229ab12a861d0b0663ea3e5158e.zip |
Disallow invoking the same modifier multiple times.
Diffstat (limited to 'libsolidity/codegen/ContractCompiler.cpp')
-rw-r--r-- | libsolidity/codegen/ContractCompiler.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/libsolidity/codegen/ContractCompiler.cpp b/libsolidity/codegen/ContractCompiler.cpp index dc090634..8724521b 100644 --- a/libsolidity/codegen/ContractCompiler.cpp +++ b/libsolidity/codegen/ContractCompiler.cpp @@ -879,6 +879,7 @@ void ContractCompiler::appendModifierOrFunctionCode() solAssert(m_currentFunction, ""); unsigned stackSurplus = 0; Block const* codeBlock = nullptr; + vector<VariableDeclaration const*> addedVariables; m_modifierDepth++; @@ -902,6 +903,7 @@ void ContractCompiler::appendModifierOrFunctionCode() for (unsigned i = 0; i < modifier.parameters().size(); ++i) { m_context.addVariable(*modifier.parameters()[i]); + addedVariables.push_back(modifier.parameters()[i].get()); compileExpression( *modifierInvocation->arguments()[i], modifier.parameters()[i]->annotation().type @@ -928,6 +930,8 @@ void ContractCompiler::appendModifierOrFunctionCode() m_returnTags.pop_back(); CompilerUtils(m_context).popStackSlots(stackSurplus); + for (auto var: addedVariables) + m_context.removeVariable(*var); } m_modifierDepth--; } |