extHostTypeConverters.ts 23.2 KB
Newer Older
E
Erich Gamma 已提交
1 2 3 4 5 6
/*---------------------------------------------------------------------------------------------
 *  Copyright (c) Microsoft Corporation. All rights reserved.
 *  Licensed under the MIT License. See License.txt in the project root for license information.
 *--------------------------------------------------------------------------------------------*/
'use strict';

7
import * as modes from 'vs/editor/common/modes';
8
import * as types from './extHostTypes';
9
import { Position as EditorPosition, ITextEditorOptions } from 'vs/platform/editor/common/editor';
10
import { IDecorationOptions } from 'vs/editor/common/editorCommon';
A
Alex Dima 已提交
11
import { EndOfLineSequence } from 'vs/editor/common/model';
J
Johannes Rieken 已提交
12
import * as vscode from 'vscode';
13
import URI from 'vs/base/common/uri';
J
Johannes Rieken 已提交
14
import { ProgressLocation as MainProgressLocation } from 'vs/platform/progress/common/progress';
15
import { SaveReason } from 'vs/workbench/services/textfile/common/textfiles';
16 17 18
import { IPosition } from 'vs/editor/common/core/position';
import { IRange } from 'vs/editor/common/core/range';
import { ISelection } from 'vs/editor/common/core/selection';
19
import * as htmlContent from 'vs/base/common/htmlContent';
20
import { IRelativePattern } from 'vs/base/common/glob';
21
import { LanguageSelector, LanguageFilter } from 'vs/editor/common/modes/languageSelector';
22
import { WorkspaceEditDto, ResourceTextEditDto } from 'vs/workbench/api/node/extHost.protocol';
23
import { MarkerSeverity, IRelatedInformation, IMarkerData } from 'vs/platform/markers/common/markers';
E
Erich Gamma 已提交
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39

export interface PositionLike {
	line: number;
	character: number;
}

export interface RangeLike {
	start: PositionLike;
	end: PositionLike;
}

export interface SelectionLike extends RangeLike {
	anchor: PositionLike;
	active: PositionLike;
}

40
export function toSelection(selection: ISelection): types.Selection {
41
	let { selectionStartLineNumber, selectionStartColumn, positionLineNumber, positionColumn } = selection;
42 43 44
	let start = new types.Position(selectionStartLineNumber - 1, selectionStartColumn - 1);
	let end = new types.Position(positionLineNumber - 1, positionColumn - 1);
	return new types.Selection(start, end);
E
Erich Gamma 已提交
45 46 47
}

export function fromSelection(selection: SelectionLike): ISelection {
48
	let { anchor, active } = selection;
E
Erich Gamma 已提交
49 50 51 52 53 54 55 56 57
	return {
		selectionStartLineNumber: anchor.line + 1,
		selectionStartColumn: anchor.character + 1,
		positionLineNumber: active.line + 1,
		positionColumn: active.character + 1
	};
}

export function fromRange(range: RangeLike): IRange {
J
Johannes Rieken 已提交
58 59 60
	if (!range) {
		return undefined;
	}
61
	let { start, end } = range;
E
Erich Gamma 已提交
62 63 64 65 66 67 68 69
	return {
		startLineNumber: start.line + 1,
		startColumn: start.character + 1,
		endLineNumber: end.line + 1,
		endColumn: end.character + 1
	};
}

70
export function toRange(range: IRange): types.Range {
J
Johannes Rieken 已提交
71 72 73
	if (!range) {
		return undefined;
	}
74
	let { startLineNumber, startColumn, endLineNumber, endColumn } = range;
75
	return new types.Range(startLineNumber - 1, startColumn - 1, endLineNumber - 1, endColumn - 1);
E
Erich Gamma 已提交
76 77
}

78 79
export function toPosition(position: IPosition): types.Position {
	return new types.Position(position.lineNumber - 1, position.column - 1);
E
Erich Gamma 已提交
80 81
}

82 83
export function fromPosition(position: types.Position): IPosition {
	return { lineNumber: position.line + 1, column: position.character + 1 };
84 85
}

