@codingame/monaco-vscode-views-service-override 1.85.0 → 1.85.2
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/assets/index-no-csp.html +4 -0
- package/assets/index.html +5 -1
- package/index.d.ts +2 -2
- package/index.js +2 -2
- package/package.json +11 -9
- package/tools/editor.js +1 -1
- package/views.d.ts +9 -4
- package/views.js +32 -10
- package/vscode/src/vs/workbench/api/browser/viewsExtensionPoint.js +2 -2
- package/vscode/src/vs/workbench/contrib/customEditor/browser/customEditorInputFactory.js +1 -1
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/commands.js +692 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/commands/devCommands.js +240 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditor.contribution.js +77 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/mergeEditorSerializer.js +42 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/colors.js +71 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/conflictActions.js +346 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editorGutter.js +96 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/baseCodeEditorView.js +145 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/codeEditorView.js +103 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/inputCodeEditorView.js +399 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView.js +196 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/fixedZoneWidget.js +41 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/lineAlignment.js +128 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/media/mergeEditor.css.js +6 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/mergeEditor.js +611 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/scrollSynchronizer.js +158 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewModel.js +262 -0
- package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/viewZones.js +173 -0
- package/vscode/src/vs/workbench/contrib/webview/browser/webview.contribution.js +79 -0
- package/vscode/src/vs/workbench/contrib/webview/browser/webviewFindWidget.js +1 -1
- package/vscode/src/vs/workbench/services/history/browser/historyService.js +3 -0
- package/override/vs/workbench/contrib/notebook/common/notebookEditorInput.js +0 -3
- package/vscode/src/vs/base/browser/ui/tree/treeDefaults.js +0 -16
- package/vscode/src/vs/workbench/browser/parts/views/checkbox.js +0 -107
- package/vscode/src/vs/workbench/browser/parts/views/media/views.css.js +0 -6
- package/vscode/src/vs/workbench/browser/parts/views/treeView.js +0 -1604
- package/vscode/src/vs/workbench/contrib/codeEditor/browser/find/simpleFindWidget.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/codeEditor/browser/find/simpleFindWidget.js +0 -390
- package/vscode/src/vs/workbench/contrib/languageDetection/browser/languageDetection.contribution.js +0 -157
- package/vscode/src/vs/workbench/contrib/notebook/common/notebookContextKeys.js +0 -5
- package/vscode/src/vs/workbench/contrib/remote/browser/media/tunnelView.css.js +0 -6
- package/vscode/src/vs/workbench/contrib/remote/browser/remoteExplorer.js +0 -217
- package/vscode/src/vs/workbench/contrib/remote/browser/remoteIcons.js +0 -91
- package/vscode/src/vs/workbench/contrib/remote/browser/tunnelView.js +0 -1837
package/vscode/src/vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView.js
ADDED
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
import { __decorate, __param } from '../../../../../../../../../external/tslib/tslib.es6.js';
|
|
2
|
+
import { reset } from 'monaco-editor/esm/vs/base/browser/dom.js';
|
|
3
|
+
import { ActionBar } from 'monaco-editor/esm/vs/base/browser/ui/actionbar/actionbar.js';
|
|
4
|
+
import { renderLabelWithIcons } from 'monaco-editor/esm/vs/base/browser/ui/iconLabel/iconLabels.js';
|
|
5
|
+
import { CompareResult } from 'monaco-editor/esm/vs/base/common/arrays.js';
|
|
6
|
+
import { BugIndicatingError } from 'monaco-editor/esm/vs/base/common/errors.js';
|
|
7
|
+
import { toDisposable } from 'monaco-editor/esm/vs/base/common/lifecycle.js';
|
|
8
|
+
import { derived, autorunWithStore, autorun } from 'monaco-editor/esm/vs/base/common/observable.js';
|
|
9
|
+
import { MinimapPosition, OverviewRulerLane } from 'monaco-editor/esm/vs/editor/common/model.js';
|
|
10
|
+
import { localizeWithPath } from 'monaco-editor/esm/vs/nls.js';
|
|
11
|
+
import { MenuId } from 'monaco-editor/esm/vs/platform/actions/common/actions.js';
|
|
12
|
+
import { IConfigurationService } from 'monaco-editor/esm/vs/platform/configuration/common/configuration.js';
|
|
13
|
+
import { IContextKeyService } from 'monaco-editor/esm/vs/platform/contextkey/common/contextkey.js';
|
|
14
|
+
import { IInstantiationService } from 'monaco-editor/esm/vs/platform/instantiation/common/instantiation.js';
|
|
15
|
+
import { ILabelService } from 'monaco-editor/esm/vs/platform/label/common/label.js';
|
|
16
|
+
import { LineRange } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/lineRange';
|
|
17
|
+
import { join, applyObservableDecorations } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/utils';
|
|
18
|
+
import { handledConflictMinimapOverViewRulerColor, unhandledConflictMinimapOverViewRulerColor } from '../colors.js';
|
|
19
|
+
import { EditorGutter } from '../editorGutter.js';
|
|
20
|
+
import { ctxIsMergeResultEditor } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/common/mergeEditor';
|
|
21
|
+
import { CodeEditorView, createSelectionsAutorun, TitleMenu } from './codeEditorView.js';
|
|
22
|
+
|
|
23
|
+
let ResultCodeEditorView = class ResultCodeEditorView extends CodeEditorView {
|
|
24
|
+
constructor(viewModel, instantiationService, _labelService, configurationService) {
|
|
25
|
+
super(instantiationService, viewModel, configurationService);
|
|
26
|
+
this._labelService = _labelService;
|
|
27
|
+
this.decorations = derived(this, reader => {
|
|
28
|
+
const viewModel = this.viewModel.read(reader);
|
|
29
|
+
if (!viewModel) {
|
|
30
|
+
return [];
|
|
31
|
+
}
|
|
32
|
+
const model = viewModel.model;
|
|
33
|
+
const textModel = model.resultTextModel;
|
|
34
|
+
const result = ( new Array());
|
|
35
|
+
const baseRangeWithStoreAndTouchingDiffs = join(model.modifiedBaseRanges.read(reader), model.baseResultDiffs.read(reader), (baseRange, diff) => baseRange.baseRange.touches(diff.inputRange)
|
|
36
|
+
? CompareResult.neitherLessOrGreaterThan
|
|
37
|
+
: LineRange.compareByStart(baseRange.baseRange, diff.inputRange));
|
|
38
|
+
const activeModifiedBaseRange = viewModel.activeModifiedBaseRange.read(reader);
|
|
39
|
+
const showNonConflictingChanges = viewModel.showNonConflictingChanges.read(reader);
|
|
40
|
+
for (const m of baseRangeWithStoreAndTouchingDiffs) {
|
|
41
|
+
const modifiedBaseRange = m.left;
|
|
42
|
+
if (modifiedBaseRange) {
|
|
43
|
+
const blockClassNames = ['merge-editor-block'];
|
|
44
|
+
let blockPadding = [0, 0, 0, 0];
|
|
45
|
+
const isHandled = model.isHandled(modifiedBaseRange).read(reader);
|
|
46
|
+
if (isHandled) {
|
|
47
|
+
blockClassNames.push('handled');
|
|
48
|
+
}
|
|
49
|
+
if (modifiedBaseRange === activeModifiedBaseRange) {
|
|
50
|
+
blockClassNames.push('focused');
|
|
51
|
+
blockPadding = [0, 2, 0, 2];
|
|
52
|
+
}
|
|
53
|
+
if (modifiedBaseRange.isConflicting) {
|
|
54
|
+
blockClassNames.push('conflicting');
|
|
55
|
+
}
|
|
56
|
+
blockClassNames.push('result');
|
|
57
|
+
if (!modifiedBaseRange.isConflicting && !showNonConflictingChanges && isHandled) {
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
const range = model.getLineRangeInResult(modifiedBaseRange.baseRange, reader);
|
|
61
|
+
result.push({
|
|
62
|
+
range: range.toInclusiveRangeOrEmpty(),
|
|
63
|
+
options: {
|
|
64
|
+
showIfCollapsed: true,
|
|
65
|
+
blockClassName: blockClassNames.join(' '),
|
|
66
|
+
blockPadding,
|
|
67
|
+
blockIsAfterEnd: range.startLineNumber > textModel.getLineCount(),
|
|
68
|
+
description: 'Result Diff',
|
|
69
|
+
minimap: {
|
|
70
|
+
position: MinimapPosition.Gutter,
|
|
71
|
+
color: { id: isHandled ? handledConflictMinimapOverViewRulerColor : unhandledConflictMinimapOverViewRulerColor },
|
|
72
|
+
},
|
|
73
|
+
overviewRuler: modifiedBaseRange.isConflicting ? {
|
|
74
|
+
position: OverviewRulerLane.Center,
|
|
75
|
+
color: { id: isHandled ? handledConflictMinimapOverViewRulerColor : unhandledConflictMinimapOverViewRulerColor },
|
|
76
|
+
} : undefined
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
if (!modifiedBaseRange || modifiedBaseRange.isConflicting) {
|
|
81
|
+
for (const diff of m.rights) {
|
|
82
|
+
const range = diff.outputRange.toInclusiveRange();
|
|
83
|
+
if (range) {
|
|
84
|
+
result.push({
|
|
85
|
+
range,
|
|
86
|
+
options: {
|
|
87
|
+
className: `merge-editor-diff result`,
|
|
88
|
+
description: 'Merge Editor',
|
|
89
|
+
isWholeLine: true,
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
if (diff.rangeMappings) {
|
|
94
|
+
for (const d of diff.rangeMappings) {
|
|
95
|
+
result.push({
|
|
96
|
+
range: d.outputRange,
|
|
97
|
+
options: {
|
|
98
|
+
className: `merge-editor-diff-word result`,
|
|
99
|
+
description: 'Merge Editor'
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
return result;
|
|
108
|
+
});
|
|
109
|
+
this.editor.invokeWithinContext(accessor => {
|
|
110
|
+
const contextKeyService = accessor.get(IContextKeyService);
|
|
111
|
+
const isMergeResultEditor = ctxIsMergeResultEditor.bindTo(contextKeyService);
|
|
112
|
+
isMergeResultEditor.set(true);
|
|
113
|
+
this._register(toDisposable(() => isMergeResultEditor.reset()));
|
|
114
|
+
});
|
|
115
|
+
this.htmlElements.gutterDiv.style.width = '5px';
|
|
116
|
+
this.htmlElements.root.classList.add(`result`);
|
|
117
|
+
this._register(autorunWithStore((reader, store) => {
|
|
118
|
+
if (this.checkboxesVisible.read(reader)) {
|
|
119
|
+
store.add(( new EditorGutter(this.editor, this.htmlElements.gutterDiv, {
|
|
120
|
+
getIntersectingGutterItems: (range, reader) => [],
|
|
121
|
+
createView: (item, target) => { throw new BugIndicatingError(); },
|
|
122
|
+
})));
|
|
123
|
+
}
|
|
124
|
+
}));
|
|
125
|
+
this._register(autorun(reader => {
|
|
126
|
+
const vm = this.viewModel.read(reader);
|
|
127
|
+
if (!vm) {
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
this.editor.setModel(vm.model.resultTextModel);
|
|
131
|
+
reset(this.htmlElements.title, ...renderLabelWithIcons(( localizeWithPath(
|
|
132
|
+
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
133
|
+
'result',
|
|
134
|
+
'Result'
|
|
135
|
+
))));
|
|
136
|
+
reset(this.htmlElements.description, ...renderLabelWithIcons(this._labelService.getUriLabel(vm.model.resultTextModel.uri, { relative: true })));
|
|
137
|
+
}));
|
|
138
|
+
const remainingConflictsActionBar = this._register(( new ActionBar(this.htmlElements.detail)));
|
|
139
|
+
this._register(autorun(reader => {
|
|
140
|
+
const vm = this.viewModel.read(reader);
|
|
141
|
+
if (!vm) {
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
const model = vm.model;
|
|
145
|
+
if (!model) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
const count = model.unhandledConflictsCount.read(reader);
|
|
149
|
+
const text = count === 1
|
|
150
|
+
? ( localizeWithPath(
|
|
151
|
+
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
152
|
+
'mergeEditor.remainingConflicts',
|
|
153
|
+
'{0} Conflict Remaining',
|
|
154
|
+
count
|
|
155
|
+
))
|
|
156
|
+
: ( localizeWithPath(
|
|
157
|
+
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
158
|
+
'mergeEditor.remainingConflict',
|
|
159
|
+
'{0} Conflicts Remaining ',
|
|
160
|
+
count
|
|
161
|
+
));
|
|
162
|
+
remainingConflictsActionBar.clear();
|
|
163
|
+
remainingConflictsActionBar.push({
|
|
164
|
+
class: undefined,
|
|
165
|
+
enabled: count > 0,
|
|
166
|
+
id: 'nextConflict',
|
|
167
|
+
label: text,
|
|
168
|
+
run() {
|
|
169
|
+
vm.model.telemetry.reportConflictCounterClicked();
|
|
170
|
+
vm.goToNextModifiedBaseRange(m => !model.isHandled(m).get());
|
|
171
|
+
},
|
|
172
|
+
tooltip: count > 0
|
|
173
|
+
? ( localizeWithPath(
|
|
174
|
+
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
175
|
+
'goToNextConflict',
|
|
176
|
+
'Go to next conflict'
|
|
177
|
+
))
|
|
178
|
+
: ( localizeWithPath(
|
|
179
|
+
'vs/workbench/contrib/mergeEditor/browser/view/editors/resultCodeEditorView',
|
|
180
|
+
'allConflictHandled',
|
|
181
|
+
'All conflicts handled, the merge can be completed now.'
|
|
182
|
+
)),
|
|
183
|
+
});
|
|
184
|
+
}));
|
|
185
|
+
this._register(applyObservableDecorations(this.editor, this.decorations));
|
|
186
|
+
this._register(createSelectionsAutorun(this, (baseRange, viewModel) => viewModel.model.translateBaseRangeToResult(baseRange)));
|
|
187
|
+
this._register(instantiationService.createInstance(TitleMenu, MenuId.MergeInputResultToolbar, this.htmlElements.toolbar));
|
|
188
|
+
}
|
|
189
|
+
};
|
|
190
|
+
ResultCodeEditorView = ( __decorate([
|
|
191
|
+
( __param(1, IInstantiationService)),
|
|
192
|
+
( __param(2, ILabelService)),
|
|
193
|
+
( __param(3, IConfigurationService))
|
|
194
|
+
], ResultCodeEditorView));
|
|
195
|
+
|
|
196
|
+
export { ResultCodeEditorView };
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { h } from 'monaco-editor/esm/vs/base/browser/dom.js';
|
|
2
|
+
import { Disposable } from 'monaco-editor/esm/vs/base/common/lifecycle.js';
|
|
3
|
+
import { Event } from 'monaco-editor/esm/vs/base/common/event.js';
|
|
4
|
+
|
|
5
|
+
class FixedZoneWidget extends Disposable {
|
|
6
|
+
static { this.counter = 0; }
|
|
7
|
+
constructor(editor, viewZoneAccessor, afterLineNumber, height, viewZoneIdsToCleanUp) {
|
|
8
|
+
super();
|
|
9
|
+
this.editor = editor;
|
|
10
|
+
this.overlayWidgetId = `fixedZoneWidget-${FixedZoneWidget.counter++}`;
|
|
11
|
+
this.widgetDomNode = h('div.fixed-zone-widget').root;
|
|
12
|
+
this.overlayWidget = {
|
|
13
|
+
getId: () => this.overlayWidgetId,
|
|
14
|
+
getDomNode: () => this.widgetDomNode,
|
|
15
|
+
getPosition: () => null
|
|
16
|
+
};
|
|
17
|
+
this.viewZoneId = viewZoneAccessor.addZone({
|
|
18
|
+
domNode: document.createElement('div'),
|
|
19
|
+
afterLineNumber: afterLineNumber,
|
|
20
|
+
heightInPx: height,
|
|
21
|
+
onComputedHeight: (height) => {
|
|
22
|
+
this.widgetDomNode.style.height = `${height}px`;
|
|
23
|
+
},
|
|
24
|
+
onDomNodeTop: (top) => {
|
|
25
|
+
this.widgetDomNode.style.top = `${top}px`;
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
viewZoneIdsToCleanUp.push(this.viewZoneId);
|
|
29
|
+
this._register(Event.runAndSubscribe(this.editor.onDidLayoutChange, () => {
|
|
30
|
+
this.widgetDomNode.style.left = this.editor.getLayoutInfo().contentLeft + 'px';
|
|
31
|
+
}));
|
|
32
|
+
this.editor.addOverlayWidget(this.overlayWidget);
|
|
33
|
+
this._register({
|
|
34
|
+
dispose: () => {
|
|
35
|
+
this.editor.removeOverlayWidget(this.overlayWidget);
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export { FixedZoneWidget };
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { compareBy } from 'monaco-editor/esm/vs/base/common/arrays.js';
|
|
2
|
+
import { assertFn, checkAdjacentItems } from 'monaco-editor/esm/vs/base/common/assert.js';
|
|
3
|
+
import { isDefined } from 'monaco-editor/esm/vs/base/common/types.js';
|
|
4
|
+
import { Position } from 'monaco-editor/esm/vs/editor/common/core/position.js';
|
|
5
|
+
import { Range } from 'monaco-editor/esm/vs/editor/common/core/range.js';
|
|
6
|
+
import { LengthObj } from 'monaco-editor/esm/vs/editor/common/model/bracketPairsTextModelPart/bracketPairsTree/length.js';
|
|
7
|
+
import { RangeMapping } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/mapping';
|
|
8
|
+
import { lengthOfRange, lengthBetweenPositions, addLength } from 'vscode/vscode/vs/workbench/contrib/mergeEditor/browser/model/rangeUtils';
|
|
9
|
+
|
|
10
|
+
function getAlignments(m) {
|
|
11
|
+
const equalRanges1 = toEqualRangeMappings(m.input1Diffs.flatMap(d => d.rangeMappings), m.baseRange.toRange(), m.input1Range.toRange());
|
|
12
|
+
const equalRanges2 = toEqualRangeMappings(m.input2Diffs.flatMap(d => d.rangeMappings), m.baseRange.toRange(), m.input2Range.toRange());
|
|
13
|
+
const commonRanges = splitUpCommonEqualRangeMappings(equalRanges1, equalRanges2);
|
|
14
|
+
let result = [];
|
|
15
|
+
result.push([m.input1Range.startLineNumber - 1, m.baseRange.startLineNumber - 1, m.input2Range.startLineNumber - 1]);
|
|
16
|
+
function isFullSync(lineAlignment) {
|
|
17
|
+
return lineAlignment.every((i) => i !== undefined);
|
|
18
|
+
}
|
|
19
|
+
for (const m of commonRanges) {
|
|
20
|
+
const lineAlignment = [m.output1Pos?.lineNumber, m.inputPos.lineNumber, m.output2Pos?.lineNumber];
|
|
21
|
+
const alignmentIsFullSync = isFullSync(lineAlignment);
|
|
22
|
+
let shouldAdd = true;
|
|
23
|
+
if (alignmentIsFullSync) {
|
|
24
|
+
const isNewFullSyncAlignment = !( result.some(r => isFullSync(r) && ( r.some((v, idx) => v !== undefined && v === lineAlignment[idx]))));
|
|
25
|
+
if (isNewFullSyncAlignment) {
|
|
26
|
+
result = result.filter(r => !( r.some((v, idx) => v !== undefined && v === lineAlignment[idx])));
|
|
27
|
+
}
|
|
28
|
+
shouldAdd = isNewFullSyncAlignment;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
const isNew = !( result.some(r => ( r.some((v, idx) => v !== undefined && v === lineAlignment[idx]))));
|
|
32
|
+
shouldAdd = isNew;
|
|
33
|
+
}
|
|
34
|
+
if (shouldAdd) {
|
|
35
|
+
result.push(lineAlignment);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
if (m.length.isGreaterThan(( new LengthObj(1, 0)))) {
|
|
39
|
+
result.push([
|
|
40
|
+
m.output1Pos ? m.output1Pos.lineNumber + 1 : undefined,
|
|
41
|
+
m.inputPos.lineNumber + 1,
|
|
42
|
+
m.output2Pos ? m.output2Pos.lineNumber + 1 : undefined
|
|
43
|
+
]);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
const finalLineAlignment = [m.input1Range.endLineNumberExclusive, m.baseRange.endLineNumberExclusive, m.input2Range.endLineNumberExclusive];
|
|
48
|
+
result = result.filter(r => r.every((v, idx) => v !== finalLineAlignment[idx]));
|
|
49
|
+
result.push(finalLineAlignment);
|
|
50
|
+
assertFn(() => checkAdjacentItems(( result.map(r => r[0])).filter(isDefined), (a, b) => a < b)
|
|
51
|
+
&& checkAdjacentItems(( result.map(r => r[1])).filter(isDefined), (a, b) => a <= b)
|
|
52
|
+
&& checkAdjacentItems(( result.map(r => r[2])).filter(isDefined), (a, b) => a < b)
|
|
53
|
+
&& result.every(alignment => alignment.filter(isDefined).length >= 2));
|
|
54
|
+
return result;
|
|
55
|
+
}
|
|
56
|
+
function toEqualRangeMappings(diffs, inputRange, outputRange) {
|
|
57
|
+
const result = [];
|
|
58
|
+
let equalRangeInputStart = inputRange.getStartPosition();
|
|
59
|
+
let equalRangeOutputStart = outputRange.getStartPosition();
|
|
60
|
+
for (const d of diffs) {
|
|
61
|
+
const equalRangeMapping = ( new RangeMapping(
|
|
62
|
+
Range.fromPositions(equalRangeInputStart, d.inputRange.getStartPosition()),
|
|
63
|
+
Range.fromPositions(equalRangeOutputStart, d.outputRange.getStartPosition())
|
|
64
|
+
));
|
|
65
|
+
assertFn(() => lengthOfRange(equalRangeMapping.inputRange).equals(lengthOfRange(equalRangeMapping.outputRange)));
|
|
66
|
+
if (!equalRangeMapping.inputRange.isEmpty()) {
|
|
67
|
+
result.push(equalRangeMapping);
|
|
68
|
+
}
|
|
69
|
+
equalRangeInputStart = d.inputRange.getEndPosition();
|
|
70
|
+
equalRangeOutputStart = d.outputRange.getEndPosition();
|
|
71
|
+
}
|
|
72
|
+
const equalRangeMapping = ( new RangeMapping(
|
|
73
|
+
Range.fromPositions(equalRangeInputStart, inputRange.getEndPosition()),
|
|
74
|
+
Range.fromPositions(equalRangeOutputStart, outputRange.getEndPosition())
|
|
75
|
+
));
|
|
76
|
+
assertFn(() => lengthOfRange(equalRangeMapping.inputRange).equals(lengthOfRange(equalRangeMapping.outputRange)));
|
|
77
|
+
if (!equalRangeMapping.inputRange.isEmpty()) {
|
|
78
|
+
result.push(equalRangeMapping);
|
|
79
|
+
}
|
|
80
|
+
return result;
|
|
81
|
+
}
|
|
82
|
+
function splitUpCommonEqualRangeMappings(equalRangeMappings1, equalRangeMappings2) {
|
|
83
|
+
const result = [];
|
|
84
|
+
const events = [];
|
|
85
|
+
for (const [input, rangeMappings] of [[0, equalRangeMappings1], [1, equalRangeMappings2]]) {
|
|
86
|
+
for (const rangeMapping of rangeMappings) {
|
|
87
|
+
events.push({
|
|
88
|
+
input: input,
|
|
89
|
+
start: true,
|
|
90
|
+
inputPos: rangeMapping.inputRange.getStartPosition(),
|
|
91
|
+
outputPos: rangeMapping.outputRange.getStartPosition()
|
|
92
|
+
});
|
|
93
|
+
events.push({
|
|
94
|
+
input: input,
|
|
95
|
+
start: false,
|
|
96
|
+
inputPos: rangeMapping.inputRange.getEndPosition(),
|
|
97
|
+
outputPos: rangeMapping.outputRange.getEndPosition()
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
events.sort(compareBy((m) => m.inputPos, Position.compare));
|
|
102
|
+
const starts = [undefined, undefined];
|
|
103
|
+
let lastInputPos;
|
|
104
|
+
for (const event of events) {
|
|
105
|
+
if (lastInputPos && ( starts.some(s => !!s))) {
|
|
106
|
+
const length = lengthBetweenPositions(lastInputPos, event.inputPos);
|
|
107
|
+
if (!length.isZero()) {
|
|
108
|
+
result.push({
|
|
109
|
+
inputPos: lastInputPos,
|
|
110
|
+
length,
|
|
111
|
+
output1Pos: starts[0],
|
|
112
|
+
output2Pos: starts[1]
|
|
113
|
+
});
|
|
114
|
+
if (starts[0]) {
|
|
115
|
+
starts[0] = addLength(starts[0], length);
|
|
116
|
+
}
|
|
117
|
+
if (starts[1]) {
|
|
118
|
+
starts[1] = addLength(starts[1], length);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
starts[event.input] = event.start ? event.outputPos : undefined;
|
|
123
|
+
lastInputPos = event.inputPos;
|
|
124
|
+
}
|
|
125
|
+
return result;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
export { getAlignments };
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import n from '../../../../../../../../../external/rollup-plugin-styles/dist/runtime/inject-css.js';
|
|
2
|
+
|
|
3
|
+
var css = ".monaco-workbench .merge-editor .code-view>.header{align-content:center;display:flex;height:30px;overflow:hidden;padding:0 10px}.monaco-workbench .merge-editor .code-view>.header>span{align-self:center;overflow:hidden;padding-right:6px;text-overflow:ellipsis;white-space:nowrap}.monaco-workbench .merge-editor .code-view>.header>span.title{flex-shrink:0}.monaco-workbench .merge-editor .code-view>.header>span.description{align-items:center;color:var(--vscode-descriptionForeground);display:flex;flex-shrink:0;font-size:12px}.monaco-workbench .merge-editor .code-view.result>.header>.description{display:inline;flex-shrink:1}.monaco-workbench .merge-editor .code-view.result>.header>.detail,.monaco-workbench .merge-editor .code-view.result>.header>.toolbar{flex-shrink:0}.monaco-workbench .merge-editor .code-view>.header>span.description .codicon{color:var(--vscode-descriptionForeground);font-size:14px}.monaco-workbench .merge-editor .code-view>.header>span.detail{color:var(--vscode-descriptionForeground);font-size:12px;margin-left:auto}.monaco-workbench .merge-editor .code-view>.header>span.detail .codicon{font-size:13px}.monaco-workbench .merge-editor .code-view.input>.header>span.detail:before{content:\"•\";opacity:.5;padding-right:3px}.monaco-workbench .merge-editor .code-view.input>.header>span.detail{margin-left:0}.monaco-workbench .merge-editor .code-view.input>.header>span.toolbar{flex-shrink:0;margin-left:auto}.monaco-workbench .merge-editor .code-view>.container{display:flex;flex-direction:row}.monaco-workbench .merge-editor .code-view>.container>.gutter{flex-grow:0;flex-shrink:0;overflow:hidden;position:relative;width:24px}.monaco-workbench .merge-editor .merge-editor-diff{background-color:var(--vscode-mergeEditor-change-background)}.monaco-workbench .merge-editor .merge-editor-diff-word{background-color:var(--vscode-mergeEditor-change-word-background)}.monaco-workbench .merge-editor .merge-editor-block:not(.handled):not(.focused){border:1px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border)}.monaco-workbench .merge-editor .merge-editor-block:not(.handled).focused{border:2px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border)}.monaco-workbench .merge-editor .merge-editor-block.handled:not(.focused){border:1px solid var(--vscode-mergeEditor-conflict-handledUnfocused-border)}.monaco-workbench .merge-editor .merge-editor-block.handled.focused{border:1px solid var(--vscode-mergeEditor-conflict-handledFocused-border)}.merge-editor-block.use-simplified-decorations.input.i1,.monaco-workbench .merge-editor .merge-editor-simplified.input.i1{background-color:var(--vscode-mergeEditor-conflict-input1-background)}.merge-editor-block.use-simplified-decorations.input.i2,.monaco-workbench .merge-editor .merge-editor-simplified.input.i2{background-color:var(--vscode-mergeEditor-conflict-input2-background)}.gutter.monaco-editor>div{position:absolute}.merge-accept-gutter-marker{margin-left:4px;width:28px}.merge-accept-gutter-marker .background{height:100%;position:absolute;width:50%}.merge-accept-gutter-marker.multi-line.focused .background{border:2px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border);border-right:0}.merge-accept-gutter-marker.multi-line .background{border:2px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border);border-bottom-left-radius:3px;border-right:0;border-top-left-radius:3px}.merge-accept-gutter-marker.multi-line.handled.focused .background{border:2px solid var(--vscode-mergeEditor-conflict-handledFocused-border);border-right:0}.merge-accept-gutter-marker.multi-line.handled .background{border:2px solid var(--vscode-checkbox-border);border-right:0}.focused .accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border)}.accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border)}.handled.focused .accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-mergeEditor-conflict-handledFocused-border)}.handled .accept-conflict-group.monaco-custom-toggle{border:1px solid var(--vscode-checkbox-border)}.merge-accept-gutter-marker.multi-line .background{left:8px;width:10px}.merge-accept-gutter-marker .checkbox{position:absolute;width:100%}.accept-conflict-group.monaco-custom-toggle{background-color:var(--vscode-checkbox-border);background-size:16px!important;border-radius:3px;height:18px;margin-left:0;margin-right:0;opacity:1;padding:0;width:18px}.merge-accept-gutter-marker .checkbox-background{background:var(--vscode-editor-background);display:flex}.conflict-zone-root{align-content:center;align-items:center;background-color:var(--vscode-mergeEditor-change-background);border:1px solid var(--vscode-mergeEditor-conflict-unhandledUnfocused-border);display:flex;height:90%}.conflict-zone-root .dots{margin:0 10px}.conflict-zone-root pre{display:\"inline\";font-family:var(--monaco-monospace-font)}.conflict-zone-root .text{align-items:center;background:var(--vscode-mergeEditor-conflictingLines-background);display:flex;height:100%;margin-left:auto;overflow:hidden;padding:0 8px;white-space:nowrap}.focused.conflict-zone .conflict-zone-root{border:1px solid var(--vscode-mergeEditor-conflict-unhandledFocused-border)}.merge-editor-conflict-actions{color:var(--vscode-editorCodeLens-foreground);display:inline-block;margin:0 3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.merge-editor-conflict-actions>a,.merge-editor-conflict-actions>span{user-select:none;-webkit-user-select:none;white-space:nowrap}.merge-editor-conflict-actions>a{text-decoration:none}.merge-editor-conflict-actions>a:hover{cursor:pointer}.merge-editor-conflict-actions>a:hover,.merge-editor-conflict-actions>a:hover .codicon{color:var(--vscode-editorLink-activeForeground)!important}.merge-editor-conflict-actions .codicon{color:currentColor!important;color:var(--vscode-editorCodeLens-foreground);vertical-align:middle}.merge-editor-conflict-actions>a:hover .codicon:before{cursor:pointer}.fixed-zone-widget{width:100%}.merge-editor-diff-empty-word.base{border-left:3px solid var(--vscode-mergeEditor-changeBase-word-background);margin-left:3px}.merge-editor-diff-empty-word.input{border-left:3px solid var(--vscode-mergeEditor-change-word-background);margin-left:3px}.merge-editor-diff-word.base{background-color:var(--vscode-mergeEditor-changeBase-word-background)}.merge-editor-diff.base{background-color:var(--vscode-mergeEditor-changeBase-background)}";
|
|
4
|
+
n(css,{});
|
|
5
|
+
|
|
6
|
+
export { css, css as default };
|