All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.scalameta.internal.FreeLocalFinder.scala Maven / Gradle / Ivy

package org.scalameta
package internal

import scala.reflect.macros.blackbox.Context

trait FreeLocalFinder {
  val c: Context

  import c.internal._
  import c.internal.decorators._
  import c.universe._

  def freeLocals(tree: Tree): Map[String, Tree] = {
    object freeLocalFinder extends Traverser {
      private val localRefs = scala.collection.mutable.ListBuffer[Tree]()
      private val localSyms = scala.collection.mutable.Set[Symbol]()
      def registerLocalSym(sym: Symbol): Unit = if (sym != null && sym != NoSymbol) localSyms += sym
      def processLocalDef(tree: Tree): Unit = if (tree.symbol != null && tree.symbol != NoSymbol) {
        val sym = tree.symbol
        registerLocalSym(sym)
        registerLocalSym(sym.deSkolemize)
        registerLocalSym(sym.companion)
        sym match {
          case sym: ClassSymbol => registerLocalSym(sym.module)
          case sym: ModuleSymbol => registerLocalSym(sym.moduleClass)
          case _ => ;
        }
      }
      override def traverse(tree: Tree): Unit = {
        val sym = tree.symbol
        tree match {
          case tree: Ident
              if !sym.owner.isClass && tree.name != termNames.WILDCARD && !sym.isMethod =>
            localRefs += tree
          case tree: This if !sym.isPackageClass => localRefs += tree
          case _: DefTree | Function(_, _) | Template(_, _, _) =>
            processLocalDef(tree); super.traverse(tree)
          case _ => super.traverse(tree)
        }
      }
      def freeLocals = localRefs.filter(ref => !localSyms.contains(ref.symbol))
    }
    freeLocalFinder.traverse(tree)
    freeLocalFinder.freeLocals.map(tree => tree.symbol.name.toString -> tree.duplicate).toMap
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy