mirror of
https://github.com/microsoft/vscode.git
synced 2026-04-20 00:28:52 +01:00
143 lines
5.4 KiB
TypeScript
143 lines
5.4 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { getLanguageService as getHTMLLanguageService, DocumentContext, HTMLData } from 'vscode-html-languageservice';
|
|
import {
|
|
CompletionItem, Location, SignatureHelp, Definition, TextEdit, TextDocument, Diagnostic, DocumentLink, Range,
|
|
Hover, DocumentHighlight, CompletionList, Position, FormattingOptions, SymbolInformation, FoldingRange
|
|
} from 'vscode-languageserver-types';
|
|
import { ColorInformation, ColorPresentation, Color, WorkspaceFolder } from 'vscode-languageserver';
|
|
|
|
import { getLanguageModelCache, LanguageModelCache } from '../languageModelCache';
|
|
import { getDocumentRegions, HTMLDocumentRegions } from './embeddedSupport';
|
|
import { getCSSMode } from './cssMode';
|
|
import { getJavaScriptMode } from './javascriptMode';
|
|
import { getHTMLMode } from './htmlMode';
|
|
|
|
export { ColorInformation, ColorPresentation, Color };
|
|
|
|
export interface Settings {
|
|
css?: any;
|
|
html?: any;
|
|
javascript?: any;
|
|
}
|
|
|
|
export interface Workspace {
|
|
readonly settings: Settings;
|
|
readonly folders: WorkspaceFolder[];
|
|
}
|
|
|
|
export interface LanguageMode {
|
|
getId(): string;
|
|
doValidation?: (document: TextDocument, settings?: Settings) => Diagnostic[];
|
|
doComplete?: (document: TextDocument, position: Position, settings?: Settings) => CompletionList;
|
|
doResolve?: (document: TextDocument, item: CompletionItem) => CompletionItem;
|
|
doHover?: (document: TextDocument, position: Position) => Hover | null;
|
|
doSignatureHelp?: (document: TextDocument, position: Position) => SignatureHelp | null;
|
|
findDocumentHighlight?: (document: TextDocument, position: Position) => DocumentHighlight[];
|
|
findDocumentSymbols?: (document: TextDocument) => SymbolInformation[];
|
|
findDocumentLinks?: (document: TextDocument, documentContext: DocumentContext) => DocumentLink[];
|
|
findDefinition?: (document: TextDocument, position: Position) => Definition | null;
|
|
findReferences?: (document: TextDocument, position: Position) => Location[];
|
|
format?: (document: TextDocument, range: Range, options: FormattingOptions, settings?: Settings) => TextEdit[];
|
|
findDocumentColors?: (document: TextDocument) => ColorInformation[];
|
|
getColorPresentations?: (document: TextDocument, color: Color, range: Range) => ColorPresentation[];
|
|
doAutoClose?: (document: TextDocument, position: Position) => string | null;
|
|
getFoldingRanges?: (document: TextDocument) => FoldingRange[];
|
|
onDocumentRemoved(document: TextDocument): void;
|
|
dispose(): void;
|
|
}
|
|
|
|
export interface LanguageModes {
|
|
getModeAtPosition(document: TextDocument, position: Position): LanguageMode | undefined;
|
|
getModesInRange(document: TextDocument, range: Range): LanguageModeRange[];
|
|
getAllModes(): LanguageMode[];
|
|
getAllModesInDocument(document: TextDocument): LanguageMode[];
|
|
getMode(languageId: string): LanguageMode | undefined;
|
|
onDocumentRemoved(document: TextDocument): void;
|
|
dispose(): void;
|
|
}
|
|
|
|
export interface LanguageModeRange extends Range {
|
|
mode: LanguageMode | undefined;
|
|
attributeValue?: boolean;
|
|
}
|
|
|
|
export function getLanguageModes(supportedLanguages: { [languageId: string]: boolean; }, workspace: Workspace, customData?: HTMLData): LanguageModes {
|
|
|
|
const htmlLanguageService = getHTMLLanguageService({
|
|
customData
|
|
});
|
|
|
|
let documentRegions = getLanguageModelCache<HTMLDocumentRegions>(10, 60, document => getDocumentRegions(htmlLanguageService, document));
|
|
|
|
let modelCaches: LanguageModelCache<any>[] = [];
|
|
modelCaches.push(documentRegions);
|
|
|
|
let modes = Object.create(null);
|
|
modes['html'] = getHTMLMode(htmlLanguageService, workspace);
|
|
if (supportedLanguages['css']) {
|
|
modes['css'] = getCSSMode(documentRegions, workspace);
|
|
}
|
|
if (supportedLanguages['javascript']) {
|
|
modes['javascript'] = getJavaScriptMode(documentRegions);
|
|
}
|
|
return {
|
|
getModeAtPosition(document: TextDocument, position: Position): LanguageMode | undefined {
|
|
let languageId = documentRegions.get(document).getLanguageAtPosition(position);
|
|
if (languageId) {
|
|
return modes[languageId];
|
|
}
|
|
return undefined;
|
|
},
|
|
getModesInRange(document: TextDocument, range: Range): LanguageModeRange[] {
|
|
return documentRegions.get(document).getLanguageRanges(range).map(r => {
|
|
return <LanguageModeRange>{
|
|
start: r.start,
|
|
end: r.end,
|
|
mode: r.languageId && modes[r.languageId],
|
|
attributeValue: r.attributeValue
|
|
};
|
|
});
|
|
},
|
|
getAllModesInDocument(document: TextDocument): LanguageMode[] {
|
|
let result = [];
|
|
for (let languageId of documentRegions.get(document).getLanguagesInDocument()) {
|
|
let mode = modes[languageId];
|
|
if (mode) {
|
|
result.push(mode);
|
|
}
|
|
}
|
|
return result;
|
|
},
|
|
getAllModes(): LanguageMode[] {
|
|
let result = [];
|
|
for (let languageId in modes) {
|
|
let mode = modes[languageId];
|
|
if (mode) {
|
|
result.push(mode);
|
|
}
|
|
}
|
|
return result;
|
|
},
|
|
getMode(languageId: string): LanguageMode {
|
|
return modes[languageId];
|
|
},
|
|
onDocumentRemoved(document: TextDocument) {
|
|
modelCaches.forEach(mc => mc.onDocumentRemoved(document));
|
|
for (let mode in modes) {
|
|
modes[mode].onDocumentRemoved(document);
|
|
}
|
|
},
|
|
dispose(): void {
|
|
modelCaches.forEach(mc => mc.dispose());
|
|
modelCaches = [];
|
|
for (let mode in modes) {
|
|
modes[mode].dispose();
|
|
}
|
|
modes = {};
|
|
}
|
|
};
|
|
} |