86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
export function fromDiagnostic(value: vscode.Diagnostic): IMarkerData {
	return {
		...fromRange(value.range),
		message: value.message,
		source: value.source,
		code: String(value.code),
		severity: fromDiagnosticSeverity(value.severity),
		relatedInformation: value.relatedInformation && value.relatedInformation.map(fromDiagnosticRelatedInformation)
	};
}

export function fromDiagnosticRelatedInformation(value: types.DiagnosticRelatedInformation): IRelatedInformation {
	return {
		...fromRange(value.location.range),
		message: value.message,
		resource: value.location.uri
	};
}

export function toDiagnosticRelatedInformation(value: IRelatedInformation): types.DiagnosticRelatedInformation {
	return new types.DiagnosticRelatedInformation(new types.Location(value.resource, toRange(value)), value.message);
}

J
Johannes Rieken 已提交
109
export function fromDiagnosticSeverity(value: number): MarkerSeverity {
E
Erich Gamma 已提交
110
	switch (value) {
111
		case types.DiagnosticSeverity.Error:
J
Johannes Rieken 已提交
112
			return MarkerSeverity.Error;
113
		case types.DiagnosticSeverity.Warning:
J
Johannes Rieken 已提交
114
			return MarkerSeverity.Warning;
115
		case types.DiagnosticSeverity.Information:
J
Johannes Rieken 已提交
116
			return MarkerSeverity.Info;
117
		case types.DiagnosticSeverity.Hint:
J
Johannes Rieken 已提交
118
			return MarkerSeverity.Hint;
E
Erich Gamma 已提交
119
	}
J
Johannes Rieken 已提交
120
	return MarkerSeverity.Error;
E
Erich Gamma 已提交
121 122
}

J
Johannes Rieken 已提交
123
export function toDiagnosticSeverty(value: MarkerSeverity): types.DiagnosticSeverity {
E
Erich Gamma 已提交
124
	switch (value) {
J
Johannes Rieken 已提交
125
		case MarkerSeverity.Info:
126
			return types.DiagnosticSeverity.Information;
J
Johannes Rieken 已提交
127
		case MarkerSeverity.Warning:
128
			return types.DiagnosticSeverity.Warning;
J
Johannes Rieken 已提交
129
		case MarkerSeverity.Error:
130
			return types.DiagnosticSeverity.Error;
J
Johannes Rieken 已提交
131
		case MarkerSeverity.Hint:
132
			return types.DiagnosticSeverity.Hint;
E
Erich Gamma 已提交
133
	}
134
	return types.DiagnosticSeverity.Error;
E
Erich Gamma 已提交
135 136
}

137

E
Erich Gamma 已提交
138
export function fromViewColumn(column?: vscode.ViewColumn): EditorPosition {
B
Benjamin Pasero 已提交
139
	let editorColumn = EditorPosition.ONE;
E
Erich Gamma 已提交
140
	if (typeof column !== 'number') {
B
Benjamin Pasero 已提交
141
		// stick with ONE
142
	} else if (column === <number>types.ViewColumn.Two) {
B
Benjamin Pasero 已提交
143
		editorColumn = EditorPosition.TWO;
144
	} else if (column === <number>types.ViewColumn.Three) {
B
Benjamin Pasero 已提交
145
		editorColumn = EditorPosition.THREE;
146 147
	} else if (column === <number>types.ViewColumn.Active) {
		editorColumn = undefined;
E
Erich Gamma 已提交
148 149 150 151
	}
	return editorColumn;
}

152 153
export function toViewColumn(position?: EditorPosition): vscode.ViewColumn {
	if (typeof position !== 'number') {
M
Matt Bierner 已提交
154
		return undefined;
155
	}
B
Benjamin Pasero 已提交
156
	if (position === EditorPosition.ONE) {
157
		return <number>types.ViewColumn.One;
B
Benjamin Pasero 已提交
158
	} else if (position === EditorPosition.TWO) {
159
		return <number>types.ViewColumn.Two;
B
Benjamin Pasero 已提交
160
	} else if (position === EditorPosition.THREE) {
161
		return <number>types.ViewColumn.Three;
162
	}
M
Matt Bierner 已提交
163
	return undefined;
164
}
E
Erich Gamma 已提交
165

