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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import * as assert from 'assert';
import { FoldingMarkers } from 'vs/editor/common/languages/languageConfiguration';
import { MAX_FOLDING_REGIONS } from 'vs/editor/contrib/folding/browser/foldingRanges';
import { computeRanges } from 'vs/editor/contrib/folding/browser/indentRangeProvider';
import { createTextModel } from 'vs/editor/test/common/testTextModel';
const markers: FoldingMarkers = {
start: /^\s*#region\b/,
end: /^\s*#endregion\b/
};
suite('FoldingRanges', () => {
test('test max folding regions', () => {
const lines: string[] = [];
const nRegions = MAX_FOLDING_REGIONS;
for (let i = 0; i < nRegions; i++) {
lines.push('#region');
}
for (let i = 0; i < nRegions; i++) {
lines.push('#endregion');
}
const model = createTextModel(lines.join('\n'));
const actual = computeRanges(model, false, markers, MAX_FOLDING_REGIONS);
assert.strictEqual(actual.length, nRegions, 'len');
for (let i = 0; i < nRegions; i++) {
assert.strictEqual(actual.getStartLineNumber(i), i + 1, 'start' + i);
assert.strictEqual(actual.getEndLineNumber(i), nRegions * 2 - i, 'end' + i);
assert.strictEqual(actual.getParentIndex(i), i - 1, 'parent' + i);
}
model.dispose();
});
test('findRange', () => {
const lines = [
/* 1*/ '#region',
/* 2*/ '#endregion',
/* 3*/ 'class A {',
/* 4*/ ' void foo() {',
/* 5*/ ' if (true) {',
/* 6*/ ' return;',
/* 7*/ ' }',
/* 8*/ '',
/* 9*/ ' if (true) {',
/* 10*/ ' return;',
/* 11*/ ' }',
/* 12*/ ' }',
/* 13*/ '}'];
const textModel = createTextModel(lines.join('\n'));
try {
const actual = computeRanges(textModel, false, markers);
// let r0 = r(1, 2);
// let r1 = r(3, 12);
// let r2 = r(4, 11);
// let r3 = r(5, 6);
// let r4 = r(9, 10);
assert.strictEqual(actual.findRange(1), 0, '1');
assert.strictEqual(actual.findRange(2), 0, '2');
assert.strictEqual(actual.findRange(3), 1, '3');
assert.strictEqual(actual.findRange(4), 2, '4');
assert.strictEqual(actual.findRange(5), 3, '5');
assert.strictEqual(actual.findRange(6), 3, '6');
assert.strictEqual(actual.findRange(7), 2, '7');
assert.strictEqual(actual.findRange(8), 2, '8');
assert.strictEqual(actual.findRange(9), 4, '9');
assert.strictEqual(actual.findRange(10), 4, '10');
assert.strictEqual(actual.findRange(11), 2, '11');
assert.strictEqual(actual.findRange(12), 1, '12');
assert.strictEqual(actual.findRange(13), -1, '13');
} finally {
textModel.dispose();
}
});
test('setCollapsed', () => {
const lines: string[] = [];
const nRegions = 500;
for (let i = 0; i < nRegions; i++) {
lines.push('#region');
}
for (let i = 0; i < nRegions; i++) {
lines.push('#endregion');
}
const model = createTextModel(lines.join('\n'));
const actual = computeRanges(model, false, markers, MAX_FOLDING_REGIONS);
assert.strictEqual(actual.length, nRegions, 'len');
for (let i = 0; i < nRegions; i++) {
actual.setCollapsed(i, i % 3 === 0);
}
for (let i = 0; i < nRegions; i++) {
assert.strictEqual(actual.isCollapsed(i), i % 3 === 0, 'line' + i);
}
model.dispose();
});
});
|