aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-12-06 00:58:23 +0800
committerGitHub <noreply@github.com>2018-12-06 00:58:23 +0800
commit32c9da9419499bf839f239ef3e1a8df627218ade (patch)
treefdba939956682345bf0ef66164e701b37944109d
parent63d67c715326209ba1dc2c3800db90830d2c4e13 (diff)
parent54846ed0a708d57d25ac5eadd618f8137867df66 (diff)
downloaddexon-solidity-32c9da9419499bf839f239ef3e1a8df627218ade.tar.gz
dexon-solidity-32c9da9419499bf839f239ef3e1a8df627218ade.tar.zst
dexon-solidity-32c9da9419499bf839f239ef3e1a8df627218ade.zip
Merge pull request #5593 from ethereum/issue-5384
Fix expression simplifier asserting on default values
-rw-r--r--libyul/optimiser/SimplificationRules.cpp3
-rw-r--r--test/libyul/yulOptimizerTests/expressionSimplifier/unassigned_vars.yul14
2 files changed, 16 insertions, 1 deletions
diff --git a/libyul/optimiser/SimplificationRules.cpp b/libyul/optimiser/SimplificationRules.cpp
index b3190fef..8ed63fa8 100644
--- a/libyul/optimiser/SimplificationRules.cpp
+++ b/libyul/optimiser/SimplificationRules.cpp
@@ -114,7 +114,8 @@ bool Pattern::matches(Expression const& _expr, map<YulString, Expression const*>
{
YulString varName = boost::get<Identifier>(_expr).name;
if (_ssaValues.count(varName))
- expr = _ssaValues.at(varName);
+ if (Expression const* new_expr = _ssaValues.at(varName))
+ expr = new_expr;
}
assertThrow(expr, OptimizerException, "");
diff --git a/test/libyul/yulOptimizerTests/expressionSimplifier/unassigned_vars.yul b/test/libyul/yulOptimizerTests/expressionSimplifier/unassigned_vars.yul
new file mode 100644
index 00000000..87391b8c
--- /dev/null
+++ b/test/libyul/yulOptimizerTests/expressionSimplifier/unassigned_vars.yul
@@ -0,0 +1,14 @@
+// c & d can't be optimized as expression simplifier doesn't handle default
+// values yet
+{
+ let c
+ let d
+ let y := add(d, add(c, 7))
+}
+// ----
+// expressionSimplifier
+// {
+// let c
+// let d
+// let y := add(add(d, c), 7)
+// }