blob: e60cf7f585196464abfd113321163dbb31e7aa2b (
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
|
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2002-2006, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
// $Id$
package scala.runtime
import Predef.Class
import compat.Platform.createArray
[serializable]
final class BoxedObjectArray(val value: Array[AnyRef]) extends BoxedArray {
def length: Int = value.length
def apply(index: Int): Any = value(index)
def update(index: Int, elem: Any): Unit = {
value(index) = elem.asInstanceOf[AnyRef]
}
def unbox(elemTag: String): AnyRef = value
def unbox(elemClass: Class): AnyRef = value
override def equals(other: Any): Boolean =
value == other ||
other.isInstanceOf[BoxedObjectArray] && value == other.asInstanceOf[BoxedObjectArray].value
override def hashCode(): Int = value.hashCode()
private def create(length: Int): Array[AnyRef] = {
createArray(value.getClass().getComponentType(), length).asInstanceOf[Array[AnyRef]]
}
override def subArray(start: Int, end: Int): Array[AnyRef] = {
val result = create(end - start)
Array.copy(value, start, result, 0, end - start)
result
}
final override def filter(p: Any => Boolean): BoxedArray = {
val include = new Array[Boolean](value.length)
var len = 0
var i = 0
while (i < value.length) {
if (p(value(i))) { include(i) = true; len = len + 1 }
i = i + 1
}
val result = create(len)
len = 0
i = 0
while (len < result.length) {
if (include(i)) { result(len) = value(i); len = len + 1 }
i = i + 1
}
new BoxedObjectArray(result)
}
}
|