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

scala.tools.nsc.backend.icode.Repository.scala Maven / Gradle / Ivy

/* NSC -- new Scala compiler
 * Copyright 2005-2013 LAMP/EPFL
 * @author  Martin Odersky
 */


package scala.tools.nsc
package backend
package icode

import scala.collection._

/**
 *  @author Iulian Dragos
 */
trait Repository {
  val global: Global
  import global._
  import icodes._

  val loaded: mutable.Map[Symbol, IClass] = perRunCaches.newMap()

  /** Is the given class available as icode? */
  def available(sym: Symbol) = classes.contains(sym) || loaded.contains(sym)

  /** The icode of the given class, if available */
  def icode(sym: Symbol): Option[IClass] = (classes get sym) orElse (loaded get sym)

  /** The icode of the given class. If not available, it loads
   *  its bytecode.
   */
  def icode(sym: Symbol, force: Boolean): IClass =
    icode(sym) getOrElse {
      log("loading " + sym)
      load(sym)
      assert(available(sym))
      loaded(sym)
    }

  /** Load bytecode for given symbol. */
  def load(sym: Symbol): Boolean = {
    try {
      val (c1, c2) = icodeReader.readClass(sym)

      assert(c1.symbol == sym || c2.symbol == sym, "c1.symbol = %s, c2.symbol = %s, sym = %s".format(c1.symbol, c2.symbol, sym))
      loaded += (c1.symbol -> c1)
      loaded += (c2.symbol -> c2)

      true
    } catch {
      case e: Throwable => // possible exceptions are MissingRequirementError, IOException and TypeError -> no better common supertype
        log("Failed to load %s. [%s]".format(sym.fullName, e.getMessage))
        if (settings.debug.value) { e.printStackTrace }

        false
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy