aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/codegen/ContractCompiler.cpp
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2017-01-21 02:01:19 +0800
committerchriseth <c@ethdev.com>2017-01-21 02:01:19 +0800
commit2536bdd6d0dfa1685967fd3106c682e0bcf17021 (patch)
tree9f90a43745c2b2adbfdbcc29aa2e3ced963b63a3 /libsolidity/codegen/ContractCompiler.cpp
parent12b002b3b8575539f332c30691e880bcc2fac5bc (diff)
downloaddexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.tar
dexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.tar.gz
dexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.tar.bz2
dexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.tar.lz
dexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.tar.xz
dexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.tar.zst
dexon-solidity-2536bdd6d0dfa1685967fd3106c682e0bcf17021.zip
Report source location on "stack too deep" errors.
Diffstat (limited to 'libsolidity/codegen/ContractCompiler.cpp')
-rw-r--r--libsolidity/codegen/ContractCompiler.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/libsolidity/codegen/ContractCompiler.cpp b/libsolidity/codegen/ContractCompiler.cpp
index fa77c1aa..bdff0da4 100644
--- a/libsolidity/codegen/ContractCompiler.cpp
+++ b/libsolidity/codegen/ContractCompiler.cpp
@@ -486,7 +486,12 @@ bool ContractCompiler::visit(FunctionDefinition const& _function)
stackLayout.push_back(i);
stackLayout += vector<int>(c_localVariablesSize, -1);
- solAssert(stackLayout.size() <= 17, "Stack too deep, try removing local variables.");
+ if (stackLayout.size() > 17)
+ BOOST_THROW_EXCEPTION(
+ CompilerError() <<
+ errinfo_sourceLocation(_function.location()) <<
+ errinfo_comment("Stack too deep, try removing local variables.")
+ );
while (stackLayout.back() != int(stackLayout.size() - 1))
if (stackLayout.back() < 0)
{
@@ -551,6 +556,7 @@ bool ContractCompiler::visit(InlineAssembly const& _inlineAssembly)
if (stackDiff < 1 || stackDiff > 16)
BOOST_THROW_EXCEPTION(
CompilerError() <<
+ errinfo_sourceLocation(_inlineAssembly.location()) <<
errinfo_comment("Stack too deep, try removing local variables.")
);
for (unsigned i = 0; i < variable->type()->sizeOnStack(); ++i)
@@ -591,6 +597,7 @@ bool ContractCompiler::visit(InlineAssembly const& _inlineAssembly)
if (stackDiff > 16 || stackDiff < 1)
BOOST_THROW_EXCEPTION(
CompilerError() <<
+ errinfo_sourceLocation(_inlineAssembly.location()) <<
errinfo_comment("Stack too deep, try removing local variables.")
);
for (unsigned i = 0; i < size; ++i) {