org.kiama.example.oberon0.drivers

A4Tests

class A4Tests extends A4Phases with TranslatingTestDriver

Annotations
@RunWith()
Linear Supertypes
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. A4Tests
  2. TranslatingTestDriver
  3. TestDriver
  4. TestCompiler
  5. FunSuite
  6. Suite
  7. Serializable
  8. AbstractSuite
  9. Assertions
  10. A4Phases
  11. PrettyPrinter
  12. PrettyPrinter
  13. PrettyPrinter
  14. PrettyPrinter
  15. PrettyPrinter
  16. CPrettyPrinter
  17. CCodeGenerator
  18. CCodeGenerator
  19. CCodeGenerator
  20. CCodeGenerator
  21. CCodeGenerator
  22. Translator
  23. Desugarer
  24. Desugarer
  25. Lifter
  26. Transformer
  27. TypeAnalyser
  28. SymbolTable
  29. TypeAnalyser
  30. TypeAnalyser
  31. TypeAnalyser
  32. TypeAnalyser
  33. NameAnalyser
  34. NameAnalyser
  35. SymbolTable
  36. NameAnalyser
  37. NameAnalyser
  38. SymbolTable
  39. SymbolTable
  40. Environments
  41. Analyser
  42. PrettyPrinter
  43. PrettyPrinter
  44. PrettyPrinter
  45. PrettyPrinter
  46. PrettyPrinter
  47. PrettyPrinter
  48. SourcePrettyPrinter
  49. ParenPrettyPrinter
  50. Parser
  51. Parser
  52. Parser
  53. Parser
  54. Parser
  55. Parser
  56. WhitespacePositionedParserUtilities
  57. PositionedParserUtilities
  58. WhitespaceParser
  59. ParserUtilities
  60. PackratParsers
  61. TranslatingDriver
  62. TransformingDriver
  63. Driver
  64. PrettyPrinter
  65. PrettyPrinterBase
  66. Compiler
  67. RegexCompiler
  68. RegexParsers
  69. Parsers
  70. CompilerBase
  71. AnyRef
  72. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Instance Constructors

  1. new A4Tests()

