From 0f2613c7aec3c222e191ca86301db1fb8127a716 Mon Sep 17 00:00:00 2001 From: Oliver Bracevac Date: Tue, 1 Oct 2024 11:43:51 +0200 Subject: [PATCH] Localize TypeError handling in addRecheckedTypes --- .../dotty/tools/dotc/transform/Recheck.scala | 19 ++++++++----------- 1 file changed, 8 insertions(+), 11 deletions(-) diff --git a/compiler/src/dotty/tools/dotc/transform/Recheck.scala b/compiler/src/dotty/tools/dotc/transform/Recheck.scala index ecf5c69d1f91..7520767c918c 100644 --- a/compiler/src/dotty/tools/dotc/transform/Recheck.scala +++ b/compiler/src/dotty/tools/dotc/transform/Recheck.scala @@ -33,10 +33,13 @@ object Recheck: val addRecheckedTypes = new TreeMap: override def transform(tree: Tree)(using Context): Tree = - val tree1 = super.transform(tree) - tree.getAttachment(RecheckedType) match - case Some(tpe) => tree1.withType(tpe) - case None => tree1 + try + val tree1 = super.transform(tree) + tree.getAttachment(RecheckedType) match + case Some(tpe) => tree1.withType(tpe) + case None => tree1 + catch + case _:TypeError => tree extension (sym: Symbol)(using Context) @@ -618,13 +621,7 @@ abstract class Recheck extends Phase, SymTransformer: override def show(tree: untpd.Tree)(using Context): String = atPhase(thisPhase): withMode(Mode.Printing): - val ttree0 = tree.asInstanceOf[tpd.Tree] - val ttree1 = - try - addRecheckedTypes.transform(ttree0) - catch - case _:TypeError => ttree0 - super.show(ttree1) + super.show(addRecheckedTypes.transform(tree.asInstanceOf[tpd.Tree])) end Recheck /** A class that can be used to test basic rechecking without any customaization */