@xterm/xterm 5.6.0-beta.8 → 5.6.0-beta.80
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -3
- package/css/xterm.css +71 -4
- package/lib/xterm.js +1 -1
- package/lib/xterm.js.map +1 -1
- package/lib/xterm.mjs +53 -0
- package/lib/xterm.mjs.map +7 -0
- package/package.json +43 -33
- package/src/browser/AccessibilityManager.ts +53 -25
- package/src/browser/{Terminal.ts → CoreBrowserTerminal.ts} +139 -148
- package/src/browser/Linkifier.ts +26 -14
- package/src/browser/LocalizableStrings.ts +15 -4
- package/src/browser/{Types.d.ts → Types.ts} +67 -15
- package/src/browser/Viewport.ts +143 -370
- package/src/browser/decorations/BufferDecorationRenderer.ts +14 -9
- package/src/browser/decorations/OverviewRulerRenderer.ts +40 -44
- package/src/browser/public/Terminal.ts +25 -19
- package/src/browser/renderer/dom/DomRenderer.ts +22 -19
- package/src/browser/renderer/dom/DomRendererRowFactory.ts +35 -15
- package/src/browser/renderer/shared/CharAtlasUtils.ts +4 -0
- package/src/browser/renderer/shared/CustomGlyphs.ts +6 -0
- package/src/browser/renderer/shared/DevicePixelObserver.ts +1 -2
- package/src/browser/renderer/shared/TextureAtlas.ts +3 -3
- package/src/browser/renderer/shared/{Types.d.ts → Types.ts} +4 -4
- package/src/browser/services/CharSizeService.ts +6 -6
- package/src/browser/services/CoreBrowserService.ts +15 -15
- package/src/browser/services/LinkProviderService.ts +2 -2
- package/src/browser/services/RenderService.ts +20 -20
- package/src/browser/services/SelectionService.ts +8 -8
- package/src/browser/services/Services.ts +13 -13
- package/src/browser/services/ThemeService.ts +19 -58
- package/src/browser/shared/Constants.ts +8 -0
- package/src/common/CircularList.ts +5 -5
- package/src/common/CoreTerminal.ts +35 -41
- package/src/common/InputHandler.ts +63 -51
- package/src/common/{Types.d.ts → Types.ts} +13 -17
- package/src/common/buffer/Buffer.ts +15 -7
- package/src/common/buffer/BufferReflow.ts +9 -6
- package/src/common/buffer/BufferSet.ts +5 -5
- package/src/common/buffer/Marker.ts +4 -4
- package/src/common/buffer/{Types.d.ts → Types.ts} +2 -2
- package/src/common/input/WriteBuffer.ts +3 -3
- package/src/common/parser/EscapeSequenceParser.ts +4 -4
- package/src/common/public/BufferNamespaceApi.ts +3 -3
- package/src/common/services/BufferService.ts +7 -7
- package/src/common/services/CoreMouseService.ts +5 -3
- package/src/common/services/CoreService.ts +8 -6
- package/src/common/services/DecorationService.ts +8 -9
- package/src/common/services/InstantiationService.ts +1 -1
- package/src/common/services/LogService.ts +2 -2
- package/src/common/services/OptionsService.ts +6 -5
- package/src/common/services/ServiceRegistry.ts +1 -1
- package/src/common/services/Services.ts +26 -17
- package/src/common/services/UnicodeService.ts +2 -2
- package/src/vs/base/browser/browser.ts +141 -0
- package/src/vs/base/browser/canIUse.ts +49 -0
- package/src/vs/base/browser/dom.ts +2369 -0
- package/src/vs/base/browser/fastDomNode.ts +316 -0
- package/src/vs/base/browser/globalPointerMoveMonitor.ts +112 -0
- package/src/vs/base/browser/iframe.ts +135 -0
- package/src/vs/base/browser/keyboardEvent.ts +213 -0
- package/src/vs/base/browser/mouseEvent.ts +229 -0
- package/src/vs/base/browser/touch.ts +372 -0
- package/src/vs/base/browser/ui/scrollbar/abstractScrollbar.ts +303 -0
- package/src/vs/base/browser/ui/scrollbar/horizontalScrollbar.ts +114 -0
- package/src/vs/base/browser/ui/scrollbar/scrollableElement.ts +720 -0
- package/src/vs/base/browser/ui/scrollbar/scrollableElementOptions.ts +165 -0
- package/src/vs/base/browser/ui/scrollbar/scrollbarArrow.ts +114 -0
- package/src/vs/base/browser/ui/scrollbar/scrollbarState.ts +243 -0
- package/src/vs/base/browser/ui/scrollbar/scrollbarVisibilityController.ts +118 -0
- package/src/vs/base/browser/ui/scrollbar/verticalScrollbar.ts +116 -0
- package/src/vs/base/browser/ui/widget.ts +57 -0
- package/src/vs/base/browser/window.ts +14 -0
- package/src/vs/base/common/arrays.ts +887 -0
- package/src/vs/base/common/arraysFind.ts +202 -0
- package/src/vs/base/common/assert.ts +71 -0
- package/src/vs/base/common/async.ts +1992 -0
- package/src/vs/base/common/cancellation.ts +148 -0
- package/src/vs/base/common/charCode.ts +450 -0
- package/src/vs/base/common/collections.ts +140 -0
- package/src/vs/base/common/decorators.ts +130 -0
- package/src/vs/base/common/equals.ts +146 -0
- package/src/vs/base/common/errors.ts +303 -0
- package/src/vs/base/common/event.ts +1778 -0
- package/src/vs/base/common/functional.ts +32 -0
- package/src/vs/base/common/hash.ts +316 -0
- package/src/vs/base/common/iterator.ts +159 -0
- package/src/vs/base/common/keyCodes.ts +526 -0
- package/src/vs/base/common/keybindings.ts +284 -0
- package/src/vs/base/common/lazy.ts +47 -0
- package/src/vs/base/common/lifecycle.ts +801 -0
- package/src/vs/base/common/linkedList.ts +142 -0
- package/src/vs/base/common/map.ts +202 -0
- package/src/vs/base/common/numbers.ts +98 -0
- package/src/vs/base/common/observable.ts +76 -0
- package/src/vs/base/common/observableInternal/api.ts +31 -0
- package/src/vs/base/common/observableInternal/autorun.ts +281 -0
- package/src/vs/base/common/observableInternal/base.ts +489 -0
- package/src/vs/base/common/observableInternal/debugName.ts +145 -0
- package/src/vs/base/common/observableInternal/derived.ts +428 -0
- package/src/vs/base/common/observableInternal/lazyObservableValue.ts +146 -0
- package/src/vs/base/common/observableInternal/logging.ts +328 -0
- package/src/vs/base/common/observableInternal/promise.ts +209 -0
- package/src/vs/base/common/observableInternal/utils.ts +610 -0
- package/src/vs/base/common/platform.ts +281 -0
- package/src/vs/base/common/scrollable.ts +522 -0
- package/src/vs/base/common/sequence.ts +34 -0
- package/src/vs/base/common/stopwatch.ts +43 -0
- package/src/vs/base/common/strings.ts +557 -0
- package/src/vs/base/common/symbols.ts +9 -0
- package/src/vs/base/common/uint.ts +59 -0
- package/src/vs/patches/nls.ts +90 -0
- package/src/vs/typings/base-common.d.ts +20 -0
- package/src/vs/typings/require.d.ts +42 -0
- package/src/vs/typings/thenable.d.ts +12 -0
- package/src/vs/typings/vscode-globals-nls.d.ts +36 -0
- package/src/vs/typings/vscode-globals-product.d.ts +33 -0
- package/typings/xterm.d.ts +66 -15
- package/src/browser/Lifecycle.ts +0 -33
- package/src/common/EventEmitter.ts +0 -78
- package/src/common/Lifecycle.ts +0 -108
- /package/src/browser/selection/{Types.d.ts → Types.ts} +0 -0
- /package/src/common/parser/{Types.d.ts → Types.ts} +0 -0
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
3
|
+
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
|
|
6
|
+
import { Comparator } from './arrays';
|
|
7
|
+
|
|
8
|
+
export function findLast<T>(array: readonly T[], predicate: (item: T) => boolean): T | undefined {
|
|
9
|
+
const idx = findLastIdx(array, predicate);
|
|
10
|
+
if (idx === -1) {
|
|
11
|
+
return undefined;
|
|
12
|
+
}
|
|
13
|
+
return array[idx];
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export function findLastIdx<T>(array: readonly T[], predicate: (item: T) => boolean, fromIndex = array.length - 1): number {
|
|
17
|
+
for (let i = fromIndex; i >= 0; i--) {
|
|
18
|
+
const element = array[i];
|
|
19
|
+
|
|
20
|
+
if (predicate(element)) {
|
|
21
|
+
return i;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
return -1;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Finds the last item where predicate is true using binary search.
|
|
30
|
+
* `predicate` must be monotonous, i.e. `arr.map(predicate)` must be like `[true, ..., true, false, ..., false]`!
|
|
31
|
+
*
|
|
32
|
+
* @returns `undefined` if no item matches, otherwise the last item that matches the predicate.
|
|
33
|
+
*/
|
|
34
|
+
export function findLastMonotonous<T>(array: readonly T[], predicate: (item: T) => boolean): T | undefined {
|
|
35
|
+
const idx = findLastIdxMonotonous(array, predicate);
|
|
36
|
+
return idx === -1 ? undefined : array[idx];
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Finds the last item where predicate is true using binary search.
|
|
41
|
+
* `predicate` must be monotonous, i.e. `arr.map(predicate)` must be like `[true, ..., true, false, ..., false]`!
|
|
42
|
+
*
|
|
43
|
+
* @returns `startIdx - 1` if predicate is false for all items, otherwise the index of the last item that matches the predicate.
|
|
44
|
+
*/
|
|
45
|
+
export function findLastIdxMonotonous<T>(array: readonly T[], predicate: (item: T) => boolean, startIdx = 0, endIdxEx = array.length): number {
|
|
46
|
+
let i = startIdx;
|
|
47
|
+
let j = endIdxEx;
|
|
48
|
+
while (i < j) {
|
|
49
|
+
const k = Math.floor((i + j) / 2);
|
|
50
|
+
if (predicate(array[k])) {
|
|
51
|
+
i = k + 1;
|
|
52
|
+
} else {
|
|
53
|
+
j = k;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return i - 1;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Finds the first item where predicate is true using binary search.
|
|
61
|
+
* `predicate` must be monotonous, i.e. `arr.map(predicate)` must be like `[false, ..., false, true, ..., true]`!
|
|
62
|
+
*
|
|
63
|
+
* @returns `undefined` if no item matches, otherwise the first item that matches the predicate.
|
|
64
|
+
*/
|
|
65
|
+
export function findFirstMonotonous<T>(array: readonly T[], predicate: (item: T) => boolean): T | undefined {
|
|
66
|
+
const idx = findFirstIdxMonotonousOrArrLen(array, predicate);
|
|
67
|
+
return idx === array.length ? undefined : array[idx];
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Finds the first item where predicate is true using binary search.
|
|
72
|
+
* `predicate` must be monotonous, i.e. `arr.map(predicate)` must be like `[false, ..., false, true, ..., true]`!
|
|
73
|
+
*
|
|
74
|
+
* @returns `endIdxEx` if predicate is false for all items, otherwise the index of the first item that matches the predicate.
|
|
75
|
+
*/
|
|
76
|
+
export function findFirstIdxMonotonousOrArrLen<T>(array: readonly T[], predicate: (item: T) => boolean, startIdx = 0, endIdxEx = array.length): number {
|
|
77
|
+
let i = startIdx;
|
|
78
|
+
let j = endIdxEx;
|
|
79
|
+
while (i < j) {
|
|
80
|
+
const k = Math.floor((i + j) / 2);
|
|
81
|
+
if (predicate(array[k])) {
|
|
82
|
+
j = k;
|
|
83
|
+
} else {
|
|
84
|
+
i = k + 1;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return i;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export function findFirstIdxMonotonous<T>(array: readonly T[], predicate: (item: T) => boolean, startIdx = 0, endIdxEx = array.length): number {
|
|
91
|
+
const idx = findFirstIdxMonotonousOrArrLen(array, predicate, startIdx, endIdxEx);
|
|
92
|
+
return idx === array.length ? -1 : idx;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Use this when
|
|
97
|
+
* * You have a sorted array
|
|
98
|
+
* * You query this array with a monotonous predicate to find the last item that has a certain property.
|
|
99
|
+
* * You query this array multiple times with monotonous predicates that get weaker and weaker.
|
|
100
|
+
*/
|
|
101
|
+
export class MonotonousArray<T> {
|
|
102
|
+
public static assertInvariants = false;
|
|
103
|
+
|
|
104
|
+
private _findLastMonotonousLastIdx = 0;
|
|
105
|
+
private _prevFindLastPredicate: ((item: T) => boolean) | undefined;
|
|
106
|
+
|
|
107
|
+
constructor(private readonly _array: readonly T[]) {
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* The predicate must be monotonous, i.e. `arr.map(predicate)` must be like `[true, ..., true, false, ..., false]`!
|
|
112
|
+
* For subsequent calls, current predicate must be weaker than (or equal to) the previous predicate, i.e. more entries must be `true`.
|
|
113
|
+
*/
|
|
114
|
+
findLastMonotonous(predicate: (item: T) => boolean): T | undefined {
|
|
115
|
+
if (MonotonousArray.assertInvariants) {
|
|
116
|
+
if (this._prevFindLastPredicate) {
|
|
117
|
+
for (const item of this._array) {
|
|
118
|
+
if (this._prevFindLastPredicate(item) && !predicate(item)) {
|
|
119
|
+
throw new Error('MonotonousArray: current predicate must be weaker than (or equal to) the previous predicate.');
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
this._prevFindLastPredicate = predicate;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
const idx = findLastIdxMonotonous(this._array, predicate, this._findLastMonotonousLastIdx);
|
|
127
|
+
this._findLastMonotonousLastIdx = idx + 1;
|
|
128
|
+
return idx === -1 ? undefined : this._array[idx];
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Returns the first item that is equal to or greater than every other item.
|
|
134
|
+
*/
|
|
135
|
+
export function findFirstMax<T>(array: readonly T[], comparator: Comparator<T>): T | undefined {
|
|
136
|
+
if (array.length === 0) {
|
|
137
|
+
return undefined;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
let max = array[0];
|
|
141
|
+
for (let i = 1; i < array.length; i++) {
|
|
142
|
+
const item = array[i];
|
|
143
|
+
if (comparator(item, max) > 0) {
|
|
144
|
+
max = item;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
return max;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
/**
|
|
151
|
+
* Returns the last item that is equal to or greater than every other item.
|
|
152
|
+
*/
|
|
153
|
+
export function findLastMax<T>(array: readonly T[], comparator: Comparator<T>): T | undefined {
|
|
154
|
+
if (array.length === 0) {
|
|
155
|
+
return undefined;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
let max = array[0];
|
|
159
|
+
for (let i = 1; i < array.length; i++) {
|
|
160
|
+
const item = array[i];
|
|
161
|
+
if (comparator(item, max) >= 0) {
|
|
162
|
+
max = item;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
return max;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
/**
|
|
169
|
+
* Returns the first item that is equal to or less than every other item.
|
|
170
|
+
*/
|
|
171
|
+
export function findFirstMin<T>(array: readonly T[], comparator: Comparator<T>): T | undefined {
|
|
172
|
+
return findFirstMax(array, (a, b) => -comparator(a, b));
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
export function findMaxIdx<T>(array: readonly T[], comparator: Comparator<T>): number {
|
|
176
|
+
if (array.length === 0) {
|
|
177
|
+
return -1;
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
let maxIdx = 0;
|
|
181
|
+
for (let i = 1; i < array.length; i++) {
|
|
182
|
+
const item = array[i];
|
|
183
|
+
if (comparator(item, array[maxIdx]) > 0) {
|
|
184
|
+
maxIdx = i;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
return maxIdx;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
/**
|
|
191
|
+
* Returns the first mapped value of the array which is not undefined.
|
|
192
|
+
*/
|
|
193
|
+
export function mapFindFirst<T, R>(items: Iterable<T>, mapFn: (value: T) => R | undefined): R | undefined {
|
|
194
|
+
for (const value of items) {
|
|
195
|
+
const mapped = mapFn(value);
|
|
196
|
+
if (mapped !== undefined) {
|
|
197
|
+
return mapped;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
return undefined;
|
|
202
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
3
|
+
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
|
|
6
|
+
import { BugIndicatingError, onUnexpectedError } from 'vs/base/common/errors';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Throws an error with the provided message if the provided value does not evaluate to a true Javascript value.
|
|
10
|
+
*
|
|
11
|
+
* @deprecated Use `assert(...)` instead.
|
|
12
|
+
* This method is usually used like this:
|
|
13
|
+
* ```ts
|
|
14
|
+
* import * as assert from 'vs/base/common/assert';
|
|
15
|
+
* assert.ok(...);
|
|
16
|
+
* ```
|
|
17
|
+
*
|
|
18
|
+
* However, `assert` in that example is a user chosen name.
|
|
19
|
+
* There is no tooling for generating such an import statement.
|
|
20
|
+
* Thus, the `assert(...)` function should be used instead.
|
|
21
|
+
*/
|
|
22
|
+
export function ok(value?: unknown, message?: string) {
|
|
23
|
+
if (!value) {
|
|
24
|
+
throw new Error(message ? `Assertion failed (${message})` : 'Assertion Failed');
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export function assertNever(value: never, message = 'Unreachable'): never {
|
|
29
|
+
throw new Error(message);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export function assert(condition: boolean, message = 'unexpected state'): asserts condition {
|
|
33
|
+
if (!condition) {
|
|
34
|
+
throw new BugIndicatingError(`Assertion Failed: ${message}`);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Like assert, but doesn't throw.
|
|
40
|
+
*/
|
|
41
|
+
export function softAssert(condition: boolean): void {
|
|
42
|
+
if (!condition) {
|
|
43
|
+
onUnexpectedError(new BugIndicatingError('Soft Assertion Failed'));
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* condition must be side-effect free!
|
|
49
|
+
*/
|
|
50
|
+
export function assertFn(condition: () => boolean): void {
|
|
51
|
+
if (!condition()) {
|
|
52
|
+
// eslint-disable-next-line no-debugger
|
|
53
|
+
debugger;
|
|
54
|
+
// Reevaluate `condition` again to make debugging easier
|
|
55
|
+
condition();
|
|
56
|
+
onUnexpectedError(new BugIndicatingError('Assertion Failed'));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export function checkAdjacentItems<T>(items: readonly T[], predicate: (item1: T, item2: T) => boolean): boolean {
|
|
61
|
+
let i = 0;
|
|
62
|
+
while (i < items.length - 1) {
|
|
63
|
+
const a = items[i];
|
|
64
|
+
const b = items[i + 1];
|
|
65
|
+
if (!predicate(a, b)) {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
i++;
|
|
69
|
+
}
|
|
70
|
+
return true;
|
|
71
|
+
}
|