Type Members

  1. case class ArrayType(size: Int, elemtype: SymbolTable.Type) extends Type with Product with Serializable

    An array type with the given size and element type.

  2. trait Builtin extends Named

    Marker trait for all built-in entities.

  3. 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.

  4. 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.

  5. 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.

  6. 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
  7. trait DocOps extends AnyRef

    Definition Classes
    PrettyPrinterBase
  8. type Elem = Char

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

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

    Definition Classes
    Environments
  11. final class Equalizer extends AnyRef

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

    Definition Classes
    Parsers
  13. trait ErrorEntity extends Entity

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

    Definition Classes
    Parsers
  15. case class Field(ident: String, tipe: SymbolTable.Type) extends Entity with Product with Serializable

    A record field.

  16. type Indent = Int

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

    Definition Classes
    Parsers
  18. 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.

  19. type Layout = String

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

    A user-defined module represented by a module declaration.

  21. trait Named extends AnyRef

    Definition Classes
    Environments
  22. trait NamedEntity extends Entity with Named

    Definition Classes
    Environments
  23. trait NoArgTest extends () ⇒ Unit with TestData

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

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

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

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

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

    Information about a particular parameter.

  29. 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.

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

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

    Definition Classes
    Parsers
  32. trait PrettyPrintable extends AnyRef

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

    A procedure entity represented by a procedure declaration.

  34. case class RecordType(fields: List[Field]) extends Type with Product with Serializable

    A record with the given fields.

  35. type Scope = Map[String, Entity]

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

    Definition Classes
    Parsers
  37. abstract class Type extends Entity

    An entity representing by a user-provided type declaration.

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

    A user-defined type.

  39. 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.

  40. type Width = Int

    Definition Classes
    PrettyPrinterBase
  41. 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 arraydimensToDoc(t1: CArrayType): Doc

    Definition Classes
    PrettyPrinter
  21. def artefact: String

    The name of this artefact.

    The name of this artefact.

    Definition Classes
    A4PhasesDriver
  22. final def asInstanceOf[T0]: T0

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

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

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

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

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

    Definition Classes
    Parser
  28. def assume(o: Option[String]): Unit

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

    Definition Classes
    Assertions
  30. def assume(condition: Boolean, clue: Any): Unit

    Definition Classes
    Assertions
  31. def assume(condition: Boolean): Unit

    Definition Classes
    Assertions
  32. def backslash: Doc

    Definition Classes
    PrettyPrinterBase
  33. 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
  34. def basetypeToDoc(t: CType): Doc

  35. lazy val block: Parser[Block]

    Definition Classes
    Parser
  36. 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
  37. lazy val booleanType: BuiltinType

    Built-in Boolean type.

    Built-in Boolean type.

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

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

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

    Definition Classes
    PrettyPrinterBase
  41. def cancel(cause: Throwable): Nothing

    Definition Classes
    Assertions
  42. def cancel(message: String, cause: Throwable): Nothing

    Definition Classes
    Assertions
  43. def cancel(message: String): Nothing

    Definition Classes
    Assertions
  44. def cancel(): Nothing

    Definition Classes
    Assertions
  45. lazy val caseStatement: Parser[CaseStatement]

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

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

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

    Definition Classes
    PrettyPrinter
  49. 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
  50. def cat(ds: Seq[Doc]): Doc

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

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

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

    Definition Classes
    Parsers
  54. var challengeFlag: Boolean

    Definition Classes
    Driver
  55. val challengeFlagDefault: Boolean

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

    Definition Classes
    PrettyPrinterBase
  57. 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
    TypeAnalyserTypeAnalyserNameAnalyserTypeAnalyserTypeAnalyserNameAnalyserAnalyser
  58. 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
  59. 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
  60. def clone(): AnyRef

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

    Definition Classes
    PrettyPrinterBase
  62. def comma: Doc

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

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

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

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

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

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

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

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

    Definition Classes
    ParserUtilities
  71. 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
  72. 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
  73. lazy val constdecl: Parser[ConstDecl]

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

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

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

    Consume the AST by translating it to C.

    Consume the AST by translating it to C.

    Definition Classes
    TranslatingDriverDriver
  77. implicit def convertToEqualizer(left: Any): Equalizer

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

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

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

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

    Definition Classes
    PrettyPrinterPrettyPrinter
  82. 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
  83. val defaultIndent: Int

    Definition Classes
    PrettyPrinterBase
  84. val defaultWidth: Int

    Definition Classes
    PrettyPrinterBase
  85. def defenv: Environment

    The default environment.

    The default environment.

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

    The default environment with pre-defined procedures added.

    The default environment with pre-defined procedures added.

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

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

    The type given by a type definition.

    The type given by a type definition.

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

    Definition Classes
    TypeAnalyserTypeAnalyser
  90. 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
  91. 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
  92. 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
  93. def dot: Doc

    Definition Classes
    PrettyPrinterBase
  94. def dquote: Doc

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

    Definition Classes
    PrettyPrinterBase
  96. 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
  97. def elem(e: Elem): Parser[Elem]

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

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

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

    Definition Classes
    Parser
  101. def empty: Doc

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

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

    Definition Classes
    Environments
  104. 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
  105. 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
    TypeAnalyserNameAnalyserNameAnalyser
  106. 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
  107. def envin(in: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

    Definition Classes
    NameAnalyserNameAnalyser
  108. 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
  109. def envout(out: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

    Definition Classes
    NameAnalyserNameAnalyser
  110. 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
  111. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  112. def equal: Doc

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

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

    Definition Classes
    ParserUtilities → Parsers
  115. final def execute: Unit

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

    Definition Classes
    Suite
  117. 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
  118. def expectResult(expected: Any)(actual: Any): Unit

    Definition Classes
    Assertions
  119. def expectResult(expected: Any, clue: Any)(actual: Any): Unit

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

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

    Definition Classes
    Parser
  122. 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
  123. def exptypeDef: (Expression) ⇒ Type

    Use of arrays and records is dealt with separately, not via the expected type.

    Use of arrays and records is dealt with separately, not via the expected type.

    Definition Classes
    TypeAnalyserTypeAnalyserTypeAnalyserTypeAnalyserTypeAnalyser
  124. lazy val factor: PackratParser[Expression]

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

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

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

    Definition Classes
    Assertions
  128. def fail(): Nothing

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

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

    Built-in false constant.

    Built-in false constant.

    Definition Classes
    SymbolTable
  131. def fieldListsToFields(fls: List[FieldList]): List[Field]

    Definition Classes
    TypeAnalyser
  132. lazy val fieldlist: Parser[Option[FieldList]]

    Definition Classes
    Parser
  133. lazy val fieldlists: Parser[List[FieldList]]

    Definition Classes
    Parser
  134. 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
  135. def fillcat(ds: Seq[Doc]): Doc

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

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

    Definition Classes
    PrettyPrinterBase
  138. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  139. lazy val fldidn: Parser[FieldIdn]

    Definition Classes
    Parser
  140. lazy val forStatement: Parser[ForStatement]

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

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

    Definition Classes
    Parser
  143. def forwslash: Doc

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

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

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

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

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

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

    Attributes
    protected
    Definition Classes
    RegexParsers
  150. def hasField(t: Type, f: String): Boolean

    Is a given type a record type containing a field called f?

    Is a given type a record type containing a field called f?

    Definition Classes
    SymbolTable
  151. def hashCode(): Int

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

    Definition Classes
    PrettyPrinterBase
  153. var helpFlag: Boolean

    Definition Classes
    Driver
  154. val helpFlagDefault: Boolean

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

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

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

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

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

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

    Definition Classes
    Parser
  161. lazy val idnlist: Parser[List[String]]

    Definition Classes
    Parser
  162. 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
  163. 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
  164. lazy val idnuse: Parser[IdnUse]

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

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

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

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

    Attributes
    protected
    Definition Classes
    FunSuite
  169. 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
  170. var input: String

    Definition Classes
    Driver
  171. lazy val integerType: BuiltinType

    Built-in integer type.

    Built-in integer type.

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

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

    Definition Classes
    Parser
  174. def isArray(e: Entity): Boolean

    Return true if the entity is erroneous or is an array.

    Return true if the entity is erroneous or is an array.

    Definition Classes
    SymbolTable
  175. 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
  176. def isCompatible(tipe: Type, exptype: Type): Boolean

    Array and record types are only compatible if they have the same name.

    Array and record types are only compatible if they have the same name.

    Definition Classes
    TypeAnalyserTypeAnalyser
  177. 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
  178. def isDefinedInEnv(env: Environment, i: String): Boolean

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

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

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

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

    Definition Classes
    Environments
  183. 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
  184. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  185. 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
  186. 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
    NameAnalyserNameAnalyser
  187. 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
  188. def isNotArray(e: Entity): Boolean

    Return true if the entity is erroneous or is not an array.

    Return true if the entity is erroneous or is not an array.

    Definition Classes
    SymbolTable
  189. def isNotRecord(e: Entity): Boolean

    Return true if the entity is erroneous or is not a record.

    Return true if the entity is erroneous or is not a record.

    Definition Classes
    SymbolTable
  190. def isRecord(e: Entity): Boolean

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

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

    Definition Classes
    SymbolTable
  191. 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
  192. 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
  193. def isVariable(e: Entity): Boolean

    Parameters are variables too.

    Parameters are variables too.

    Definition Classes
    SymbolTableSymbolTable
  194. 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
  195. lazy val kase: Parser[Case]

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

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

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

    Definition Classes
    ParserUtilities
  199. def langle: Doc

    Definition Classes
    PrettyPrinterBase
  200. def langlevel: Int

    Definition Classes
    A4Phases
  201. def lbrace: Doc

    Definition Classes
    PrettyPrinterBase
  202. def lbracket: Doc

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

    Definition Classes
    Environments
  204. 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
  205. lazy val lhs: PackratParser[Expression]

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

    Definition Classes
    ParserParser
  207. def line: Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  208. def linebreak: Doc

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

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

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

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

    Definition Classes
    Environments
  213. def lparen: Doc

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

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

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

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

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

    Definition Classes
    RegexCompiler → CompilerBase
  219. def mangle(s: String): String

    Mangle an Oberon name so it is safe to be used at the C level.

    Mangle an Oberon name so it is safe to be used at the C level. We assume that there are no C names with "ob_" prefix.

    Definition Classes
    CCodeGenerator
  220. implicit def markup: Documenter

    Attributes
    protected
    Definition Classes
    FunSuite
  221. val maxlanglevel: Int

    The maximum language level we support.

    The maximum language level we support.

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

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

    Definition Classes
    Parsers
  224. 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
  225. lazy val moduledecl: Parser[ModuleDecl]

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

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

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

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  229. def nestedSuites: IndexedSeq[Suite]

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

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

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

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

    Definition Classes
    AnyRef
  234. 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
  235. def opt[T](p: ⇒ Parser[T]): Parser[Option[T]]

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

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

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

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

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

    Definition Classes
    Parser
  241. 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
  242. 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
  243. def paramsToDoc(ds: List[Doc], sep: Doc): Doc

    Definition Classes
    PrettyPrinter
  244. 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
  245. def parens(d: Doc): Doc

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

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

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

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

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

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

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

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

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

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

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

    Definition Classes
    ParserUtilities
  257. 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
  258. def parseString[T](parser: Parser[T], str: String): Either[T, String]

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

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

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

    Definition Classes
    PackratParsers
  262. var parsingWhitespace: Boolean

    Attributes
    protected
    Definition Classes
    WhitespaceParser
  263. def pending: PendingNothing

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

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

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

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

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

    Definition Classes
    Driver
  269. val pprintastFlagDefault: Boolean

    Definition Classes
    TestDriver
  270. var pprintcastFlag: Boolean

    Definition Classes
    TranslatingDriver
  271. val pprintcastFlagDefault: Boolean

    Definition Classes
    TranslatingTestDriver
  272. var pprintiastFlag: Boolean

    Definition Classes
    TransformingDriver
  273. val pprintiastFlagDefault: Boolean

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

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

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

    Definition Classes
    PrettyPrinterBase
  277. var printastFlag: Boolean

    Definition Classes
    Driver
  278. val printastFlagDefault: Boolean

    Definition Classes
    Driver
  279. var printcastFlag: Boolean

    Definition Classes
    TranslatingDriver
  280. val printcastFlagDefault: Boolean

    Definition Classes
    TranslatingDriver
  281. var printiastFlag: Boolean

    Definition Classes
    TransformingDriver
  282. val printiastFlagDefault: Boolean

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

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

    Definition Classes
    Parser
  285. 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
  286. def processargs(args: List[String]): Boolean

    Definition Classes
    TranslatingDriverTransformingDriverDriver
  287. 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
  288. def rangle: Doc

    Definition Classes
    PrettyPrinterBase
  289. def rbrace: Doc

    Definition Classes
    PrettyPrinterBase
  290. def rbracket: Doc

    Definition Classes
    PrettyPrinterBase
  291. lazy val readProc: BuiltinProc

    The built-in Read procedure.

    The built-in Read procedure.

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

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

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

    Definition Classes
    Parsers
  295. 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.

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

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

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

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

    Definition Classes
    Parsers
  300. def rerunner: Option[String]

    Definition Classes
    Suite → AbstractSuite
  301. def resetEnvironments: Unit

    Definition Classes
    Environments
  302. def resetflags(): Unit

    Definition Classes
    TranslatingDriverTransformingDriverDriver
  303. def result[T](v: ⇒ T): Parser[T]

    Definition Classes
    ParserUtilities
  304. 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
  305. def rootconstexpDef: (Expression) ⇒ Boolean

    Definition Classes
    TypeAnalyserNameAnalyserNameAnalyser
  306. def rootenv(bindings: (String, Entity)*): Environment

    Definition Classes
    Environments
  307. def rparen: Doc

    Definition Classes
    PrettyPrinterBase
  308. def run(testName: Option[String], args: Args): Unit

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

    Definition Classes
    AbstractSuite
  310. def runNestedSuites(args: Args): Unit

    Attributes
    protected
    Definition Classes
    Suite → AbstractSuite
  311. def runTest(testName: String, args: Args): Unit

    Attributes
    protected
    Definition Classes
    FunSuite → Suite → AbstractSuite
  312. def runTests(testName: Option[String], args: Args): Unit

    Attributes
    protected
    Definition Classes
    FunSuite → Suite → AbstractSuite
  313. 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
  314. 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
  315. def semi: Doc

    Definition Classes
    PrettyPrinterBase
  316. 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
  317. def sep(ds: Seq[Doc]): Doc

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

    Definition Classes
    Parser
  319. def skipWhitespace: Boolean

    Definition Classes
    WhitespaceParser → RegexParsers
  320. def softbreak: Doc

    Definition Classes
    PrettyPrinterBase
  321. def softline: Doc

    Definition Classes
    PrettyPrinterBase
  322. def space: Doc

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

    Definition Classes
    PrettyPrinterBase
  324. def squote: Doc

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

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

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

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

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

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

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

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

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

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

    Definition Classes
    ParserUtilities
  335. final val styleName: String

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

    Definition Classes
    Parsers
  337. def suiteId: String

    Definition Classes
    Suite
  338. def suiteName: String

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

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

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

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

    Definition Classes
    A4Phases
  343. lazy val term: PackratParser[Expression]

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

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

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

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

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

    The type of an expression.

    The type of an expression.

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

    Definition Classes
    TypeAnalyserTypeAnalyser
  350. def toDoc(n: CASTNode): Doc

  351. def toDoc(n: SourceASTNode): Doc

  352. def toParenDoc(e: PrettyExpression): Doc

    CNegExp (CNegExp) special case is to avoid output of --e which is interpreted as a pre-decrement operator.

    CNegExp (CNegExp) special case is to avoid output of --e which is interpreted as a pre-decrement operator.

    Definition Classes
    PrettyPrinterPrettyPrinterPrettyPrinterPrettyPrinter → ParenPrettyPrinter
  353. def toString(): String

    Definition Classes
    AnyRef → Any
  354. 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
  355. def translate(e: Expression): CExpression

    Uses of array parameter names don't need to be dereferenced.

    Uses of array parameter names don't need to be dereferenced.

    Definition Classes
    CCodeGeneratorCCodeGeneratorCCodeGenerator
  356. def translate(t: Type): CType

    Add translation for array and record types.

    Add translation for array and record types.

    Definition Classes
    CCodeGeneratorCCodeGenerator
  357. def translate(s: Statement): CStatement

    Add translation of call statements.

    Add translation of call statements.

    Definition Classes
    CCodeGeneratorCCodeGeneratorCCodeGeneratorCCodeGeneratorTranslator
  358. def translate(d: Declaration): List[CDeclaration]

    Add translation of procedure declarations.

    Add translation of procedure declarations.

    Definition Classes
    CCodeGeneratorCCodeGeneratorCCodeGeneratorTranslator
  359. def translate(m: ModuleDecl): CProgram

    Add STDIO header since output is now possible.

    Add STDIO header since output is now possible.

    Definition Classes
    CCodeGeneratorCCodeGeneratorTranslator
  360. def translate(eis: List[(Expression, Block)], oe: Option[Block]): CStatement

    Translation of expression, block pairs from an IF statement into cascading C IFs.

    Translation of expression, block pairs from an IF statement into cascading C IFs.

    Definition Classes
    CCodeGenerator
  361. def translateActualParam(p: Expression, mode: Mode): CExpression

    Array parameters get passed by reference, so we don't need to insert addressing operations for VAR.

    Array parameters get passed by reference, so we don't need to insert addressing operations for VAR.

    Definition Classes
    CCodeGeneratorCCodeGenerator
  362. def translateActualParams(u: IdnUse, ps: List[Expression]): List[CExpression]

    Translate the actual parameters of a procedure call.

    Translate the actual parameters of a procedure call. Assumes that the right number of parameters are present.

    Definition Classes
    CCodeGenerator
  363. def translateFormalParam(m: Mode, i: String, t: Type): CDeclaration

    Array formal parameters are not made into address types.

    Array formal parameters are not made into address types.

    Definition Classes
    CCodeGeneratorCCodeGenerator
  364. def translateFormalParams(p: IdnDef): List[CDeclaration]

    Translate the formal parameters of a particular defined procedure.

    Translate the formal parameters of a particular defined procedure.

    Definition Classes
    CCodeGenerator
  365. lazy val trueConstant: IntegerValue

    Built-in true constant.

    Built-in true constant.

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

    The actual type that a user type denotes.

    The actual type that a user type denotes.

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

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

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

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

    Definition Classes
    ParserParser
  371. 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
  372. 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
  373. def usageMessage: String

    Definition Classes
    TranslatingDriverTransformingDriverDriver
  374. def value(v: Any): Doc

    Definition Classes
    PrettyPrinterBase
  375. 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
  376. lazy val vardecl: Parser[VarDecl]

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

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

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

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

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

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

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

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

    Definition Classes
    Parser
  385. val whiteSpace: Regex

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

    Definition Classes
    Parser → WhitespaceParser
  387. def withClue[T](clue: Any)(fun: ⇒ T): T

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

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

    Definition Classes
    ParserUtilities
  390. lazy val writeProc: BuiltinProc

    The built-in Write procedure.

    The built-in Write procedure.

    Definition Classes
    SymbolTable
  391. lazy val writelnProc: BuiltinProc

    The built-in WriteLn procedure.

    The built-in WriteLn procedure.

    Definition Classes
    SymbolTable

Deprecated Value Members

  1. def expect(expected: Any)(actual: Any): Unit

    Definition Classes
    Assertions
    Annotations
    @deprecated
    Deprecated

    This expect method has been deprecated. Please replace all invocations of expect with an identical invocation of expectResult instead.

  2. def expect(expected: Any, clue: Any)(actual: Any): Unit

    Definition Classes
    Assertions
    Annotations
    @deprecated
    Deprecated

    This expect method has been deprecated. Please replace all invocations of expect with an identical invocation of expectResult instead.

  3. 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

  4. 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

  5. def product(p: Any): Doc

    Definition Classes
    PrettyPrinterBase
    Annotations
    @deprecated
    Deprecated

    (Since version 1.2.1) Use PrettyPrinter.any instead.

Inherited from TranslatingTestDriver

Inherited from TestDriver

Inherited from TestCompiler[ModuleDecl]

Inherited from FunSuite

Inherited from Suite

Inherited from Serializable

Inherited from AbstractSuite

Inherited from Assertions

Inherited from A4Phases

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from PrettyPrinter

Inherited from CPrettyPrinter

Inherited from CCodeGenerator

Inherited from CCodeGenerator

Inherited from CCodeGenerator

Inherited from CCodeGenerator

Inherited from CCodeGenerator

Inherited from Translator

Inherited from Desugarer

Inherited from Desugarer

Inherited from Lifter

Inherited from Transformer

Inherited from TypeAnalyser

Inherited from SymbolTable

Inherited from TypeAnalyser

Inherited from TypeAnalyser

Inherited from TypeAnalyser

Inherited from TypeAnalyser

Inherited from NameAnalyser

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 PrettyPrinter

Inherited from SourcePrettyPrinter

Inherited from ParenPrettyPrinter

Inherited from L4.Parser

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 TranslatingDriver

Inherited from TransformingDriver

Inherited from Driver

Inherited from PrettyPrinter

Inherited from PrettyPrinterBase

Inherited from Compiler[ModuleDecl]

Inherited from RegexCompiler[ModuleDecl]

Inherited from RegexParsers

Inherited from Parsers

Inherited from CompilerBase[ModuleDecl]

Inherited from AnyRef

Inherited from Any

Ungrouped