M
Martin Aeschlimann 已提交
166
function isDecorationOptions(something: any): something is vscode.DecorationOptions {
167
	return (typeof something.range !== 'undefined');
E
Erich Gamma 已提交
168 169
}

170
export function isDecorationOptionsArr(something: vscode.Range[] | vscode.DecorationOptions[]): something is vscode.DecorationOptions[] {
E
Erich Gamma 已提交
171 172 173
	if (something.length === 0) {
		return true;
	}
M
Martin Aeschlimann 已提交
174
	return isDecorationOptions(something[0]) ? true : false;
E
Erich Gamma 已提交
175 176
}

177 178 179 180 181 182
export namespace MarkdownString {

	export function fromMany(markup: (vscode.MarkdownString | vscode.MarkedString)[]): htmlContent.IMarkdownString[] {
		return markup.map(MarkdownString.from);
	}

J
Johannes Rieken 已提交
183 184 185 186 187 188
	interface Codeblock {
		language: string;
		value: string;
	}

	function isCodeblock(thing: any): thing is Codeblock {
J
Johannes Rieken 已提交
189
		return thing && typeof thing === 'object'
J
Johannes Rieken 已提交
190 191 192 193
			&& typeof (<Codeblock>thing).language === 'string'
			&& typeof (<Codeblock>thing).value === 'string';
	}

194
	export function from(markup: vscode.MarkdownString | vscode.MarkedString): htmlContent.IMarkdownString {
J
Johannes Rieken 已提交
195 196 197 198
		if (isCodeblock(markup)) {
			const { language, value } = markup;
			return { value: '```' + language + '\n' + value + '\n```\n' };
		} else if (htmlContent.isMarkdownString(markup)) {
199
			return markup;
J
Johannes Rieken 已提交
200
		} else if (typeof markup === 'string') {
201
			return { value: <string>markup };
202
		} else {
J
Johannes Rieken 已提交
203
			return { value: '' };
204 205
		}
	}
206 207 208 209
	export function to(value: htmlContent.IMarkdownString): vscode.MarkdownString {
		const ret = new htmlContent.MarkdownString(value.value);
		ret.isTrusted = value.isTrusted;
		return ret;
210
	}
211 212 213 214 215 216 217

	export function fromStrict(value: string | types.MarkdownString): undefined | string | htmlContent.IMarkdownString {
		if (!value) {
			return undefined;
		}
		return typeof value === 'string' ? value : MarkdownString.from(value);
	}
218 219
}

220
export function fromRangeOrRangeWithMessage(ranges: vscode.Range[] | vscode.DecorationOptions[]): IDecorationOptions[] {
M
Martin Aeschlimann 已提交
221
	if (isDecorationOptionsArr(ranges)) {
222
		return ranges.map(r => {
E
Erich Gamma 已提交
223 224
			return {
				range: fromRange(r.range),
225
				hoverMessage: Array.isArray(r.hoverMessage) ? MarkdownString.fromMany(r.hoverMessage) : r.hoverMessage && MarkdownString.from(r.hoverMessage),
226
				renderOptions: <any> /* URI vs Uri */r.renderOptions
E
Erich Gamma 已提交
227 228 229
			};
		});
	} else {
M
Martin Aeschlimann 已提交
230
		return ranges.map((r): IDecorationOptions => {
E
Erich Gamma 已提交
231 232
			return {
				range: fromRange(r)
B
Benjamin Pasero 已提交
233
			};
E
Erich Gamma 已提交
234 235 236
		});
	}
}
237

