org.kiama.example.oberon0.drivers

A3Tests

class A3Tests extends A3Phases with TestDriver

Annotations
@RunWith()
Linear Supertypes
TestDriver, TestCompiler[ModuleDecl], FunSuite, Suite, Serializable, AbstractSuite, Assertions, A3Phases, Desugarer, Desugarer, Lifter, Transformer, TypeAnalyser, TypeAnalyser, TypeAnalyser, TypeAnalyser, NameAnalyser, SymbolTable, NameAnalyser, NameAnalyser, SymbolTable, SymbolTable, Environments, Analyser, PrettyPrinter, PrettyPrinter, PrettyPrinter, PrettyPrinter, PrettyPrinter, SourcePrettyPrinter, ParenPrettyPrinter, L3.Parser, L2.Parser, L1.Parser, L0.Parser, base.Parser, WhitespacePositionedParserUtilities, PositionedParserUtilities, WhitespaceParser, ParserUtilities, PackratParsers, RegexParsers, Parsers, TransformingDriver, Driver, PrettyPrinter, PrettyPrinterBase, Compiler[ModuleDecl], RegexCompiler[ModuleDecl], CompilerBase[ModuleDecl], AnyRef, Any
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. A3Tests
  2. TestDriver
  3. TestCompiler
  4. FunSuite
  5. Suite
  6. Serializable
  7. AbstractSuite
  8. Assertions
  9. A3Phases
  10. Desugarer
  11. Desugarer
  12. Lifter
  13. Transformer
  14. TypeAnalyser
  15. TypeAnalyser
  16. TypeAnalyser
  17. TypeAnalyser
  18. NameAnalyser
  19. SymbolTable
  20. NameAnalyser
  21. NameAnalyser
  22. SymbolTable
  23. SymbolTable
  24. Environments
  25. Analyser
  26. PrettyPrinter
  27. PrettyPrinter
  28. PrettyPrinter
  29. PrettyPrinter
  30. PrettyPrinter
  31. SourcePrettyPrinter
  32. ParenPrettyPrinter
  33. Parser
  34. Parser
  35. Parser
  36. Parser
  37. Parser
  38. WhitespacePositionedParserUtilities
  39. PositionedParserUtilities
  40. WhitespaceParser
  41. ParserUtilities
  42. PackratParsers
  43. RegexParsers
  44. Parsers
  45. TransformingDriver
  46. Driver
  47. PrettyPrinter
  48. PrettyPrinterBase
  49. Compiler
  50. RegexCompiler
  51. CompilerBase
  52. AnyRef
  53. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Instance Constructors

  1. new A3Tests()

Type Members

  1. trait Builtin extends Named

    Marker trait for all built-in entities.

  2. case class BuiltinProc(ident: String, params: List[ParamInfo]) extends Entity with NamedEntity with Builtin with Product with Serializable

    A built-in procedure with its parameter information.

  3. case class BuiltinType(ident: String) extends Type with Named with Builtin with Product with Serializable

    A built-in type with an implicit definition that the compiler must have special knowledge about.

  4. case class Constant(ident: String, decl: ConstDecl) extends Entity with NamedEntity with Product with Serializable

    A user-defined constant entity represented by a constant declaration.

  5. class Doc extends ((output.PrettyPrinter.Indent, output.PrettyPrinter.Width)) ⇒ ((Int, Queue[(Int, (Boolean) ⇒ ((Int) ⇒ output.PrettyPrinter.Layout) ⇒ (Int) ⇒ output.PrettyPrinter.Layout)]) ⇒ (Int) ⇒ output.PrettyPrinter.Layout) ⇒ (Int, Queue[(Int, (Boolean) ⇒ ((Int) ⇒ output.PrettyPrinter.Layout) ⇒ (Int) ⇒ output.PrettyPrinter.Layout)]) ⇒ (Int) ⇒ output.PrettyPrinter.Layout with output.PrettyPrinter.DocOps

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  6. trait DocOps extends AnyRef

    Definition Classes
    PrettyPrinterBase
  7. type Elem = Char

    Definition Classes
    RegexParsers → Parsers
  8. abstract class Entity extends AnyRef

    Definition Classes
    Environments
  9. type Environment = Stack[Scope]

    Definition Classes
    Environments
  10. final class Equalizer extends AnyRef

    Definition Classes
    Assertions
  11. case class Error extends NoSuccess with Product with Serializable

    Definition Classes
    Parsers
  12. trait ErrorEntity extends Entity

    Definition Classes
    Environments
  13. case class Failure extends NoSuccess with Product with Serializable

    Definition Classes
    Parsers
  14. type Indent = Int

    Definition Classes
    PrettyPrinterBase
  15. type Input = Reader[Elem]

    Definition Classes
    Parsers
  16. case class IntegerValue(ident: String, tipe: Type, value: Int) extends Entity with NamedEntity with Builtin with Product with Serializable

    A built-in value of some type that is represented by a particular integer value.

  17. type Layout = String

    Definition Classes
    PrettyPrinterBase
  18. case class Module(ident: String, decl: ModuleDecl) extends Entity with NamedEntity with Product with Serializable

    A user-defined module represented by a module declaration.

  19. trait Named extends AnyRef

    Definition Classes
    Environments
  20. trait NamedEntity extends Entity with Named

    Definition Classes
    Environments
  21. trait NoArgTest extends () ⇒ Unit

    Attributes
    protected
    Definition Classes
    Suite
  22. sealed abstract class NoSuccess extends ParseResult[Nothing]

    Definition Classes
    Parsers
  23. trait OnceParser[+T] extends Parser[T]

    Definition Classes
    Parsers
  24. abstract class PackratParser[+T] extends scala.util.parsing.combinator.PackratParsers.Parser[T]

    Definition Classes
    PackratParsers
  25. class PackratReader[+T] extends Reader[T]

    Definition Classes
    PackratParsers
  26. case class ParamInfo(mode: Mode, ident: String, tipe: SymbolTable.Type) extends Product with Serializable

    Information about a particular parameter.

  27. case class Parameter(mode: Mode, varr: SymbolTable.Variable) extends Entity with NamedEntity with Product with Serializable

    A parameter is a variable augmented with a passing mode.

  28. sealed abstract class ParseResult[+T] extends AnyRef

    Definition Classes
    Parsers
  29. abstract class Parser[+T] extends (Input) ⇒ ParseResult[T]

    Definition Classes
    Parsers
  30. trait PrettyPrintable extends AnyRef

    Definition Classes
    PrettyPrinterBase
  31. case class Procedure(ident: String, decl: ProcDecl) extends Entity with NamedEntity with Product with Serializable

    A procedure entity represented by a procedure declaration.

  32. type Scope = Map[String, Entity]

    Definition Classes
    Environments
  33. case class Success[+T] extends ParseResult[T] with Product with Serializable

    Definition Classes
    Parsers
  34. abstract class Type extends Entity

    An entity representing by a user-provided type declaration.

  35. case class UserType(ident: String, tipe: TypeDecl) extends Type with Named with Product with Serializable

    A user-defined type.

  36. case class Variable(ident: String, tipe: TypeDef) extends Entity with NamedEntity with Product with Serializable

    A variable entity including a reference to its types' definition.

  37. type Width = Int

    Definition Classes
    PrettyPrinterBase
  38. case class ~[+a, +b] extends Product with Serializable

    Definition Classes
    Parsers

