diff --git a/play-json/shared/src/main/scala-2/play/api/libs/json/JsMacroImpl.scala b/play-json/shared/src/main/scala-2/play/api/libs/json/JsMacroImpl.scala index 0152050f4..98ce49397 100644 --- a/play-json/shared/src/main/scala-2/play/api/libs/json/JsMacroImpl.scala +++ b/play-json/shared/src/main/scala-2/play/api/libs/json/JsMacroImpl.scala @@ -556,22 +556,23 @@ class JsMacroImpl(val c: blackbox.Context) { val tpeSym = atag.tpe.typeSymbol.asClass @tailrec - def allSubclasses(path: List[Symbol], subclasses: mutable.LinkedHashSet[Type]): mutable.LinkedHashSet[Type] = path match { - case (cls: ClassSymbol) :: tail if tpeSym != cls && cls.selfType.baseClasses.contains(tpeSym) => { - if (cls.typeParams.nonEmpty) - c.warning(c.enclosingPosition, s"cannot handle class ${cls.fullName}: type parameter not supported") - val newSub = if (cls.typeParams.isEmpty) Set(cls.selfType) else Set.empty - allSubclasses(tail, subclasses ++ newSub) - } + def allSubclasses(path: List[Symbol], subclasses: mutable.LinkedHashSet[Type]): mutable.LinkedHashSet[Type] = + path match { + case (cls: ClassSymbol) :: tail if tpeSym != cls && cls.selfType.baseClasses.contains(tpeSym) => { + if (cls.typeParams.nonEmpty) + c.warning(c.enclosingPosition, s"cannot handle class ${cls.fullName}: type parameter not supported") + val newSub = if (cls.typeParams.isEmpty) Set(cls.selfType) else Set.empty + allSubclasses(tail, subclasses ++ newSub) + } - case (o: ModuleSymbol) :: tail - if o.companion == NoSymbol // not a companion object - && o.typeSignature.baseClasses.contains(tpeSym) => - allSubclasses(tail, subclasses ++ Set(o.typeSignature)) + case (o: ModuleSymbol) :: tail + if o.companion == NoSymbol // not a companion object + && o.typeSignature.baseClasses.contains(tpeSym) => + allSubclasses(tail, subclasses ++ Set(o.typeSignature)) - case _ :: tail => allSubclasses(tail, subclasses) - case _ => subclasses - } + case _ :: tail => allSubclasses(tail, subclasses) + case _ => subclasses + } if (tpeSym.isSealed && tpeSym.isAbstract) { Some(allSubclasses(tpeSym.owner.typeSignature.decls.sorted, mutable.LinkedHashSet[Type]()).toList)