238
export const TextEdit = {
239

J
Johannes Rieken 已提交
240 241
	from(edit: vscode.TextEdit): modes.TextEdit {
		return <modes.TextEdit>{
242
			text: edit.newText,
J
Johannes Rieken 已提交
243
			eol: EndOfLine.from(edit.newEol),
244
			range: fromRange(edit.range)
B
Benjamin Pasero 已提交
245
		};
246
	},
247
	to(edit: modes.TextEdit): types.TextEdit {
J
Johannes Rieken 已提交
248 249 250
		let result = new types.TextEdit(toRange(edit.range), edit.text);
		result.newEol = EndOfLine.to(edit.eol);
		return result;
251
	}
B
Benjamin Pasero 已提交
252
};
253

254 255
export namespace WorkspaceEdit {
	export function from(value: vscode.WorkspaceEdit): modes.WorkspaceEdit {
256
		const result: modes.WorkspaceEdit = {
257
			edits: []
258
		};
259
		for (const entry of value.entries()) {
260 261 262 263 264 265 266
			const [uri, uriOrEdits] = entry;
			if (Array.isArray(uriOrEdits)) {
				// text edits
				result.edits.push({ resource: uri, edits: uriOrEdits.map(TextEdit.from) });
			} else {
				// resource edits
				result.edits.push({ oldUri: uri, newUri: uriOrEdits });
267 268 269 270 271
			}
		}
		return result;
	}

272
	export function to(value: WorkspaceEditDto) {
273 274
		const result = new types.WorkspaceEdit();
		for (const edit of value.edits) {
275 276 277 278 279
			if (Array.isArray((<ResourceTextEditDto>edit).edits)) {
				result.set(
					URI.revive((<ResourceTextEditDto>edit).resource),
					<types.TextEdit[]>(<ResourceTextEditDto>edit).edits.map(TextEdit.to)
				);
280 281 282 283 284
				// } else {
				// 	result.renameResource(
				// 		URI.revive((<ResourceFileEditDto>edit).oldUri),
				// 		URI.revive((<ResourceFileEditDto>edit).newUri)
				// 	);
285
			}
286 287 288
		}
		return result;
	}
289 290
}

291

292 293 294
export namespace SymbolKind {

	const _fromMapping: { [kind: number]: modes.SymbolKind } = Object.create(null);
295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317
	_fromMapping[types.SymbolKind.File] = modes.SymbolKind.File;
	_fromMapping[types.SymbolKind.Module] = modes.SymbolKind.Module;
	_fromMapping[types.SymbolKind.Namespace] = modes.SymbolKind.Namespace;
	_fromMapping[types.SymbolKind.Package] = modes.SymbolKind.Package;
	_fromMapping[types.SymbolKind.Class] = modes.SymbolKind.Class;
	_fromMapping[types.SymbolKind.Method] = modes.SymbolKind.Method;
	_fromMapping[types.SymbolKind.Property] = modes.SymbolKind.Property;
	_fromMapping[types.SymbolKind.Field] = modes.SymbolKind.Field;
	_fromMapping[types.SymbolKind.Constructor] = modes.SymbolKind.Constructor;
	_fromMapping[types.SymbolKind.Enum] = modes.SymbolKind.Enum;
	_fromMapping[types.SymbolKind.Interface] = modes.SymbolKind.Interface;
	_fromMapping[types.SymbolKind.Function] = modes.SymbolKind.Function;
	_fromMapping[types.SymbolKind.Variable] = modes.SymbolKind.Variable;
	_fromMapping[types.SymbolKind.Constant] = modes.SymbolKind.Constant;
	_fromMapping[types.SymbolKind.String] = modes.SymbolKind.String;
	_fromMapping[types.SymbolKind.Number] = modes.SymbolKind.Number;
	_fromMapping[types.SymbolKind.Boolean] = modes.SymbolKind.Boolean;
	_fromMapping[types.SymbolKind.Array] = modes.SymbolKind.Array;
	_fromMapping[types.SymbolKind.Object] = modes.SymbolKind.Object;
	_fromMapping[types.SymbolKind.Key] = modes.SymbolKind.Key;
	_fromMapping[types.SymbolKind.Null] = modes.SymbolKind.Null;
	_fromMapping[types.SymbolKind.EnumMember] = modes.SymbolKind.EnumMember;
	_fromMapping[types.SymbolKind.Struct] = modes.SymbolKind.Struct;
318 319
	_fromMapping[types.SymbolKind.Event] = modes.SymbolKind.Event;
	_fromMapping[types.SymbolKind.Operator] = modes.SymbolKind.Operator;
320
	_fromMapping[types.SymbolKind.TypeParameter] = modes.SymbolKind.TypeParameter;
321 322