Value Members

  1. final def !=(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

    Definition Classes
    AnyRef → Any
  4. final def ==(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  6. object MultipleEntity extends Entity with ErrorEntity with Product with Serializable

    Definition Classes
    Environments
  7. def OnceParser[T](f: (Input) ⇒ ParseResult[T]): Parser[T] with OnceParser[T]

    Definition Classes
    PositionedParserUtilities → Parsers
  8. def Parser[T](f: (Input) ⇒ ParseResult[T]): Parser[T]

    Definition Classes
    PositionedParserUtilities → Parsers
  9. object UnknownEntity extends Entity with ErrorEntity with Product with Serializable

    Definition Classes
    Environments
  10. def accept[U](expected: String, f: PartialFunction[Elem, U]): Parser[U]

    Definition Classes
    Parsers
  11. def accept[ES](es: ES)(implicit arg0: (ES) ⇒ List[Elem]): Parser[List[Elem]]

    Definition Classes
    Parsers
  12. implicit def accept(e: Elem): Parser[Elem]

    Definition Classes
    Parsers
  13. def acceptIf(p: (Elem) ⇒ Boolean)(err: (Elem) ⇒ String): Parser[Elem]

    Definition Classes
    Parsers
  14. def acceptMatch[U](expected: String, f: PartialFunction[Elem, U]): Parser[U]

    Definition Classes
    Parsers
  15. def acceptSeq[ES](es: ES)(implicit arg0: (ES) ⇒ Iterable[Elem]): Parser[List[Elem]]

    Definition Classes
    Parsers
  16. def angles(d: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  17. def any: PackratParser[Char]

    Definition Classes
    ParserUtilities
  18. def any(a: Any): Doc

    Definition Classes
    PrettyPrinterBase
  19. implicit def anyToPrettyPrintable(a: Any): PrettyPrintable

    Definition Classes
    PrettyPrinterBase
  20. def artefact: String

    The name of this artefact.

    The name of this artefact.

    Definition Classes
    A3PhasesDriver
  21. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  22. def assert(o: Option[String]): Unit

    Definition Classes
    Assertions
  23. def assert(o: Option[String], clue: Any): Unit

    Definition Classes
    Assertions
  24. def assert(condition: Boolean, clue: Any): Unit

    Definition Classes
    Assertions
  25. def assert(condition: Boolean): Unit

    Definition Classes
    Assertions
  26. lazy val assignment: Parser[Assignment]

    Definition Classes
    Parser
  27. def backslash: Doc

    Definition Classes
    PrettyPrinterBase
  28. lazy val basetype: (Expression) ⇒ Type

    The actual type of an expression following type aliases.

    The actual type of an expression following type aliases.

    Definition Classes
    TypeAnalyser
  29. lazy val block: Parser[Block]

    Definition Classes
    Parser
  30. def blockToDoc(b: Block, beginend: Boolean = false): Doc

    Pretty-print a block, omitting the BEGIN if there are no statements.

    Pretty-print a block, omitting the BEGIN if there are no statements. Add the possibility of declarations to the previous level.

    Definition Classes
    PrettyPrinterPrettyPrinter
  31. lazy val booleanType: BuiltinType

    Built-in Boolean type.

    Built-in Boolean type.

    Definition Classes
    SymbolTable
  32. def braces(d: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  33. def bracket(inner: PrettyOperatorExpression, outer: PrettyOperatorExpression, side: Side): Doc

    Definition Classes
    ParenPrettyPrinter
  34. def brackets(d: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  35. lazy val caseStatement: Parser[CaseStatement]

    Definition Classes
    Parser
  36. def caseToDoc(s: CaseStatement): Doc

    Definition Classes
    PrettyPrinter
  37. lazy val cases: Parser[List[Case]]

    Definition Classes
    Parser
  38. def casesToDoc(l: List[Case]): Doc

    Definition Classes
    PrettyPrinter
  39. def casesToIf(ce: IdnExp, cases: List[Case], optelse: Option[Block]): IfStatement

    Return an IF cascade equivaleant to the given cases and optional else block.

    Return an IF cascade equivaleant to the given cases and optional else block. The variable ce holds the selection value. Specifically, these cases on ce CASE e1 : s1 CASE e2 .. e3 : s2 ELSE s3 are transformed into IF ce = e1 THEN s1 ELSEIF (ce >= e2) & (ce <= e3) THEN s2 ELSE 32 END If a case has more than one condition then they are combined with Or operators.

    Definition Classes
    Desugarer
  40. def cat(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  41. def chainl1[T, U](first: ⇒ Parser[T], p: ⇒ Parser[U], q: ⇒ Parser[(T, U) ⇒ T]): Parser[T]

    Definition Classes
    Parsers
  42. def chainl1[T](p: ⇒ Parser[T], q: ⇒ Parser[(T, T) ⇒ T]): Parser[T]

    Definition Classes
    Parsers
  43. def chainr1[T, U](p: ⇒ Parser[T], q: ⇒ Parser[(T, U) ⇒ U], combine: (T, U) ⇒ U, first: U): Parser[U]

    Definition Classes
    Parsers
  44. var challengeFlag: Boolean

    Definition Classes
    Driver
  45. val challengeFlagDefault: Boolean

    Definition Classes
    Driver
  46. implicit def char(c: Char): Doc

    Definition Classes
    PrettyPrinterBase
  47. def check(n: SourceASTNode): Unit

    Check an AST node for semantic errors.

    Check an AST node for semantic errors. Report any errors using the messaging module. This default implementation just ask the node's children to check themselves.

    Definition Classes
    TypeAnalyserNameAnalyserTypeAnalyserTypeAnalyserNameAnalyserAnalyser
  48. def checkNonLocalVarAccess(u: IdnUse): Unit

    Check for non-local variable and procedure accesses.

    Check for non-local variable and procedure accesses. In the L3 language non-local variable accesses are disallowed, unless they are to a variable at the top level. Non-local procedure accesses are just disallowed.

    Definition Classes
    NameAnalyser
  49. def checkargs(args: Array[String], emitter: Emitter): Array[String]

    Process the command-line arguments and return an array of the input file names if processing should continue, None otherwise.

    Process the command-line arguments and return an array of the input file names if processing should continue, None otherwise.

    Definition Classes
    Driver → CompilerBase
  50. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  51. def colon: Doc

    Definition Classes
    PrettyPrinterBase
  52. def comma: Doc

    Definition Classes
    PrettyPrinterBase
  53. lazy val comment: PackratParser[Any]

    Definition Classes
    Parser
  54. def commit[T](p: ⇒ Parser[T]): Parser[T]

    Definition Classes
    Parsers
  55. def compile(args: Array[String], console: Console): String

    Definition Classes
    CompilerBase
  56. lazy val condition: Parser[Condition with Serializable]

    Definition Classes
    Parser
  57. lazy val conditions: Parser[List[Condition with Serializable]]

    Definition Classes
    Parser
  58. implicit def constToTupleFunction2[A, B, R](r: (A, B) ⇒ R): (~[A, B]) ⇒ R

    Definition Classes
    ParserUtilities
  59. implicit def constToTupleFunction3[A, B, C, R](r: (A, B, C) ⇒ R): (~[~[A, B], C]) ⇒ R

    Definition Classes
    ParserUtilities
  60. implicit def constToTupleFunction4[A, B, C, D, R](r: (A, B, C, D) ⇒ R): (~[~[~[A, B], C], D]) ⇒ R

    Definition Classes
    ParserUtilities
  61. implicit def constToTupleFunction5[A, B, C, D, E, R](r: (A, B, C, D, E) ⇒ R): (~[~[~[~[A, B], C], D], E]) ⇒ R

    Definition Classes
    ParserUtilities
  62. implicit def constToTupleFunction6[A, B, C, D, E, F, R](r: (A, B, C, D, E, F) ⇒ R): (~[~[~[~[~[A, B], C], D], E], F]) ⇒ R

    Definition Classes
    ParserUtilities
  63. lazy val constdecl: Parser[ConstDecl]

    Definition Classes
    Parser
  64. lazy val constdeclsection: Parser[List[ConstDecl]]

    Definition Classes
    Parser
  65. lazy val constrainedInt: PackratParser[Int]

    Definition Classes
    ParserUtilities
  66. def consumeast(ast: ModuleDecl, console: Console, emitter: Emitter): Unit

    Process the AST, returning the new one.

    Process the AST, returning the new one. By default, do nothing.

    Definition Classes
    Driver
  67. implicit def convertToEqualizer(left: Any): Equalizer

    Definition Classes
    Assertions
  68. lazy val declarations: PackratParser[List[Declaration]]

    Definition Classes
    Parser
  69. def declarationsDef: PackratParser[List[Declaration with Serializable]]

    Definition Classes
    ParserParserParser
  70. def declsToDoc(ds: List[Declaration]): Doc

    Definition Classes
    PrettyPrinter
  71. def declsection(d: Declaration): String

    Definition Classes
    PrettyPrinterPrettyPrinter
  72. lazy val decltype: (TypeDecl) ⇒ Type

    The built-in type associated with a type declaration.

    The built-in type associated with a type declaration.

    Definition Classes
    TypeAnalyser
  73. val defaultIndent: Int

    Definition Classes
    PrettyPrinterBase
  74. val defaultWidth: Int

    Definition Classes
    PrettyPrinterBase
  75. def defenv: Environment

    The default environment.

    The default environment.

    Definition Classes
    SymbolTable
  76. def defenvPairs: List[(String, Entity)]

    The default environment with pre-defined procedures added.

    The default environment with pre-defined procedures added.

    Definition Classes
    SymbolTableSymbolTable
  77. def define(env: Environment, i: String, e: Entity): Environment

    Definition Classes
    Environments
  78. lazy val deftype: (TypeDef) ⇒ Type

    The type given by a type definition.

    The type given by a type definition.

    Definition Classes
    TypeAnalyser
  79. def deftypeDef: (TypeDef) ⇒ Type

    Definition Classes
    TypeAnalyser
  80. lazy val desugarCase: rewriting.Rewriter.Strategy

    Desugar CASE statements into equivalent blocks containing cascading IF statements.

    Desugar CASE statements into equivalent blocks containing cascading IF statements. A new variable called "casevar" is introduced in the block to hold the selection value so that it does not need to be re-evaluated. Specifically, CASE e OF cases END is transformed into VAR caseval : INTEGER; BEGIN caseval := e; IF caseval ... THEN ... END END

    Definition Classes
    Desugarer
  81. lazy val desugarFor: rewriting.Rewriter.Strategy

    Desugar FOR statements into equivalent blocks containing a WHILE loop.

    Desugar FOR statements into equivalent blocks containing a WHILE loop. A new variable called "limit" is introduced in the block to hold the upper limit of the FOR to protect against changes in the body. Specifically, FOR id := e1 TO e2 BY e3 DO body END is transformed into VAR limit : INTEGER; BEGIN id := e1; limit := e2; WHILE (id op limit) DO body id := id + e3 END END If e3 is negative, op is <=, otherwise it is >=.

    Definition Classes
    Desugarer
  82. def dosanitisation: Boolean

    Flag to decide whether to sanitise the output before comparison of test results with expected results (see sanitise method).

    Flag to decide whether to sanitise the output before comparison of test results with expected results (see sanitise method). Default is true; override with false if you want actual results compared.

    Definition Classes
    TestCompiler
  83. def dot: Doc

    Definition Classes
    PrettyPrinterBase
  84. def dquote: Doc

    Definition Classes
    PrettyPrinterBase
  85. def dquotes(d: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  86. def driver(args: Array[String], console: Console, emitter: Emitter): Unit

    Custom driver for section tagging and challenge mode for errors.

    Custom driver for section tagging and challenge mode for errors. If a parse error occurs: in challenge mode, just send "parse failed" to standard output, otherwise send the message to the errors file.

    Definition Classes
    Driver → CompilerBase
  87. def elem(e: Elem): Parser[Elem]

    Definition Classes
    Parsers
  88. def elem(kind: String, p: (Elem) ⇒ Boolean): Parser[Elem]

    Definition Classes
    Parsers
  89. lazy val elsif: PackratParser[(Expression, Block)]

    Definition Classes
    Parser
  90. lazy val elsifs: Parser[List[(Expression, Block)]]

    Definition Classes
    Parser
  91. def empty: Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  92. def enclose(l: Doc, d: Doc, r: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  93. def enter(env: Environment): Environment

    Definition Classes
    Environments
  94. lazy val entity: (Identifier) ⇒ Entity

    The program entity referred to by an identifier definition or use.

    The program entity referred to by an identifier definition or use. In the case of a definition it's the thing being defined, so define it to be a reference to the declaration. If it's already defined, return a entity that indicates a multiple definition. In the case of a use, it's the thing defined elsewhere that is being referred to here, so look it up in the environment.

    Definition Classes
    NameAnalyser
  95. def entityFromDecl(n: IdnDef, i: String): Entity

    The entity for an identifier definition as given by its declaration context.

    The entity for an identifier definition as given by its declaration context.

    Definition Classes
    NameAnalyserNameAnalyser
  96. lazy val env: Chain[SourceASTNode, Environment]

    The environment containing bindings for all identifiers visible at the given node.

    The environment containing bindings for all identifiers visible at the given node. It starts at the module declaration with the default environment. At blocks we enter a nested scope which is removed on exit from the block. At constant and type declarations the left-hand side binding is not in scope on the right-hand side. Each identifier definition just adds its binding to the chain. The envout cases for assignment and expression mean that we don't need to traverse into those constructs, since declarations can't occur there.

    Definition Classes
    NameAnalyser
  97. def envin(in: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

    Definition Classes
    NameAnalyserNameAnalyser
  98. def envinl(in: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

    Blocks that are immediately inside procedure decls do not introduce new scopes since the procedure itself does.

    Blocks that are immediately inside procedure decls do not introduce new scopes since the procedure itself does. This computation overrides the one earlier that pushes a scope for all blocks. Don't include the procedure name in the scope of its own body.

    Definition Classes
    NameAnalyser
  99. def envout(out: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

    Definition Classes
    NameAnalyserNameAnalyser
  100. def envoutl(out: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

    Similarly for envin we don't need to leave a scope for a procedure block, since we didn't enter one.

    Similarly for envin we don't need to leave a scope for a procedure block, since we didn't enter one. The IdnDef that is for a ProcDecl needs to be in the outer scope, but not in the scope of its own body. All arguments and local declarations go in the nested scope.

    Definition Classes
    NameAnalyser
  101. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  102. def equal: Doc

    Definition Classes
    PrettyPrinterBase
  103. def equals(arg0: Any): Boolean

    Definition Classes
    AnyRef → Any
  104. def err(msg: String): Parser[Nothing]

    Definition Classes
    ParserUtilities → Parsers
  105. final def execute(testName: String, configMap: Map[String, Any], color: Boolean, durations: Boolean, shortstacks: Boolean, fullstacks: Boolean, stats: Boolean): Unit

    Definition Classes
    Suite
  106. lazy val expconst: (Expression) ⇒ Boolean

    Is an expression expected to be constant or not? Either the expression is the root of an expected constant expression or its parent expression is expected to be constant.

    Is an expression expected to be constant or not? Either the expression is the root of an expected constant expression or its parent expression is expected to be constant.

    Definition Classes
    NameAnalyser
  107. def expect(expected: Any)(actual: Any): Unit

    Definition Classes
    Assertions
  108. def expect(expected: Any, clue: Any)(actual: Any): Unit

    Definition Classes
    Assertions
  109. def expectedTestCount(filter: Filter): Int

    Definition Classes
    Suite → AbstractSuite
  110. lazy val expression: Parser[Expression]

    Definition Classes
    Parser
  111. lazy val exptype: (Expression) ⇒ Type

    The type expected of an expression as defined by its context.

    The type expected of an expression as defined by its context.

    Definition Classes
    TypeAnalyser
  112. def exptypeDef: (Expression) ⇒ Type

    The expected type of a parameter to a call is the type of the parameter at that position.

    The expected type of a parameter to a call is the type of the parameter at that position.

    Definition Classes
    TypeAnalyserTypeAnalyserTypeAnalyserTypeAnalyser
  113. lazy val factor: PackratParser[Expression]

    Definition Classes
    Parser
  114. def fail(cause: Throwable): Nothing

    Definition Classes
    Assertions
  115. def fail(message: String, cause: Throwable): Nothing

    Definition Classes
    Assertions
  116. def fail(message: String): Nothing

    Definition Classes
    Assertions
  117. def fail(): Nothing

    Definition Classes
    Assertions
  118. def failure(msg: String): Parser[Nothing]

    Definition Classes
    ParserUtilities → Parsers
  119. lazy val falseConstant: IntegerValue

    Built-in false constant.

    Built-in false constant.

    Definition Classes
    SymbolTable
  120. def filetests(name: String, path: String, srcext: String, resext: String, optinext: Option[String] = None, indefault: String = "", argslist: List[Array[String]] = List (Array ())): Unit

    Make tests that process the files in path.

    Make tests that process the files in path. name is an identifying name for this set of tests. All files whose names end in srcext are processed. Processing is done by the function compile which must return either Some (s) where s is the output or None if processing failed. If srcext is .x and resext is .y, then the expected result for foo.x is found in file foo.y. If optinext is Some (z), then foo.z is used for standard input, if it exists, otherwise the string indefault is used. A test fails if either the processing fails or it succeeds with the wrong result. argslist is used to specify the sets of command-line arguments that you want to use. Each test is run with each set of arguments. The default is an empty argument list.

    Definition Classes
    TestCompiler
  121. def fillcat(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  122. def fillsep(ds: Seq[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  123. def fillsep(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  124. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  125. lazy val forStatement: Parser[ForStatement]

    Definition Classes
    Parser
  126. def forToDoc(s: ForStatement): Doc

    Definition Classes
    PrettyPrinter
  127. lazy val forVar: Parser[IdnExp]

    Definition Classes
    Parser
  128. def forwslash: Doc

    Definition Classes
    PrettyPrinterBase
  129. lazy val fpsection: Parser[FPSection]

    Definition Classes
    Parser
  130. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  131. def group(d: Doc): Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  132. def guard[T](p: ⇒ Parser[T]): Parser[T]

    Definition Classes
    Parsers
  133. def handleWhiteSpace(in: Input): Int

    Definition Classes
    WhitespacePositionedParserUtilities → ParserUtilities
  134. def handleWhiteSpace(source: CharSequence, offset: Int): Int

    Attributes
    protected
    Definition Classes
    RegexParsers
  135. def hashCode(): Int

    Definition Classes
    AnyRef → Any
  136. def hcat(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  137. var helpFlag: Boolean

    Definition Classes
    Driver
  138. val helpFlagDefault: Boolean

    Definition Classes
    Driver
  139. def hsep(ds: Seq[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  140. def hsep(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  141. lazy val ident: Parser[String]

    Definition Classes
    Parser
  142. def idlistToDoc(ids: List[IdnDef]): Doc

    Definition Classes
    PrettyPrinter
  143. lazy val idndef: Parser[IdnDef]

    Definition Classes
    Parser
  144. lazy val idndeflist: Parser[List[IdnDef]]

    Definition Classes
    Parser
  145. lazy val idntype: (IdnUse) ⇒ Type

    The type of the entity denoted by an identifier use.

    The type of the entity denoted by an identifier use.

    Definition Classes
    TypeAnalyser
  146. def idntypeDef: (IdnUse) ⇒ Type

    The type of a parameter is the type of its underlying variable.

    The type of a parameter is the type of its underlying variable.

    Definition Classes
    TypeAnalyserTypeAnalyser
  147. lazy val idnuse: Parser[IdnUse]

    Definition Classes
    Parser
  148. lazy val ifStatement: Parser[IfStatement]

    Definition Classes
    Parser
  149. def ifToDoc(s: IfStatement): Doc

    Definition Classes
    PrettyPrinter
  150. def ignore(testName: String, testTags: Tag*)(testFun: ⇒ Unit): Unit

    Attributes
    protected
    Definition Classes
    FunSuite
  151. implicit def info: Informer

    Attributes
    protected
    Definition Classes
    FunSuite
  152. def initialiseSemanticAnalysis: Unit

    Perform initialisation of semantic analysis that is necessary before processing an AST.

    Perform initialisation of semantic analysis that is necessary before processing an AST.

    Definition Classes
    Driver
  153. var input: String

    Definition Classes
    Driver
  154. lazy val integerType: BuiltinType

    Built-in integer type.

    Built-in integer type.

    Definition Classes
    SymbolTable
  155. def intercept[T <: AnyRef](f: ⇒ Any)(implicit manifest: Manifest[T]): T

    Definition Classes
    Assertions
  156. lazy val intexp: Parser[IntExp]

    Definition Classes
    Parser
  157. def isBoolean(e: Type): Boolean

    Return true if the given type is Boolean or an unknown type.

    Return true if the given type is Boolean or an unknown type.

    Definition Classes
    SymbolTable
  158. def isCompatible(tipe: Type, exptype: Type): Boolean

    Compatibility of types.

    Compatibility of types. Return true if the type is compatible with the expected type. Unknown types are compatible with any other type. Otherwise, use look up the base types of what we have and compare them.

    Definition Classes
    TypeAnalyser
  159. def isConstant(e: Entity): Boolean

    Return true if the entity is erroneous or is a constant.

    Return true if the entity is erroneous or is a constant.

    Definition Classes
    SymbolTable
  160. def isDefinedInEnv(env: Environment, i: String): Boolean

    Definition Classes
    Environments
  161. def isDefinedInInner(env: Environment, i: String): Boolean

    Definition Classes
    Environments
  162. def isDefinedInOuter(env: Environment, i: String): Boolean

    Definition Classes
    Environments
  163. def isDefinedInScope(scope: Scope, i: String): Boolean

    Definition Classes
    Environments
  164. def isDefinedInScope(env: Environment, i: String): Boolean

    Definition Classes
    Environments
  165. def isError(e: Entity): Boolean

    Return true if the entity is an error, false otherwise.

    Return true if the entity is an error, false otherwise.

    Definition Classes
    SymbolTable
  166. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  167. def isInteger(e: Type): Boolean

    Return true if the given type is integer or an unknown type.

    Return true if the given type is integer or an unknown type.

    Definition Classes
    SymbolTable
  168. def isLvalue(l: Expression): Boolean

    Return true if the expression can legally appear on the left-hand side of an assignment statement.

    Return true if the expression can legally appear on the left-hand side of an assignment statement. At this level only allow identifiers of variables or things we don't know anything about. The true default is used so that this computation can be used in redefinitions.

    Definition Classes
    NameAnalyser
  169. def isModule(e: Entity): Boolean

    Return true if the entity is erroneous or is a module.

    Return true if the entity is erroneous or is a module.

    Definition Classes
    SymbolTable
  170. def isRvalue(r: IdnExp): Boolean

    Return true if the identifier is an r-value and hence its value can be used (ie.

    Return true if the identifier is an r-value and hence its value can be used (ie. it's erroneous or is a constant, value or variable).

    Definition Classes
    NameAnalyser
  171. def isType(e: Entity): Boolean

    Return true if the entity is erroneous or is a type.

    Return true if the entity is erroneous or is a type.

    Definition Classes
    SymbolTable
  172. def isVariable(e: Entity): Boolean

    Parameters are variables too.

    Parameters are variables too.

    Definition Classes
    SymbolTableSymbolTable
  173. lazy val isconst: (Expression) ⇒ Boolean

    Is an expression constant or not? Unknown entities are constant.

    Is an expression constant or not? Unknown entities are constant. Strictly speaking we only need to support integer expressions here, but we treat Boolean ones as constant in the same way so that we avoid spurious errors. Type analysis will reject Boolean constant expressions anyway.

    Definition Classes
    NameAnalyser
  174. lazy val kase: Parser[Case]

    Definition Classes
    Parser
  175. lazy val keyword: Parser[String]

    Definition Classes
    Parser
  176. def keywordStrings: List[String]

    Definition Classes
    ParserParserParserParserParser
  177. def keywords(ext: Regex, kws: List[String]): Parser[String]

    Definition Classes
    ParserUtilities
  178. def langle: Doc

    Definition Classes
    PrettyPrinterBase
  179. def langlevel: Int

    Definition Classes
    A3Phases
  180. def lbrace: Doc

    Definition Classes
    PrettyPrinterBase
  181. def lbracket: Doc

    Definition Classes
    PrettyPrinterBase
  182. def leave(env: Environment): Environment

    Definition Classes
    Environments
  183. lazy val level: (SourceASTNode) ⇒ Int

    Level of a node considering the module level to be zero and incrementing each time we enter a nested procedure declaration.

    Level of a node considering the module level to be zero and incrementing each time we enter a nested procedure declaration.

    Definition Classes
    NameAnalyser
  184. lazy val lhs: PackratParser[Expression]

    Definition Classes
    Parser
  185. def lhsDef: PackratParser[Expression]

    Definition Classes
    Parser
  186. def line: Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  187. def linebreak: Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  188. def list[T](l: List[T], prefix: String, elemToDoc: (T) ⇒ Doc, sep: Doc, sepfn: (Seq[Doc], Doc) ⇒ Doc): Doc

    Definition Classes
    PrettyPrinterBase
  189. implicit def literal(s: String): Parser[String]

    Definition Classes
    WhitespaceParser → RegexParsers
  190. def log[T](p: ⇒ Parser[T])(name: String): Parser[T]

    Definition Classes
    Parsers
  191. def lookup(env: Environment, i: String, e: Entity, scope: Boolean): Entity

    Definition Classes
    Environments
  192. def lparen: Doc

    Definition Classes
    PrettyPrinterBase
  193. def lsep(ds: Seq[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  194. def lsep2(ds: Seq[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  195. def lterm(ds: Seq[Doc], term: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  196. def main(args: Array[String]): Unit

    Definition Classes
    CompilerBase
  197. def makeast(reader: Reader, filename: String, emitter: Emitter): Either[ModuleDecl, String]

    Definition Classes
    RegexCompiler → CompilerBase
  198. val maxlanglevel: Int

    The maximum language level we support.

    The maximum language level we support.

    Definition Classes
    TestDriver
  199. def memo[T](p: Parser[T]): PackratParser[T]

    Definition Classes
    PackratParsers
  200. def mkList[T]: (~[T, List[T]]) ⇒ List[T]

    Definition Classes
    Parsers
  201. def mktests(proglang: String): Unit

    Make the tests for a given language subset.

    Make the tests for a given language subset. proglang denotes the language subset whose tests are used.

    Definition Classes
    TestDriver
  202. lazy val moduledecl: Parser[ModuleDecl]

    Definition Classes
    Parser
  203. lazy val namedtypedef: Parser[NamedType]

    Definition Classes
    Parser
  204. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  205. def nest(d: Doc, j: Indent): Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  206. def nestedSuites: List[Suite]

    Definition Classes
    Suite → AbstractSuite
  207. def noparens(inner: PrettyOperatorExpression, outer: PrettyOperatorExpression, side: Side): Boolean

    Definition Classes
    ParenPrettyPrinter
  208. def not[T](p: ⇒ Parser[T]): Parser[Unit]

    Definition Classes
    Parsers
  209. final def notify(): Unit

    Definition Classes
    AnyRef
  210. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  211. lazy val numparams: (IdnUse) ⇒ Option[Int]

    Calculate the number of parameters to a procedure.

    Calculate the number of parameters to a procedure. Return None if the identifier use does not denote a procedure.

    Definition Classes
    TypeAnalyser
  212. def opt[T](p: ⇒ Parser[T]): Parser[Option[T]]

    Definition Classes
    Parsers
  213. lazy val optActualParameters: Parser[List[Expression]]

    Definition Classes
    Parser
  214. def optSectionToDoc(section: String, optds: Option[List[Declaration]]): Doc

    Definition Classes
    PrettyPrinter
  215. lazy val optelse: Parser[Option[Block]]

    Definition Classes
    Parser
  216. lazy val optformalParameters: PackratParser[List[FPSection]]

    Definition Classes
    Parser
  217. lazy val optvar: Parser[Product with Serializable with Mode]

    Definition Classes
    Parser
  218. lazy val parameters: (Identifier) ⇒ Option[List[ParamInfo]]

    Calculate the parameter information list for a procedure.

    Calculate the parameter information list for a procedure. If it's a built-in we have the information already, otherwise we need to work it out from the declaration. Returns None if the entity is not a procedure.

    Definition Classes
    TypeAnalyser
  219. def parammode(u: IdnUse, i: Int): Mode

    Return the ith parameter mode of the procedure denoted by u (counting from one).

    Return the ith parameter mode of the procedure denoted by u (counting from one). If u is not a procedure or has less than i parameters, return a value mode, since that mode places no constraints on its actual parameter.

    Definition Classes
    TypeAnalyser
  220. def paramsToDoc(ds: List[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinter
  221. def paramtype(u: IdnUse, i: Int): Type

    Return the ith parameter type of the procedure denoted by u (counting from one).

    Return the ith parameter type of the procedure denoted by u (counting from one). If u is not a procedure or has less than i parameters, return an unknown type.

    Definition Classes
    TypeAnalyser
  222. def parens(d: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  223. def parse[T](p: Parser[T], in: Reader): ParseResult[T]

    Definition Classes
    RegexParsers
  224. def parse[T](p: Parser[T], in: CharSequence): ParseResult[T]

    Definition Classes
    RegexParsers
  225. def parse[T](p: Parser[T], in: Reader[Char]): ParseResult[T]

    Definition Classes
    RegexParsers
  226. def parseAll[T](p: Parser[T], in: CharSequence): ParseResult[T]

    Definition Classes
    RegexParsers
  227. def parseAll[T](p: Parser[T], in: Reader): ParseResult[T]

    Definition Classes
    RegexParsers
  228. def parseAll[T](p: Parser[T], in: Reader[Char]): ParseResult[T]

    Definition Classes
    RegexParsers
  229. def parseAndPosition[T](f: (Input) ⇒ ParseResult[T], in: Input): ParseResult[T]

    Definition Classes
    PositionedParserUtilities
  230. implicit def parseResultToTuple2[A, B](p: Parser[~[A, B]]): PackratParser[(A, B)]

    Definition Classes
    ParserUtilities
  231. implicit def parseResultToTuple3[A, B, C](p: Parser[~[~[A, B], C]]): PackratParser[(A, B, C)]

    Definition Classes
    ParserUtilities
  232. implicit def parseResultToTuple4[A, B, C, D](p: Parser[~[~[~[A, B], C], D]]): PackratParser[(A, B, C, D)]

    Definition Classes
    ParserUtilities
  233. implicit def parseResultToTuple5[A, B, C, D, E](p: Parser[~[~[~[~[A, B], C], D], E]]): PackratParser[(A, B, C, D, E)]

    Definition Classes
    ParserUtilities
  234. implicit def parseResultToTuple6[A, B, C, D, E, F](p: Parser[~[~[~[~[~[A, B], C], D], E], F]]): PackratParser[(A, B, C, D, E, F)]

    Definition Classes
    ParserUtilities
  235. def parseString[T](parser: Parser[T], str: String): Either[T, String]

    Definition Classes
    ParserUtilities
  236. def parseWhitespace(in: Input): ParseResult[Any]

    Attributes
    protected
    Definition Classes
    WhitespaceParser
  237. lazy val parser: PackratParser[ModuleDecl]

    Definition Classes
    Parser
  238. implicit def parser2packrat[T](p: ⇒ Parser[T]): PackratParser[T]

    Definition Classes
    PackratParsers
  239. var parsingWhitespace: Boolean

    Attributes
    protected
    Definition Classes
    WhitespaceParser
  240. def pending: PendingNothing

    Definition Classes
    Suite
  241. def pendingUntilFixed(f: ⇒ Unit): Unit

    Definition Classes
    Suite
  242. def phrase[T](p: Parser[T]): PackratParser[T]

    Definition Classes
    PackratParsers → Parsers
  243. def plist(l: List[PrettyPrintable], prefix: String, elemToDoc: (PrettyPrintable) ⇒ Doc, sep: Doc, sepfn: (Seq[Doc], Doc) ⇒ Doc): Doc

    Definition Classes
    PrettyPrinterBase
  244. def positioned[T <: Positional](p: ⇒ Parser[T]): Parser[T]

    Definition Classes
    WhitespaceParser → RegexParsers → Parsers
  245. var pprintastFlag: Boolean

    Definition Classes
    Driver
  246. val pprintastFlagDefault: Boolean

    Definition Classes
    TestDriver
  247. var pprintiastFlag: Boolean

    Definition Classes
    TransformingDriver
  248. val pprintiastFlagDefault: Boolean

    Definition Classes
    TransformingDriver
  249. def pretty(d: Doc, w: Width): Layout

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  250. def pretty(p: PrettyPrintable): Layout

    Definition Classes
    PrettyPrinterBase
  251. def pretty_any(a: Any): Layout

    Definition Classes
    PrettyPrinterBase
  252. var printastFlag: Boolean

    Definition Classes
    Driver
  253. val printastFlagDefault: Boolean

    Definition Classes
    Driver
  254. var printiastFlag: Boolean

    Definition Classes
    TransformingDriver
  255. val printiastFlagDefault: Boolean

    Definition Classes
    TransformingDriver
  256. lazy val procedureCall: Parser[Call]

    Definition Classes
    Parser
  257. lazy val procedureDeclaration: Parser[ProcDecl]

    Definition Classes
    Parser
  258. def process(ast: ModuleDecl, console: Console, emitter: Emitter): Boolean

    Process the given abstract syntax tree.

    Process the given abstract syntax tree. Send output to emitter, marking sections so that we can split things later.

    Definition Classes
    Driver → Compiler → CompilerBase
  259. def processargs(args: List[String]): Boolean

    Definition Classes
    TransformingDriverDriver
  260. def processast(ast: ModuleDecl, console: Console, emitter: Emitter): ModuleDecl

    Process the AST by transforming it.

    Process the AST by transforming it. Then apply higher-level transformations.

    Definition Classes
    TransformingDriverDriver
  261. def rangle: Doc

    Definition Classes
    PrettyPrinterBase
  262. def rbrace: Doc

    Definition Classes
    PrettyPrinterBase
  263. def rbracket: Doc

    Definition Classes
    PrettyPrinterBase
  264. lazy val readProc: BuiltinProc

    The built-in Read procedure.

    The built-in Read procedure.

    Definition Classes
    SymbolTable
  265. implicit def regex(r: Regex): Parser[String]

    Definition Classes
    WhitespaceParser → RegexParsers
  266. def regexnows(r: Regex): Parser[String]

    Definition Classes
    ParserUtilities
  267. def rep[T](p: ⇒ Parser[T]): Parser[List[T]]

    Definition Classes
    Parsers
  268. def rep1[T](first: ⇒ Parser[T], p0: ⇒ Parser[T]): Parser[List[T]]

    Definition Classes
    Parsers
    Annotations
    @migration
    Migration

    (Changed in version 2.9.0) The p0 call-by-name arguments is evaluated at most once per constructed Parser object, instead of on every need that arises during parsing.

  269. def rep1[T](p: ⇒ Parser[T]): Parser[List[T]]

    Definition Classes
    Parsers
  270. def rep1sep[T](p: ⇒ Parser[T], q: ⇒ Parser[Any]): Parser[List[T]]

    Definition Classes
    Parsers
  271. def repN[T](num: Int, p: ⇒ Parser[T]): Parser[List[T]]

    Definition Classes
    Parsers
  272. def repsep[T](p: ⇒ Parser[T], q: ⇒ Parser[Any]): Parser[List[T]]

    Definition Classes
    Parsers
  273. def resetEnvironments: Unit

    Definition Classes
    Environments
  274. def resetflags(): Unit

    Definition Classes
    TransformingDriverDriver
  275. def result[T](v: ⇒ T): Parser[T]

    Definition Classes
    ParserUtilities
  276. lazy val rootconstexp: (Expression) ⇒ Boolean

    Is this expression the root of what is expected to be a constant expression? At this level only expressions on the RHS of a constant declaration have this property.

    Is this expression the root of what is expected to be a constant expression? At this level only expressions on the RHS of a constant declaration have this property.

    Definition Classes
    NameAnalyser
  277. def rootconstexpDef: (Expression) ⇒ Boolean

    Definition Classes
    NameAnalyserNameAnalyser
  278. def rootenv(bindings: (String, Entity)*): Environment

    Definition Classes
    Environments
  279. def rparen: Doc

    Definition Classes
    PrettyPrinterBase
  280. def run(testName: Option[String], reporter: Reporter, stopper: Stopper, filter: Filter, configMap: Map[String, Any], distributor: Option[Distributor], tracker: Tracker): Unit

    Definition Classes
    FunSuite → Suite → AbstractSuite
  281. def runNestedSuites(reporter: Reporter, stopper: Stopper, filter: Filter, configMap: Map[String, Any], distributor: Option[Distributor], tracker: Tracker): Unit

    Attributes
    protected
    Definition Classes
    Suite → AbstractSuite
  282. def runTest(testName: String, reporter: Reporter, stopper: Stopper, configMap: Map[String, Any], tracker: Tracker): Unit

    Attributes
    protected
    Definition Classes
    FunSuite → Suite → AbstractSuite
  283. def runTests(testName: Option[String], reporter: Reporter, stopper: Stopper, filter: Filter, configMap: Map[String, Any], distributor: Option[Distributor], tracker: Tracker): Unit

    Attributes
    protected
    Definition Classes
    FunSuite → Suite → AbstractSuite
  284. def sanitise(s: String): String

    Sanitise the output from a test.

    Sanitise the output from a test. Remove any output that doesn't make sense to this program. I.e., if we are running a program that performs tasks 1-m, then any lines marked with [p], where p > m should be removed before comparison. Also, there can be three numbers, a'la [p,q,r] where p is as before and q (r) are lower (upper) inclusive bounds on the language level to which this output should apply. If p is omitted, the output applies to all task levels. If p is given, but q and r are omitted, the output also applies to all language levels.

    Definition Classes
    TestDriverTestCompiler
  285. def section(emitter: Emitter, name: String): Unit

    Output a section heading so that the output can be split later.

    Output a section heading so that the output can be split later.

    Definition Classes
    Driver
  286. def semi: Doc

    Definition Classes
    PrettyPrinterBase
  287. def semisep(l: List[SourceASTNode], sep: Doc = semi): Doc

    Pretty-print a nested list of nodes separated by sep (default: semi colon) and line breaks.

    Pretty-print a nested list of nodes separated by sep (default: semi colon) and line breaks.

    Definition Classes
    PrettyPrinter
  288. def sep(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  289. lazy val simpexp: PackratParser[Expression]

    Definition Classes
    Parser
  290. def skipWhitespace: Boolean

    Definition Classes
    WhitespaceParser → RegexParsers
  291. def softbreak: Doc

    Definition Classes
    PrettyPrinterBase
  292. def softline: Doc

    Definition Classes
    PrettyPrinterBase
  293. def space: Doc

    Definition Classes
    PrettyPrinterBase
  294. def spaces(n: Int): Doc

    Definition Classes
    PrettyPrinterBase
  295. def squote: Doc

    Definition Classes
    PrettyPrinterBase
  296. def squotes(d: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  297. def ssep(ds: Seq[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  298. lazy val statement: PackratParser[Statement]

    Definition Classes
    Parser
  299. def statementDef: PackratParser[Statement]

    Definition Classes
    ParserParserParserParserParser
  300. lazy val statementSequence: Parser[Block]

    Definition Classes
    Parser
  301. lazy val statements: Parser[Block]

    Definition Classes
    Parser
  302. lazy val step: Parser[Option[Expression]]

    Definition Classes
    Parser
  303. def sterm(ds: Seq[Doc], term: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  304. def string(s: String): Doc

    Definition Classes
    PrettyPrinterBase
  305. def stringToInt(s: String): Either[Int, String]

    Definition Classes
    ParserUtilities
  306. final val styleName: String

    Definition Classes
    FunSuite → Suite → AbstractSuite
  307. def success[T](v: T): Parser[T]

    Definition Classes
    Parsers
  308. def suiteName: String

    Definition Classes
    Suite
  309. def surround(d: Doc, b: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  310. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  311. def tags: Map[String, Set[String]]

    Definition Classes
    FunSuite → Suite → AbstractSuite
  312. def tasklevel: Int

    Definition Classes
    A3Phases
  313. lazy val term: PackratParser[Expression]

    Definition Classes
    Parser
  314. def test(testName: String, testTags: Tag*)(testFun: ⇒ Unit): Unit

    Attributes
    protected
    Definition Classes
    FunSuite
  315. def testNames: Set[String]

    Definition Classes
    FunSuite → Suite → AbstractSuite
  316. def testsFor(unit: Unit): Unit

    Attributes
    protected
    Definition Classes
    FunSuite
  317. implicit def text(t: String): Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  318. lazy val tipe: (Expression) ⇒ Type

    The type of an expression.

    The type of an expression.

    Definition Classes
    TypeAnalyser
  319. def tipeDef: (Expression) ⇒ Type

    Definition Classes
    TypeAnalyser
  320. def toDoc(n: SourceASTNode): Doc

  321. def toParenDoc(e: PrettyExpression): Doc

    Definition Classes
    PrettyPrinter → ParenPrettyPrinter
  322. def toString(): String

    Definition Classes
    AnyRef → Any
  323. def transform(m: ModuleDecl): ModuleDecl

    Desugar FOR and CASE statements into simpler constructs.

    Desugar FOR and CASE statements into simpler constructs. Then call the next level of transformation.

    Definition Classes
    DesugarerDesugarerTransformer
  324. lazy val trueConstant: IntegerValue

    Built-in true constant.

    Built-in true constant.

    Definition Classes
    SymbolTable
  325. lazy val typebasetype: (Type) ⇒ Type

    The actual type that a user type denotes.

    The actual type that a user type denotes.

    Definition Classes
    TypeAnalyser
  326. lazy val typedecl: Parser[TypeDecl]

    Definition Classes
    Parser
  327. lazy val typedeclsection: Parser[List[TypeDecl]]

    Definition Classes
    Parser
  328. lazy val typedef: PackratParser[TypeDef]

    Definition Classes
    Parser
  329. def typedefDef: PackratParser[TypeDef]

    Definition Classes
    Parser
  330. def uniquifyNames(m: ModuleDecl): ModuleDecl

    Rename user-defined names to avoid clashes with outer declarations of the same name.

    Rename user-defined names to avoid clashes with outer declarations of the same name. This transformation is not idempotent.

    Definition Classes
    Desugarer
  331. lazy val unknownType: BuiltinType

    A type that is unknown, eg because the typed thing is erroneously defined.

    A type that is unknown, eg because the typed thing is erroneously defined.

    Definition Classes
    SymbolTable
  332. def usageMessage: String

    Definition Classes
    TransformingDriverDriver
  333. def value(v: Any): Doc

    Definition Classes
    PrettyPrinterBase
  334. lazy val value: (Expression) ⇒ Int

    What is the value of an integer expression? Only needs to be valid if the expression is an integer constant (see isconst above) and is defined (eg, no divide by zero.

    What is the value of an integer expression? Only needs to be valid if the expression is an integer constant (see isconst above) and is defined (eg, no divide by zero.) Returns zero in all other cases. FIXME: Ignores issues of overflow.

    Definition Classes
    NameAnalyser
  335. lazy val vardecl: Parser[VarDecl]

    Definition Classes
    Parser
  336. lazy val vardeclsection: Parser[List[VarDecl]]

    Definition Classes
    Parser
  337. def vcat(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  338. def vsep(ds: Seq[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinterBase
  339. def vsep(ds: Seq[Doc]): Doc

    Definition Classes
    PrettyPrinterBase
  340. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  341. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  342. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  343. lazy val whileStatement: Parser[WhileStatement]

    Definition Classes
    Parser
  344. val whiteSpace: Regex

    Attributes
    protected
    Definition Classes
    RegexParsers
  345. lazy val whitespaceParser: PackratParser[Any]

    Definition Classes
    Parser → WhitespaceParser
  346. def withClue(clue: Any)(fun: ⇒ Unit): Unit

    Definition Classes
    Assertions
  347. def withFixture(test: NoArgTest): Unit

    Attributes
    protected
    Definition Classes
    Suite → AbstractSuite
  348. def wrap[T, U](p: ⇒ Parser[T], f: (T) ⇒ Either[U, String]): Parser[U]

    Definition Classes
    ParserUtilities
  349. lazy val writeProc: BuiltinProc

    The built-in Write procedure.

    The built-in Write procedure.

    Definition Classes
    SymbolTable
  350. lazy val writelnProc: BuiltinProc

    The built-in WriteLn procedure.

    The built-in WriteLn procedure.

    Definition Classes
    SymbolTable

Deprecated Value Members

  1. def lastNoSuccess: NoSuccess

    Definition Classes
    Parsers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) lastNoSuccess was not thread-safe and will be removed in 2.11.0

  2. def lastNoSuccess_=(x: NoSuccess): Unit

    Definition Classes
    Parsers
    Annotations
    @deprecated
    Deprecated

    (Since version 2.10.0) lastNoSuccess was not thread-safe and will be removed in 2.11.0

  3. def product(p: Any): Doc

    Definition Classes
    PrettyPrinterBase
    Annotations
    @deprecated
    Deprecated

    (Since version 1.2.1) Use PrettyPrinter.any instead.

Inherited from TestDriver

Inherited from TestCompiler[ModuleDecl]

Inherited from FunSuite

Inherited from Suite

Inherited from Serializable

Inherited from AbstractSuite

Inherited from Assertions

Inherited from A3Phases

Inherited from Desugarer

Inherited from Desugarer

Inherited from Lifter

Inherited from Transformer

Inherited from TypeAnalyser

Inherited from TypeAnalyser

Inherited from TypeAnalyser

Inherited from TypeAnalyser

Inherited from NameAnalyser

Inherited from SymbolTable

Inherited from NameAnalyser

Inherited from NameAnalyser

Inherited from SymbolTable

Inherited from SymbolTable

Inherited from Environments

Inherited from Analyser

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from SourcePrettyPrinter

Inherited from ParenPrettyPrinter

Inherited from L3.Parser

Inherited from L2.Parser

Inherited from L1.Parser

Inherited from L0.Parser

Inherited from base.Parser

Inherited from WhitespacePositionedParserUtilities

Inherited from PositionedParserUtilities

Inherited from WhitespaceParser

Inherited from ParserUtilities

Inherited from PackratParsers

Inherited from RegexParsers

Inherited from Parsers

Inherited from TransformingDriver

Inherited from Driver

Inherited from PrettyPrinter

Inherited from PrettyPrinterBase

Inherited from Compiler[ModuleDecl]

Inherited from RegexCompiler[ModuleDecl]

Inherited from CompilerBase[ModuleDecl]

Inherited from AnyRef

Inherited from Any

No Group