@theia/terminal 1.53.0-next.5 → 1.53.0-next.55

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.
Files changed (45) hide show
  1. package/README.md +30 -30
  2. package/lib/browser/terminal-link-provider.d.ts +1 -1
  3. package/lib/browser/terminal-link-provider.d.ts.map +1 -1
  4. package/lib/browser/terminal-widget-impl.js +4 -4
  5. package/package.json +10 -10
  6. package/src/browser/base/terminal-service.ts +60 -60
  7. package/src/browser/base/terminal-widget.ts +268 -268
  8. package/src/browser/index.ts +17 -17
  9. package/src/browser/search/terminal-search-container.ts +28 -28
  10. package/src/browser/search/terminal-search-widget.tsx +161 -161
  11. package/src/browser/shell-terminal-profile.ts +45 -45
  12. package/src/browser/style/terminal-search.css +99 -99
  13. package/src/browser/style/terminal.css +32 -32
  14. package/src/browser/terminal-contribution.ts +19 -19
  15. package/src/browser/terminal-copy-on-selection-handler.ts +92 -92
  16. package/src/browser/terminal-file-link-provider.ts +289 -289
  17. package/src/browser/terminal-frontend-contribution.ts +1134 -1134
  18. package/src/browser/terminal-frontend-module.ts +138 -138
  19. package/src/browser/terminal-link-helpers.ts +187 -187
  20. package/src/browser/terminal-link-provider.ts +203 -203
  21. package/src/browser/terminal-preferences.ts +428 -428
  22. package/src/browser/terminal-profile-service.ts +180 -180
  23. package/src/browser/terminal-quick-open-service.ts +132 -132
  24. package/src/browser/terminal-theme-service.ts +213 -213
  25. package/src/browser/terminal-url-link-provider.ts +66 -66
  26. package/src/browser/terminal-widget-impl.ts +996 -996
  27. package/src/common/base-terminal-protocol.ts +125 -125
  28. package/src/common/shell-terminal-protocol.ts +103 -103
  29. package/src/common/terminal-common-module.ts +30 -30
  30. package/src/common/terminal-protocol.ts +32 -32
  31. package/src/common/terminal-watcher.ts +69 -69
  32. package/src/node/base-terminal-server.ts +173 -173
  33. package/src/node/buffering-stream.spec.ts +46 -46
  34. package/src/node/buffering-stream.ts +95 -95
  35. package/src/node/index.ts +17 -17
  36. package/src/node/shell-process.ts +102 -102
  37. package/src/node/shell-terminal-server.spec.ts +40 -40
  38. package/src/node/shell-terminal-server.ts +223 -223
  39. package/src/node/terminal-backend-contribution.slow-spec.ts +63 -63
  40. package/src/node/terminal-backend-contribution.ts +60 -60
  41. package/src/node/terminal-backend-module.ts +82 -82
  42. package/src/node/terminal-server.spec.ts +47 -47
  43. package/src/node/terminal-server.ts +52 -52
  44. package/src/node/test/terminal-test-container.ts +39 -39
  45. package/src/package.spec.ts +28 -28