	export function from(kind: vscode.SymbolKind): modes.SymbolKind {
323
		return _fromMapping[kind] || modes.SymbolKind.Property;
324 325
	}

326 327 328 329
	export function to(kind: modes.SymbolKind): vscode.SymbolKind {
		for (let k in _fromMapping) {
			if (_fromMapping[k] === kind) {
				return Number(k);
330
			}
331 332
		}
		return types.SymbolKind.Property;
333 334 335
	}
}

336 337
export function fromSymbolInformation(info: vscode.SymbolInformation): modes.SymbolInformation {
	return <modes.SymbolInformation>{
338
		name: info.name,
339
		kind: SymbolKind.from(info.kind),
340
		containerName: info.containerName,
341
		location: location.from(info.location)
342 343 344
	};
}

345 346 347 348
export function toSymbolInformation(bearing: modes.SymbolInformation): types.SymbolInformation {
	return new types.SymbolInformation(
		bearing.name,
		SymbolKind.to(bearing.kind),
349
		bearing.containerName,
350
		location.to(bearing.location)
351
	);
352 353 354
}


355
export const location = {
J
Johannes Rieken 已提交
356
	from(value: vscode.Location): modes.Location {
357
		return {
J
Johannes Rieken 已提交
358
			range: value.range && fromRange(value.range),
J
Johannes Rieken 已提交
359
			uri: value.uri
J
Johannes Rieken 已提交
360
		};
361
	},
362 363
	to(value: modes.Location): types.Location {
		return new types.Location(value.uri, toRange(value.range));
364
	}
J
Johannes Rieken 已提交
365
};
366

367 368
export function fromHover(hover: vscode.Hover): modes.Hover {
	return <modes.Hover>{
369
		range: fromRange(hover.range),
370
		contents: MarkdownString.fromMany(hover.contents)
B
Benjamin Pasero 已提交
371
	};
372 373
}

374
export function toHover(info: modes.Hover): types.Hover {
375
	return new types.Hover(info.contents.map(MarkdownString.to), toRange(info.range));
376 377
}

378 379
export function toDocumentHighlight(occurrence: modes.DocumentHighlight): types.DocumentHighlight {
	return new types.DocumentHighlight(toRange(occurrence.range), occurrence.kind);
380 381
}

M
Matt Bierner 已提交
382 383 384 385 386
export namespace CompletionTriggerKind {
	export function from(kind: modes.SuggestTriggerKind) {
		switch (kind) {
			case modes.SuggestTriggerKind.TriggerCharacter:
				return types.CompletionTriggerKind.TriggerCharacter;
387 388
			case modes.SuggestTriggerKind.TriggerForIncompleteCompletions:
				return types.CompletionTriggerKind.TriggerForIncompleteCompletions;
M
Matt Bierner 已提交
389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404
			case modes.SuggestTriggerKind.Invoke:
			default:
				return types.CompletionTriggerKind.Invoke;
		}
	}
}

export namespace CompletionContext {
	export function from(context: modes.SuggestContext): types.CompletionContext {
		return {
			triggerKind: CompletionTriggerKind.from(context.triggerKind),
			triggerCharacter: context.triggerCharacter
		};
	}
}

