blob: 57d51dad49edccca3bc7c81c97ba6bd8db4d337e (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
/* NSC -- new Scala compiler
* Copyright 2005-2013 LAMP/EPFL
* @author Martin Odersky
*/
package scala.tools.nsc
package backend
package icode
/** This trait ...
*
* @author Iulian Dragos
* @version 1.0
*/
trait TypeStacks {
self: ICodes =>
/* This class simulates the type of the operand
* stack of the ICode.
*/
type Rep = List[TypeKind]
class TypeStack(var types: Rep) {
if (types.nonEmpty)
checkerDebug("Created " + this)
def this() = this(Nil)
def this(that: TypeStack) = this(that.types)
def length: Int = types.length
def isEmpty = length == 0
def nonEmpty = length != 0
/** Push a type on the type stack. UNITs are ignored. */
def push(t: TypeKind) = {
if (t != UNIT)
types = t :: types
}
def head: TypeKind = types.head
/** Removes the value on top of the stack, and returns it. It assumes
* the stack contains at least one element.
*/
def pop: TypeKind = {
val t = types.head
types = types.tail
t
}
/** Return the topmost two values on the stack. It assumes the stack
* is large enough. Topmost element first.
*/
def pop2: (TypeKind, TypeKind) = (pop, pop)
/** Return the topmost three values on the stack. It assumes the stack
* is large enough. Topmost element first.
*/
def pop3: (TypeKind, TypeKind, TypeKind) = (pop, pop, pop)
/** Drop the first n elements of the stack. */
def pop(n: Int): List[TypeKind] = {
val prefix = types.take(n)
types = types.drop(n)
prefix
}
def apply(n: Int): TypeKind = types(n)
/* This method returns a String representation of the stack */
override def toString() =
if (types.isEmpty) "[]"
else types.mkString("[", " ", "]")
override def hashCode() = types.hashCode()
override def equals(other: Any): Boolean = other match {
case x: TypeStack => x.types == types
case _ => false
}
}
}
|