Packages

  • package root
    Definition Classes
    root
  • package scala
    Definition Classes
    root
  • package tools
    Definition Classes
    scala
  • package nsc
    Definition Classes
    tools
  • package interpreter

    The main REPL related classes and values are as follows.

    The main REPL related classes and values are as follows. In addition to standard compiler classes Global and Settings, there are:

    History: an interface for session history. Completion: an interface for tab completion. ILoop (formerly InterpreterLoop): The umbrella class for a session. IMain (formerly Interpreter): Handles the evolving state of the session and handles submitting code to the compiler and handling the output. InteractiveReader: how ILoop obtains input. History: an interface for session history. Completion: an interface for tab completion. Power: a repository for more advanced/experimental features.

    ILoop contains { in: InteractiveReader, intp: IMain, settings: Settings, power: Power } InteractiveReader contains { history: History, completion: Completion } IMain contains { global: Global }

    Definition Classes
    nsc
  • class IMain extends Imports with PresentationCompilation

    An interpreter for Scala code.

    An interpreter for Scala code.

    The main public entry points are compile(), interpret(), and bind(). The compile() method loads a complete Scala file. The interpret() method executes one line of Scala code at the request of the user. The bind() method binds an object to a variable that can then be used by later interpreted code.

    The overall approach is based on compiling the requested code and then using a Java classloader and Java reflection to run the code and access its results.

    In more detail, a single compiler instance is used to accumulate all successfully compiled or interpreted Scala code. To "interpret" a line of code, the compiler generates a fresh object that includes the line of code and which has public member(s) to export all variables defined by that code. To extract the result of an interpreted line to show the user, a second "result object" is created which imports the variables exported by the above object and then exports members called "$eval" and "$print". To accommodate user expressions that read from variables or methods defined in previous statements, "import" statements are used.

    This interpreter shares the strengths and weaknesses of using the full compiler-to-Java. The main strength is that interpreted code behaves exactly as does compiled code, including running at full speed. The main weakness is that redefining classes and methods is not handled properly, because rebinding at the Java level is technically difficult.

    Definition Classes
    interpreter
  • ComputedImports
  • PhaseDependentOps
  • PresentationCompileResult
  • ReadEvalPrint
  • ReplTypeOps
  • Request
  • deconstruct
  • exprTyper
  • flatOp
  • naming
  • parse
  • replOutput
  • typerOp

class Request extends AnyRef

One line of code submitted by the user for interpretation

Linear Supertypes
AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Request
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Request(line: String, trees: List[Global.Tree], generousImports: Boolean = false)

Type Members

  1. class ClassBasedWrapper extends Wrapper
  2. class ObjectBasedWrapper extends Wrapper
  3. abstract class Wrapper extends CodeAssembler[(memberHandlers)#MemberHandler]

    generate the source code for the object that computes this request

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. lazy val accessPath: String

    Code to import bound names from previous lines - accessPath is code to append to objectName to access anything bound by request.

  5. def applyToResultMember[T](name: Global.Name, f: (Global.Symbol) ⇒ T): T
  6. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  7. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  8. lazy val compile: Boolean

    Compile the object file.

    Compile the object file. Returns whether the compilation succeeded. If all goes well, the "types" map is computed.

  9. lazy val compilerTypeOf: Map[Global.Name, Global.Type]

    Types of variables defined by this request.

  10. def defHandlers: collection.immutable.List[(memberHandlers)#MemberDefHandler]
  11. lazy val definedSymbols: Map[Global.Name, Global.Symbol]
  12. def defines: collection.immutable.List[Global.Symbol]
  13. val definesClass: Boolean
  14. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  16. def finalize(): Unit
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  17. def fullAccessPath: String

    The path of the value that contains the user code.

  18. def fullPath(vname: String): String

    The path of the given member of the wrapping instance.

  19. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  20. val handlers: List[(memberHandlers)#MemberHandler]

    handlers for each tree in this request

  21. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  22. lazy val headerPreamble: String

    Code to import bound names from previous lines - accessPath is code to append to objectName to access anything bound by request.

  23. def importedSymbols: collection.immutable.List[Global.Symbol]
  24. def imports: collection.immutable.List[Global.Symbol]
  25. lazy val importsPreamble: String

    Code to import bound names from previous lines - accessPath is code to append to objectName to access anything bound by request.

  26. lazy val importsTrailer: String

    Code to import bound names from previous lines - accessPath is code to append to objectName to access anything bound by request.

  27. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  28. val line: String
  29. val lineRep: ReadEvalPrint
  30. def loadAndRun: (String, Boolean)

    load and run the code using reflection

  31. def lookupTypeOf(name: Global.Name): String
  32. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  33. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  34. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  35. def originalLine: String
  36. val referencedNames: List[Global.Name]

    list of names used by this expression

  37. lazy val resultSymbol: Global.Symbol
  38. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  39. def termNames: collection.immutable.List[Global.TermName]

    def and val names

  40. def toCompute: String

    the line of code to compute

  41. def toString(): String
    Definition Classes
    Request → AnyRef → Any
  42. val trees: List[Global.Tree]
  43. def typeNames: collection.immutable.List[Global.TypeName]
  44. lazy val typeOf: Map[Global.Name, String]

    String representations of same.

  45. lazy val typesOfDefinedTerms: Map[Global.Name, Global.Type]
  46. def value: Global.Symbol
  47. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  48. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  49. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  50. def withOriginalLine(s: String): Request.this.type

Inherited from AnyRef

Inherited from Any

Ungrouped