J
Johannes Rieken 已提交
405 406 407 408
export const CompletionItemKind = {

	from(kind: types.CompletionItemKind): modes.SuggestionType {
		switch (kind) {
409
			case types.CompletionItemKind.Method: return 'method';
J
Johannes Rieken 已提交
410 411 412 413 414 415
			case types.CompletionItemKind.Function: return 'function';
			case types.CompletionItemKind.Constructor: return 'constructor';
			case types.CompletionItemKind.Field: return 'field';
			case types.CompletionItemKind.Variable: return 'variable';
			case types.CompletionItemKind.Class: return 'class';
			case types.CompletionItemKind.Interface: return 'interface';
416
			case types.CompletionItemKind.Struct: return 'struct';
J
Johannes Rieken 已提交
417 418 419 420
			case types.CompletionItemKind.Module: return 'module';
			case types.CompletionItemKind.Property: return 'property';
			case types.CompletionItemKind.Unit: return 'unit';
			case types.CompletionItemKind.Value: return 'value';
421
			case types.CompletionItemKind.Constant: return 'constant';
J
Johannes Rieken 已提交
422
			case types.CompletionItemKind.Enum: return 'enum';
423
			case types.CompletionItemKind.EnumMember: return 'enum-member';
J
Johannes Rieken 已提交
424 425 426 427 428 429
			case types.CompletionItemKind.Keyword: return 'keyword';
			case types.CompletionItemKind.Snippet: return 'snippet';
			case types.CompletionItemKind.Text: return 'text';
			case types.CompletionItemKind.Color: return 'color';
			case types.CompletionItemKind.File: return 'file';
			case types.CompletionItemKind.Reference: return 'reference';
430
			case types.CompletionItemKind.Folder: return 'folder';
431 432
			case types.CompletionItemKind.Event: return 'event';
			case types.CompletionItemKind.Operator: return 'operator';
433
			case types.CompletionItemKind.TypeParameter: return 'type-parameter';
J
Johannes Rieken 已提交
434
		}
435
		return 'property';
J
Johannes Rieken 已提交
436 437 438 439
	},

	to(type: modes.SuggestionType): types.CompletionItemKind {
		if (!type) {
440
			return types.CompletionItemKind.Property;
J
Johannes Rieken 已提交
441 442 443 444 445 446
		} else {
			return types.CompletionItemKind[type.charAt(0).toUpperCase() + type.substr(1)];
		}
	}
};

447
export namespace Suggest {
448

449
	export function to(position: types.Position, suggestion: modes.ISuggestion): types.CompletionItem {
450
		const result = new types.CompletionItem(suggestion.label);
451
		result.insertText = suggestion.insertText;
J
Johannes Rieken 已提交
452
		result.kind = CompletionItemKind.to(suggestion.type);
453
		result.detail = suggestion.detail;
454
		result.documentation = htmlContent.isMarkdownString(suggestion.documentation) ? MarkdownString.to(suggestion.documentation) : suggestion.documentation;
455 456
		result.sortText = suggestion.sortText;
		result.filterText = suggestion.filterText;
457

458
		// 'overwrite[Before|After]'-logic
459
		let overwriteBefore = (typeof suggestion.overwriteBefore === 'number') ? suggestion.overwriteBefore : 0;
M
Martin Aeschlimann 已提交
460 461 462
		let startPosition = new types.Position(position.line, Math.max(0, position.character - overwriteBefore));
		let endPosition = position;
		if (typeof suggestion.overwriteAfter === 'number') {
463 464
			endPosition = new types.Position(position.line, position.character + suggestion.overwriteAfter);
		}
465 466 467 468 469 470 471 472 473 474 475
		result.range = new types.Range(startPosition, endPosition);

		// 'inserText'-logic
		if (suggestion.snippetType === 'textmate') {
			result.insertText = new types.SnippetString(suggestion.insertText);
		} else {
			result.insertText = suggestion.insertText;
			result.textEdit = new types.TextEdit(result.range, result.insertText);
		}

		// TODO additionalEdits, command
476

477 478
		return result;
	}
479
}
480

481 482 483 484
export namespace ParameterInformation {
	export function from(info: types.ParameterInformation): modes.ParameterInformation {
		return {
			label: info.label,
485
			documentation: MarkdownString.fromStrict(info.documentation)
486 487 488 489 490 491 492 493 494 495 496 497 498 499 500
		};
	}
	export function to(info: modes.ParameterInformation): types.ParameterInformation {
		return {
			label: info.label,
			documentation: htmlContent.isMarkdownString(info.documentation) ? MarkdownString.to(info.documentation) : info.documentation
		};
	}
}

