org.kiama.example.oberon0.drivers

A4Phases

trait A4Phases extends TranslatingDriver with Parser with PrettyPrinter with NameAnalyser with TypeAnalyser with Lifter with Desugarer with CCodeGenerator with PrettyPrinter

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

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. 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. case class Field(ident: String, tipe: SymbolTable.Type) extends Entity with Product with Serializable

    A record field.

  15. type Indent = Int

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

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

  18. type Layout = String

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

    A user-defined module represented by a module declaration.

  20. case class MultipleEntity extends Entity with ErrorEntity with Product with Serializable

    Definition Classes
    Environments
  21. trait Named extends AnyRef

    Definition Classes
    Environments
  22. trait NamedEntity extends Entity with Named

    Definition Classes
    Environments
  23. sealed abstract class NoSuccess extends ParseResult[Nothing]

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

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

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

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

    Information about a particular parameter.

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

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

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

    Definition Classes
    Parsers
  31. trait PrettyPrintable extends AnyRef

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

    A procedure entity represented by a procedure declaration.

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

    A record with the given fields.

  34. type Scope = Map[String, Entity]

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

    Definition Classes
    Parsers
  36. abstract class Type extends Entity

    An entity representing by a user-provided type declaration.

  37. case class UnknownEntity extends Entity with ErrorEntity with Product with Serializable

    Definition Classes
    Environments
  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. def OnceParser[T](f: (Input) ⇒ ParseResult[T]): Parser[T] with OnceParser[T]

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

    Definition Classes
    PositionedParserUtilities → Parsers
  8. def accept[U](expected: String, f: PartialFunction[Elem, U]): Parser[U]

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

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

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

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

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

    Definition Classes
    Parsers
  14. def ampersand: Doc

    Definition Classes
    PrettyPrinterBase
  15. def angles(d: Doc): Doc

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

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

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

    Definition Classes
    PrettyPrinterBase
  19. def arraydimensToDoc(t1: CArrayType): Doc

    Definition Classes
    PrettyPrinter
  20. def artefact: String

    The name of this artefact.

    The name of this artefact.

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

    Definition Classes
    Any
  22. lazy val assignment: Parser[Assignment]

    Definition Classes
    Parser
  23. def asterisk: Doc

    Definition Classes
    PrettyPrinterBase
  24. def atsign: Doc

    Definition Classes
    PrettyPrinterBase
  25. def backquote: Doc

    Definition Classes
    PrettyPrinterBase
  26. def backslash: Doc

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

  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. def caret: Doc

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

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

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

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

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

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

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

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

    Definition Classes
    Parsers
  45. var challengeFlag: Boolean

    Definition Classes
    Driver
  46. val challengeFlagDefault: Boolean

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

    Definition Classes
    PrettyPrinterBase
  48. 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
  49. 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
  50. 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
  51. def clone(): AnyRef

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

    Definition Classes
    PrettyPrinterBase
  53. def comma: Doc

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

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

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

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

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

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

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

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

    Definition Classes
    ParserUtilities
  62. 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
  63. 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
  64. lazy val constdecl: Parser[ConstDecl]

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

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

    Definition Classes
    ParserUtilities
  67. 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
  68. lazy val declarations: PackratParser[List[Declaration]]

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

    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
    TypeAnalyserTypeAnalyser
  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 dollar: Doc

    Definition Classes
    PrettyPrinterBase
  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 encoding: String

    Definition Classes
    CompilerBase
  94. def enter(env: Environment): Environment

    Definition Classes
    Environments
  95. 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
  96. 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
  97. 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
  98. def envin(in: (SourceASTNode) ⇒ Environment): ==>[SourceASTNode, Environment]

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

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

    Definition Classes
    AnyRef
  103. def equal: Doc

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

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

    Definition Classes
    ParserUtilities → Parsers
  106. def exclamation: Doc

    Definition Classes
    PrettyPrinterBase
  107. 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
  108. lazy val expression: Parser[Expression]

    Definition Classes
    Parser
  109. 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
  110. 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
  111. lazy val factor: PackratParser[Expression]

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

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

    Built-in false constant.

    Built-in false constant.

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

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

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

    Definition Classes
    Parser
  117. def fillcat(ds: Seq[Doc]): Doc

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

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

    Definition Classes
    PrettyPrinterBase
  120. def finalize(): Unit

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

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

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

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

    Definition Classes
    Parser
  125. def forwslash: Doc

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

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

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

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

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

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

    Attributes
    protected
    Definition Classes
    RegexParsers
  132. 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
  133. def hash: Doc

    Definition Classes
    PrettyPrinterBase
  134. def hashCode(): Int

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

    Definition Classes
    PrettyPrinterBase
  136. var helpFlag: Boolean

    Definition Classes
    Driver
  137. val helpFlagDefault: Boolean

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

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

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

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

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

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

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

    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 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
  151. var input: Option[String]

    Definition Classes
    Driver
  152. lazy val integerType: BuiltinType

    Built-in integer type.

    Built-in integer type.

    Definition Classes
    SymbolTable
  153. lazy val intexp: Parser[IntExp]

    Definition Classes
    Parser
  154. 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
  155. 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
  156. 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
  157. 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
  158. def isDefinedInEnv(env: Environment, i: String): Boolean

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

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

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

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

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

    Definition Classes
    Any
  165. 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
  166. 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
  167. 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
  168. 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
  169. 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
  170. 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
  171. 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
  172. 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
  173. def isVariable(e: Entity): Boolean

    Parameters are variables too.

    Parameters are variables too.

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

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

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

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

    Definition Classes
    ParserUtilities
  179. def langle: Doc

    Definition Classes
    PrettyPrinterBase
  180. def langlevel: Int

  181. def lbrace: Doc

    Definition Classes
    PrettyPrinterBase
  182. def lbracket: Doc

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

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

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

    Definition Classes
    ParserParser
  187. def line: Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  188. def linebreak: Doc

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

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

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

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

    Definition Classes
    Environments
  193. def lparen: Doc

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

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

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

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

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

    Definition Classes
    RegexCompiler → CompilerBase
  199. 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
  200. def memo[T](p: Parser[T]): PackratParser[T]

    Definition Classes
    PackratParsers
  201. def minus: Doc

    Definition Classes
    PrettyPrinterBase
  202. def mkList[T]: (~[T, List[T]]) ⇒ List[T]

    Definition Classes
    Parsers
  203. lazy val moduledecl: Parser[ModuleDecl]

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

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

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

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  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 percent: Doc

    Definition Classes
    PrettyPrinterBase
  241. def phrase[T](p: Parser[T]): PackratParser[T]

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

    Definition Classes
    PrettyPrinterBase
  243. def plus: 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
    Driver
  247. var pprintcastFlag: Boolean

    Definition Classes
    TranslatingDriver
  248. val pprintcastFlagDefault: Boolean

    Definition Classes
    TranslatingDriver
  249. var pprintiastFlag: Boolean

    Definition Classes
    TransformingDriver
  250. val pprintiastFlagDefault: Boolean

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

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

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

    Definition Classes
    PrettyPrinterBase
  254. var printastFlag: Boolean

    Definition Classes
    Driver
  255. val printastFlagDefault: Boolean

    Definition Classes
    Driver
  256. var printcastFlag: Boolean

    Definition Classes
    TranslatingDriver
  257. val printcastFlagDefault: Boolean

    Definition Classes
    TranslatingDriver
  258. var printiastFlag: Boolean

    Definition Classes
    TransformingDriver
  259. val printiastFlagDefault: Boolean

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

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

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

    Definition Classes
    TranslatingDriverTransformingDriverDriver
  264. 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
  265. def question: Doc

    Definition Classes
    PrettyPrinterBase
  266. def rangle: Doc

    Definition Classes
    PrettyPrinterBase
  267. def rbrace: Doc

    Definition Classes
    PrettyPrinterBase
  268. def rbracket: Doc

    Definition Classes
    PrettyPrinterBase
  269. lazy val readProc: BuiltinProc

    The built-in Read procedure.

    The built-in Read procedure.

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

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

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

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

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

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

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

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

    Definition Classes
    Parsers
  278. def resetEnvironments: Unit

    Definition Classes
    Environments
  279. def resetflags(): Unit

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

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

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

    Definition Classes
    Environments
  284. def rparen: Doc

    Definition Classes
    PrettyPrinterBase
  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. def success[T](v: T): Parser[T]

    Definition Classes
    Parsers
  307. def surround(d: Doc, b: Doc): Doc

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

    Definition Classes
    AnyRef
  309. def tasklevel: Int

  310. lazy val term: PackratParser[Expression]

    Definition Classes
    Parser
  311. implicit def text(t: String): Doc

    Definition Classes
    PrettyPrinter → PrettyPrinterBase
  312. def tilde: Doc

    Definition Classes
    PrettyPrinterBase
  313. lazy val tipe: (Expression) ⇒ Type

    The type of an expression.

    The type of an expression.

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

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

  316. def toDoc(n: SourceASTNode): Doc

  317. 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
  318. def toString(): String

    Definition Classes
    AnyRef → Any
  319. 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
  320. 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
  321. def translate(t: Type): CType

    Add translation for array and record types.

    Add translation for array and record types.

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

    Add translation of call statements.

    Add translation of call statements.

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

    Add translation of procedure declarations.

    Add translation of procedure declarations.

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

    Add STDIO header since output is now possible.

    Add STDIO header since output is now possible.

    Definition Classes
    CCodeGeneratorCCodeGeneratorTranslator
  325. 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
  326. 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
  327. 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
  328. 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
  329. 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
  330. lazy val trueConstant: IntegerValue

    Built-in true constant.

    Built-in true constant.

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

    The actual type that a user type denotes.

    The actual type that a user type denotes.

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

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

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

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

    Definition Classes
    ParserParser
  336. def underscore: Doc

    Definition Classes
    PrettyPrinterBase
  337. 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
  338. 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
  339. def usageMessage: String

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

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

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

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

    Definition Classes
    PrettyPrinterBase
  345. def verticalbar: Doc

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

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

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

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

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

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

    Definition Classes
    Parser
  352. val whiteSpace: Regex

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

    Definition Classes
    Parser → WhitespaceParser
  354. def wrap[T, U](p: ⇒ Parser[T], f: (T) ⇒ Either[U, String]): Parser[U]

    Definition Classes
    ParserUtilities
  355. lazy val writeProc: BuiltinProc

    The built-in Write procedure.

    The built-in Write procedure.

    Definition Classes
    SymbolTable
  356. 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 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