aboutsummaryrefslogtreecommitdiff
path: root/src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala
diff options
context:
space:
mode:
authorFelix Mulder <felix.mulder@gmail.com>2016-05-26 12:06:56 +0200
committerFelix Mulder <felix.mulder@gmail.com>2016-05-26 13:20:11 +0200
commit73f099ba506f6e877b676022a12cfdd31ab915b7 (patch)
tree0011f3add02b2b46fa8c6e894addbd7e74b22b44 /src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala
parentfa81e54db9ebb36c7f76cbedfa98115e50a8f88c (diff)
downloaddotty-73f099ba506f6e877b676022a12cfdd31ab915b7.tar.gz
dotty-73f099ba506f6e877b676022a12cfdd31ab915b7.tar.bz2
dotty-73f099ba506f6e877b676022a12cfdd31ab915b7.zip
Fix double evaluation of scrutinee with side-effects, add test
Diffstat (limited to 'src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala')
-rw-r--r--src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala17
1 files changed, 7 insertions, 10 deletions
diff --git a/src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala b/src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala
index 584628acd..6765604c8 100644
--- a/src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala
+++ b/src/dotty/tools/dotc/transform/IsInstanceOfEvaluator.scala
@@ -91,16 +91,13 @@ class IsInstanceOfEvaluator extends MiniPhaseTransform { thisTransformer =>
*
* `scrutinee.isInstanceOf[Selector]` if `scrutinee eq null`
*/
- def rewrite(tree: Select, to: Boolean): Tree = {
- val expr =
- if (!to || !tree.qualifier.tpe.widen.derivesFrom(defn.AnyRefAlias))
- Literal(Constant(to))
- else
- Apply(tree.qualifier.select(defn.Object_ne), List(Literal(Constant(null))))
-
- if (!isPureExpr(tree.qualifier)) Block(List(tree.qualifier), expr)
- else expr
- }
+ def rewrite(tree: Select, to: Boolean): Tree =
+ if (!to || !tree.qualifier.tpe.widen.derivesFrom(defn.AnyRefAlias)) {
+ val literal = Literal(Constant(to))
+ if (!isPureExpr(tree.qualifier)) Block(List(tree.qualifier), literal)
+ else literal
+ } else
+ Apply(tree.qualifier.select(defn.Object_ne), List(Literal(Constant(null))))
/** Attempts to rewrite TypeApply to either `scrutinee ne null` or a
* constant