export namespace SignatureInformation {

	export function from(info: types.SignatureInformation): modes.SignatureInformation {
		return {
			label: info.label,
501
			documentation: MarkdownString.fromStrict(info.documentation),
502 503 504 505 506 507 508 509 510 511 512 513
			parameters: info.parameters && info.parameters.map(ParameterInformation.from)
		};
	}

	export function to(info: modes.SignatureInformation): types.SignatureInformation {
		return {
			label: info.label,
			documentation: htmlContent.isMarkdownString(info.documentation) ? MarkdownString.to(info.documentation) : info.documentation,
			parameters: info.parameters && info.parameters.map(ParameterInformation.to)
		};
	}
}
514

515 516
export namespace SignatureHelp {

517 518 519 520 521 522
	export function from(help: types.SignatureHelp): modes.SignatureHelp {
		return {
			activeSignature: help.activeSignature,
			activeParameter: help.activeParameter,
			signatures: help.signatures && help.signatures.map(SignatureInformation.from)
		};
523 524
	}

525 526 527 528 529 530
	export function to(help: modes.SignatureHelp): types.SignatureHelp {
		return {
			activeSignature: help.activeSignature,
			activeParameter: help.activeParameter,
			signatures: help.signatures && help.signatures.map(SignatureInformation.to)
		};
531
	}
J
Johannes Rieken 已提交
532 533
}

J
Johannes Rieken 已提交
534 535
export namespace DocumentLink {

536
	export function from(link: vscode.DocumentLink): modes.ILink {
J
Johannes Rieken 已提交
537 538
		return {
			range: fromRange(link.range),
539
			url: link.target && link.target.toString()
J
Johannes Rieken 已提交
540 541 542
		};
	}

543
	export function to(link: modes.ILink): vscode.DocumentLink {
544
		return new types.DocumentLink(toRange(link.range), link.url && URI.parse(link.url));
J
Johannes Rieken 已提交
545 546
	}
}
547

548
export namespace ColorPresentation {
549 550 551 552 553 554 555 556 557
	export function to(colorPresentation: modes.IColorPresentation): types.ColorPresentation {
		let cp = new types.ColorPresentation(colorPresentation.label);
		if (colorPresentation.textEdit) {
			cp.textEdit = TextEdit.to(colorPresentation.textEdit);
		}
		if (colorPresentation.additionalTextEdits) {
			cp.additionalTextEdits = colorPresentation.additionalTextEdits.map(value => TextEdit.to(value));
		}
		return cp;
558 559 560 561 562 563 564 565 566 567 568
	}

	export function from(colorPresentation: vscode.ColorPresentation): modes.IColorPresentation {
		return {
			label: colorPresentation.label,
			textEdit: colorPresentation.textEdit ? TextEdit.from(colorPresentation.textEdit) : undefined,
			additionalTextEdits: colorPresentation.additionalTextEdits ? colorPresentation.additionalTextEdits.map(value => TextEdit.from(value)) : undefined
		};
	}
}

569 570 571 572 573 574 575 576 577
export namespace Color {
	export function to(c: [number, number, number, number]): types.Color {
		return new types.Color(c[0], c[1], c[2], c[3]);
	}
	export function from(color: types.Color): [number, number, number, number] {
		return [color.red, color.green, color.blue, color.alpha];
	}
}

578 579 580 581 582
export namespace TextDocumentSaveReason {

	export function to(reason: SaveReason): vscode.TextDocumentSaveReason {
		switch (reason) {
			case SaveReason.AUTO:
583
				return types.TextDocumentSaveReason.AfterDelay;
584
			case SaveReason.EXPLICIT:
585
				return types.TextDocumentSaveReason.Manual;
586 587 588 589 590
			case SaveReason.FOCUS_CHANGE:
			case SaveReason.WINDOW_CHANGE:
				return types.TextDocumentSaveReason.FocusOut;
		}
	}
591
}
592 593


594 595 596 597 598 599 600 601 602
export namespace EndOfLine {