@@ -1,187 +1,187 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2022 STMicroelectronics and others.
3
- //
4
- // This program and the accompanying materials are made available under the
5
- // terms of the Eclipse Public License v. 2.0 which is available at
6
- // http://www.eclipse.org/legal/epl-2.0.
7
- //
8
- // This Source Code may also be made available under the following Secondary
9
- // Licenses when the conditions for such availability set forth in the Eclipse
10
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
- // with the GNU Classpath Exception which is available at
12
- // https://www.gnu.org/software/classpath/license.html.
13
- //
14
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
- // *****************************************************************************
16
-
17
- import type { IBufferRange, IBufferLine, IBuffer, Terminal } from 'xterm';
18
-
19
- export const LinkContext = Symbol('LinkContext');
20
- export interface LinkContext {
21
- text: string;
22
- startLine: number;
23
- lines: IBufferLine[];
24
- }
25
-
26
- /**
27
- * Mimics VS Code IRange
28
- */
29
- interface TerminalRange {
30
- readonly startLineNumber: number;
31
- readonly startColumn: number;
32
- readonly endLineNumber: number;
33
- readonly endColumn: number;
34
- }
35
-
36
- /*---------------------------------------------------------------------------------------------
37
- * Copyright (c) Microsoft Corporation and others. All rights reserved.
38
- * Licensed under the MIT License.
39
- *--------------------------------------------------------------------------------------------*/
40
- export function getLinkContext(terminal: Terminal, line: number, maxLinkLength = 2000): LinkContext {
41
- // The following method is based on VS Code's TerminalLinkDetectorAdapter._provideLinks()
42
- // https://github.com/microsoft/vscode/blob/7888ff3a6b104e9e2e3d0f7890ca92dd0828215f/src/vs/workbench/contrib/terminal/browser/links/terminalLinkDetectorAdapter.ts#L51
43
- let startLine = line - 1;
44
- let endLine = startLine;
45
-
46
- const lines: IBufferLine[] = [terminal.buffer.active.getLine(startLine)!];
47
-
48
- // Cap the maximum context on either side of the line being provided, by taking the context
49
- // around the line being provided for this ensures the line the pointer is on will have
50
- // links provided.
51
- const maxLineContext = Math.max(maxLinkLength / terminal.cols);
52
- const minStartLine = Math.max(startLine - maxLineContext, 0);
53
- const maxEndLine = Math.min(endLine + maxLineContext, terminal.buffer.active.length);
54
-
55
- while (startLine >= minStartLine && terminal.buffer.active.getLine(startLine)?.isWrapped) {
56
- lines.unshift(terminal.buffer.active.getLine(startLine - 1)!);
57
- startLine--;
58
- }
59
-
60
- while (endLine < maxEndLine && terminal.buffer.active.getLine(endLine + 1)?.isWrapped) {
61
- lines.push(terminal.buffer.active.getLine(endLine + 1)!);
62
- endLine++;
63
- }
64
-
65
- const text = getXtermLineContent(terminal.buffer.active, startLine, endLine, terminal.cols);
66
-
67
- return { text, startLine, lines };
68
- }
69
-
70
- // The following code is taken as is from
71
- // https://github.com/microsoft/vscode/blob/7888ff3a6b104e9e2e3d0f7890ca92dd0828215f/src/vs/workbench/contrib/terminal/browser/links/terminalLinkHelpers.ts#L1
72
-
73
- /**
74
- * Converts a possibly wrapped link's range (comprised of string indices) into a buffer range that plays nicely with xterm.js
75
- *
76
- * @param lines A single line (not the entire buffer)
77
- * @param bufferWidth The number of columns in the terminal
78
- * @param range The link range - string indices
79
- * @param startLine The absolute y position (on the buffer) of the line
80
- */
81
- export function convertLinkRangeToBuffer(
82
- lines: IBufferLine[],
83
- bufferWidth: number,
84
- range: TerminalRange,
85
- startLine: number
86
- ): IBufferRange {
87
- const bufferRange: IBufferRange = {
88
- start: {
89
- x: range.startColumn,
90
- y: range.startLineNumber + startLine
91
- },
92
- end: {
93
- x: range.endColumn - 1,
94
- y: range.endLineNumber + startLine
95
- }
96
- };
97
-
98
- // Shift start range right for each wide character before the link
99
- let startOffset = 0;
100
- const startWrappedLineCount = Math.ceil(range.startColumn / bufferWidth);
101
- for (let y = 0; y < Math.min(startWrappedLineCount); y++) {
102
- const lineLength = Math.min(bufferWidth, range.startColumn - y * bufferWidth);
103
- let lineOffset = 0;
104
- const line = lines[y];
105
- // Sanity check for line, apparently this can happen but it's not clear under what
106
- // circumstances this happens. Continue on, skipping the remainder of start offset if this
107
- // happens to minimize impact.
108
- if (!line) {
109
- break;
110
- }
111
- for (let x = 0; x < Math.min(bufferWidth, lineLength + lineOffset); x++) {
112
- const cell = line.getCell(x)!;
113
- const width = cell.getWidth();
114
- if (width === 2) {
115
- lineOffset++;
116
- }
117
- const char = cell.getChars();
118
- if (char.length > 1) {
119
- lineOffset -= char.length - 1;
120
- }
121
- }
122
- startOffset += lineOffset;
123
- }
124
-
125
- // Shift end range right for each wide character inside the link
126
- let endOffset = 0;
127
- const endWrappedLineCount = Math.ceil(range.endColumn / bufferWidth);
128
- for (let y = Math.max(0, startWrappedLineCount - 1); y < endWrappedLineCount; y++) {
129
- const start = (y === startWrappedLineCount - 1 ? (range.startColumn + startOffset) % bufferWidth : 0);
130
- const lineLength = Math.min(bufferWidth, range.endColumn + startOffset - y * bufferWidth);
131
- const startLineOffset = (y === startWrappedLineCount - 1 ? startOffset : 0);
132
- let lineOffset = 0;
133
- const line = lines[y];
134
- // Sanity check for line, apparently this can happen but it's not clear under what
135
- // circumstances this happens. Continue on, skipping the remainder of start offset if this
136
- // happens to minimize impact.
137
- if (!line) {
138
- break;
139
- }
140
- for (let x = start; x < Math.min(bufferWidth, lineLength + lineOffset + startLineOffset); x++) {
141
- const cell = line.getCell(x)!;
142
- const width = cell.getWidth();
143
- // Offset for 0 cells following wide characters
144
- if (width === 2) {
145
- lineOffset++;
146
- }
147
- // Offset for early wrapping when the last cell in row is a wide character
148
- if (x === bufferWidth - 1 && cell.getChars() === '') {
149
- lineOffset++;
150
- }
151
- }
152
- endOffset += lineOffset;
153
- }
154
-
155
- // Apply the width character offsets to the result
156
- bufferRange.start.x += startOffset;
157
- bufferRange.end.x += startOffset + endOffset;
158
-
159
- // Convert back to wrapped lines
160
- while (bufferRange.start.x > bufferWidth) {
161
- bufferRange.start.x -= bufferWidth;
162
- bufferRange.start.y++;
163
- }
164
- while (bufferRange.end.x > bufferWidth) {
165
- bufferRange.end.x -= bufferWidth;
166
- bufferRange.end.y++;
167
- }
168
-
169
- return bufferRange;
170
- }
171
-
172
- function getXtermLineContent(buffer: IBuffer, lineStart: number, lineEnd: number, cols: number): string {
173
- // Cap the maximum number of lines generated to prevent potential performance problems. This is
174
- // more of a sanity check as the wrapped line should already be trimmed down at this point.
175
- const maxLineLength = Math.max(2048 / cols * 2);
176
- lineEnd = Math.min(lineEnd, lineStart + maxLineLength);
177
- let content = '';
178
- for (let i = lineStart; i <= lineEnd; i++) {
179
- // Make sure only 0 to cols are considered as resizing when windows mode is enabled will
180
- // retain buffer data outside of the terminal width as reflow is disabled.
181
- const line = buffer.getLine(i);
182
- if (line) {
183
- content += line.translateToString(true, 0, cols);
184
- }
185
- }
186
- return content;
187
- }
1
+ // *****************************************************************************
2
+ // Copyright (C) 2022 STMicroelectronics and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+
17
+ import type { IBufferRange, IBufferLine, IBuffer, Terminal } from 'xterm';
18
+
19
+ export const LinkContext = Symbol('LinkContext');
20
+ export interface LinkContext {
21
+ text: string;
22
+ startLine: number;
23
+ lines: IBufferLine[];
24
+ }
25
+
26
+ /**
27
+ * Mimics VS Code IRange
28
+ */
29
+ interface TerminalRange {
30
+ readonly startLineNumber: number;
31
+ readonly startColumn: number;
32
+ readonly endLineNumber: number;
33
+ readonly endColumn: number;
34
+ }
35
+
36
+ /*---------------------------------------------------------------------------------------------
37
+ * Copyright (c) Microsoft Corporation and others. All rights reserved.
38
+ * Licensed under the MIT License.
39
+ *--------------------------------------------------------------------------------------------*/
40
+ export function getLinkContext(terminal: Terminal, line: number, maxLinkLength = 2000): LinkContext {
41
+ // The following method is based on VS Code's TerminalLinkDetectorAdapter._provideLinks()
42
+ // https://github.com/microsoft/vscode/blob/7888ff3a6b104e9e2e3d0f7890ca92dd0828215f/src/vs/workbench/contrib/terminal/browser/links/terminalLinkDetectorAdapter.ts#L51
43
+ let startLine = line - 1;
44
+ let endLine = startLine;
45
+
46
+ const lines: IBufferLine[] = [terminal.buffer.active.getLine(startLine)!];
47
+
48
+ // Cap the maximum context on either side of the line being provided, by taking the context
49
+ // around the line being provided for this ensures the line the pointer is on will have
50
+ // links provided.
51
+ const maxLineContext = Math.max(maxLinkLength / terminal.cols);
52
+ const minStartLine = Math.max(startLine - maxLineContext, 0);
53
+ const maxEndLine = Math.min(endLine + maxLineContext, terminal.buffer.active.length);
54
+
55
+ while (startLine >= minStartLine && terminal.buffer.active.getLine(startLine)?.isWrapped) {
56
+ lines.unshift(terminal.buffer.active.getLine(startLine - 1)!);
57
+ startLine--;
58
+ }
59
+
60
+ while (endLine < maxEndLine && terminal.buffer.active.getLine(endLine + 1)?.isWrapped) {
61
+ lines.push(terminal.buffer.active.getLine(endLine + 1)!);
62
+ endLine++;
63
+ }
64
+
65
+ const text = getXtermLineContent(terminal.buffer.active, startLine, endLine, terminal.cols);
66
+
67
+ return { text, startLine, lines };
68
+ }
69
+
70
+ // The following code is taken as is from
71
+ // https://github.com/microsoft/vscode/blob/7888ff3a6b104e9e2e3d0f7890ca92dd0828215f/src/vs/workbench/contrib/terminal/browser/links/terminalLinkHelpers.ts#L1
72
+
73
+ /**
74
+ * Converts a possibly wrapped link's range (comprised of string indices) into a buffer range that plays nicely with xterm.js
75
+ *
76
+ * @param lines A single line (not the entire buffer)
77
+ * @param bufferWidth The number of columns in the terminal
78
+ * @param range The link range - string indices
79
+ * @param startLine The absolute y position (on the buffer) of the line
80
+ */
81
+ export function convertLinkRangeToBuffer(
82
+ lines: IBufferLine[],
83
+ bufferWidth: number,
84
+ range: TerminalRange,
85
+ startLine: number
86
+ ): IBufferRange {
87
+ const bufferRange: IBufferRange = {
88
+ start: {
89
+ x: range.startColumn,
90
+ y: range.startLineNumber + startLine
91
+ },
92
+ end: {
93
+ x: range.endColumn - 1,
94
+ y: range.endLineNumber + startLine
95
+ }
96
+ };
97
+
98
+ // Shift start range right for each wide character before the link
99
+ let startOffset = 0;
100
+ const startWrappedLineCount = Math.ceil(range.startColumn / bufferWidth);
101
+ for (let y = 0; y < Math.min(startWrappedLineCount); y++) {
102
+ const lineLength = Math.min(bufferWidth, range.startColumn - y * bufferWidth);
103
+ let lineOffset = 0;
104
+ const line = lines[y];
105
+ // Sanity check for line, apparently this can happen but it's not clear under what
106
+ // circumstances this happens. Continue on, skipping the remainder of start offset if this
107
+ // happens to minimize impact.
108
+ if (!line) {
109
+ break;
110
+ }
111
+ for (let x = 0; x < Math.min(bufferWidth, lineLength + lineOffset); x++) {
112
+ const cell = line.getCell(x)!;
113
+ const width = cell.getWidth();
114
+ if (width === 2) {
115
+ lineOffset++;
116
+ }
117
+ const char = cell.getChars();
118
+ if (char.length > 1) {
119
+ lineOffset -= char.length - 1;
120
+ }
121
+ }
122
+ startOffset += lineOffset;
123
+ }
124
+
125
+ // Shift end range right for each wide character inside the link
126
+ let endOffset = 0;
127
+ const endWrappedLineCount = Math.ceil(range.endColumn / bufferWidth);
128
+ for (let y = Math.max(0, startWrappedLineCount - 1); y < endWrappedLineCount; y++) {
129
+ const start = (y === startWrappedLineCount - 1 ? (range.startColumn + startOffset) % bufferWidth : 0);
130
+ const lineLength = Math.min(bufferWidth, range.endColumn + startOffset - y * bufferWidth);
131
+ const startLineOffset = (y === startWrappedLineCount - 1 ? startOffset : 0);
132
+ let lineOffset = 0;
133
+ const line = lines[y];
134
+ // Sanity check for line, apparently this can happen but it's not clear under what
135
+ // circumstances this happens. Continue on, skipping the remainder of start offset if this
136
+ // happens to minimize impact.
137
+ if (!line) {
138
+ break;
139
+ }
140
+ for (let x = start; x < Math.min(bufferWidth, lineLength + lineOffset + startLineOffset); x++) {
141
+ const cell = line.getCell(x)!;
142
+ const width = cell.getWidth();
143
+ // Offset for 0 cells following wide characters
144
+ if (width === 2) {
145
+ lineOffset++;
146
+ }
147
+ // Offset for early wrapping when the last cell in row is a wide character
148
+ if (x === bufferWidth - 1 && cell.getChars() === '') {
149
+ lineOffset++;
150
+ }
151
+ }
152
+ endOffset += lineOffset;
153
+ }
154
+
155
+ // Apply the width character offsets to the result
156
+ bufferRange.start.x += startOffset;
157
+ bufferRange.end.x += startOffset + endOffset;
158
+
159
+ // Convert back to wrapped lines
160
+ while (bufferRange.start.x > bufferWidth) {
161
+ bufferRange.start.x -= bufferWidth;
162
+ bufferRange.start.y++;
163
+ }
164
+ while (bufferRange.end.x > bufferWidth) {
165
+ bufferRange.end.x -= bufferWidth;
166
+ bufferRange.end.y++;
167
+ }
168
+
169
+ return bufferRange;
170
+ }
171
+
172
+ function getXtermLineContent(buffer: IBuffer, lineStart: number, lineEnd: number, cols: number): string {
173
+ // Cap the maximum number of lines generated to prevent potential performance problems. This is
174
+ // more of a sanity check as the wrapped line should already be trimmed down at this point.
175
+ const maxLineLength = Math.max(2048 / cols * 2);
176
+ lineEnd = Math.min(lineEnd, lineStart + maxLineLength);
177
+ let content = '';
178
+ for (let i = lineStart; i <= lineEnd; i++) {
179
+ // Make sure only 0 to cols are considered as resizing when windows mode is enabled will
180
+ // retain buffer data outside of the terminal width as reflow is disabled.
181
+ const line = buffer.getLine(i);
182
+ if (line) {
183
+ content += line.translateToString(true, 0, cols);
184
+ }
185
+ }
186
+ return content;
187
+ }