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
|
function makeRope() {
var left = newRope("@ABCDEFGHIJKLMNO", "PQRSTUVWXYZ[\\]^_");
var right = newRope("`abcdefghijklmno", "pqrstuvwxyz{|}~");
var rope = newRope(left, right);
return {left, right, rope};
}
// Load a character from the left rope child using a constant index. The input
// to String.prototype.charAt is always rope.
function testLeftChildConstant() {
for (var i = 0; i < 200; ++i) {
var {rope} = makeRope();
var ch = rope.charAt(0);
assertEq(ch, "@");
}
}
for (var i = 0; i < 2; ++i) {
testLeftChildConstant();
}
// Load a character from the right rope child using a constant index. The input
// to String.prototype.charAt is always rope.
function testRightChildConstant() {
for (var i = 0; i < 200; ++i) {
var {rope} = makeRope();
var ch = rope.charAt(32);
assertEq(ch, "`");
}
}
for (var i = 0; i < 2; ++i) {
testRightChildConstant();
}
// Load a character from the left rope child using a variable index. The input
// to String.prototype.charAt is always rope.
function testLeftChildVariable() {
for (var i = 0; i < 200; ++i) {
var {left, rope} = makeRope();
var idx = i % left.length;
var ch = rope.charAt(idx);
assertEq(ch, String.fromCharCode(0x40 + idx));
}
}
for (var i = 0; i < 2; ++i) {
testLeftChildVariable();
}
// Load a character from the right rope child using a variable index. The input
// to String.prototype.charAt is always rope.
function testRightChildVariable() {
for (var i = 0; i < 200; ++i) {
var {left, right, rope} = makeRope();
var idx = i % right.length;
var ch = rope.charAt(left.length + idx);
assertEq(ch, String.fromCharCode(0x60 + idx));
}
}
for (var i = 0; i < 2; ++i) {
testRightChildVariable();
}
// Load all characters from both child ropes. This covers the case when the
// call to String.prototype.charAt linearizes the rope.
function testBothChildren() {
for (var i = 0; i < 200; ++i) {
var {rope} = makeRope();
for (var j = 0; j < rope.length; ++j) {
var ch = rope.charAt(j);
assertEq(ch, String.fromCharCode(0x40 + j));
}
}
}
for (var i = 0; i < 2; ++i) {
testBothChildren();
}
|