	export function from(eol: vscode.EndOfLine): EndOfLineSequence {
		if (eol === types.EndOfLine.CRLF) {
			return EndOfLineSequence.CRLF;
		} else if (eol === types.EndOfLine.LF) {
			return EndOfLineSequence.LF;
		}
		return undefined;
603
	}
J
Johannes Rieken 已提交
604 605 606 607 608 609 610 611 612

	export function to(eol: EndOfLineSequence): vscode.EndOfLine {
		if (eol === EndOfLineSequence.CRLF) {
			return types.EndOfLine.CRLF;
		} else if (eol === EndOfLineSequence.LF) {
			return types.EndOfLine.LF;
		}
		return undefined;
	}
613 614
}

J
Johannes Rieken 已提交
615 616 617
export namespace ProgressLocation {
	export function from(loc: vscode.ProgressLocation): MainProgressLocation {
		switch (loc) {
618
			case types.ProgressLocation.SourceControl: return MainProgressLocation.Scm;
J
Johannes Rieken 已提交
619
			case types.ProgressLocation.Window: return MainProgressLocation.Window;
620
			case types.ProgressLocation.Notification: return MainProgressLocation.Notification;
J
Johannes Rieken 已提交
621 622 623 624
		}
		return undefined;
	}
}
625

626
export namespace FoldingRange {
627
	export function from(r: vscode.FoldingRange): modes.FoldingRange {
628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648
		let range: modes.FoldingRange = { start: r.start + 1, end: r.end + 1 };
		if (r.kind) {
			range.kind = FoldingRangeKind.from(r.kind);
		}
		return range;
	}
}

export namespace FoldingRangeKind {
	export function from(kind: vscode.FoldingRangeKind | undefined): modes.FoldingRangeKind | undefined {
		if (kind) {
			switch (kind) {
				case types.FoldingRangeKind.Comment:
					return modes.FoldingRangeKind.Comment;
				case types.FoldingRangeKind.Imports:
					return modes.FoldingRangeKind.Imports;
				case types.FoldingRangeKind.Region:
					return modes.FoldingRangeKind.Region;
			}
		}
		return void 0;
649 650 651
	}
}

652 653 654 655 656 657 658 659 660 661
export function toTextEditorOptions(options?: vscode.TextDocumentShowOptions): ITextEditorOptions {
	if (options) {
		return {
			pinned: typeof options.preview === 'boolean' ? !options.preview : undefined,
			preserveFocus: options.preserveFocus,
			selection: typeof options.selection === 'object' ? fromRange(options.selection) : undefined
		} as ITextEditorOptions;
	}

	return undefined;
662 663 664 665 666 667 668
}

export function toGlobPattern(pattern: vscode.GlobPattern): string | IRelativePattern {
	if (typeof pattern === 'string') {
		return pattern;
	}

J
Johannes Rieken 已提交
669 670
	if (isRelativePattern(pattern)) {
		return new types.RelativePattern(pattern.base, pattern.pattern);
671 672
	}

J
Johannes Rieken 已提交
673
	return pattern; // preserve `undefined` and `null`
674 675
}

676 677 678 679 680 681
function isRelativePattern(obj: any): obj is vscode.RelativePattern {
	const rp = obj as vscode.RelativePattern;

	return rp && typeof rp.base === 'string' && typeof rp.pattern === 'string';
}

682 683 684 685 686 687 688 689 690 691 692 693 694
export function toLanguageSelector(selector: vscode.DocumentSelector): LanguageSelector {
	if (Array.isArray(selector)) {
		return selector.map(sel => doToLanguageSelector(sel));
	}

	return doToLanguageSelector(selector);
}

function doToLanguageSelector(selector: string | vscode.DocumentFilter): string | LanguageFilter {
	if (typeof selector === 'string') {
		return selector;
	}

695 696 697 698
	if (selector) {
		return {
			language: selector.language,
			scheme: selector.scheme,
699 700
			pattern: toGlobPattern(selector.pattern),
			exclusive: selector.exclusive
701 702 703 704
		};
	}

	return undefined;
705
}