mirror of
https://github.com/microsoft/monaco-editor.git
synced 2025-12-22 20:52:56 +01:00
Create monaco lib models on demand
This commit is contained in:
parent
577f254aac
commit
a213b303a6
1 changed files with 15 additions and 3 deletions
|
|
@ -7,6 +7,7 @@
|
|||
import { LanguageServiceDefaultsImpl } from './monaco.contribution';
|
||||
import * as ts from './lib/typescriptServices';
|
||||
import { TypeScriptWorker } from './tsWorker';
|
||||
import {libFileMap} from "./lib/lib"
|
||||
|
||||
import Uri = monaco.Uri;
|
||||
import Position = monaco.Position;
|
||||
|
|
@ -22,6 +23,17 @@ enum IndentStyle {
|
|||
Smart = 2
|
||||
}
|
||||
|
||||
function getOrCreateLibFile(uri: Uri) {
|
||||
let model = monaco.editor.getModel(uri)
|
||||
if (!model) {
|
||||
if (uri.path.indexOf("/lib.") === 0) {
|
||||
return monaco.editor.createModel(libFileMap[uri.path.slice(1)], "javascript", uri)
|
||||
}
|
||||
}
|
||||
return model
|
||||
}
|
||||
|
||||
|
||||
export function flattenDiagnosticMessageText(diag: string | ts.DiagnosticMessageChain | undefined, newLine: string, indent = 0): string {
|
||||
if (typeof diag === "string") {
|
||||
return diag;
|
||||
|
|
@ -224,7 +236,7 @@ export class DiagnosticsAdapter extends Adapter {
|
|||
let relatedResource: monaco.editor.ITextModel | null = model;
|
||||
if (info.file) {
|
||||
const relatedResourceUri = monaco.Uri.parse(info.file.fileName);
|
||||
relatedResource = monaco.editor.getModel(relatedResourceUri);
|
||||
relatedResource = getOrCreateLibFile(relatedResourceUri);
|
||||
}
|
||||
|
||||
if (!relatedResource) {
|
||||
|
|
@ -492,7 +504,7 @@ export class DefinitionAdapter extends Adapter {
|
|||
const result: monaco.languages.Location[] = [];
|
||||
for (let entry of entries) {
|
||||
const uri = Uri.parse(entry.fileName);
|
||||
const refModel = monaco.editor.getModel(uri);
|
||||
const refModel = getOrCreateLibFile(uri);
|
||||
if (refModel) {
|
||||
result.push({
|
||||
uri: uri,
|
||||
|
|
@ -521,7 +533,7 @@ export class ReferenceAdapter extends Adapter implements monaco.languages.Refere
|
|||
const result: monaco.languages.Location[] = [];
|
||||
for (let entry of entries) {
|
||||
const uri = Uri.parse(entry.fileName);
|
||||
const refModel = monaco.editor.getModel(uri);
|
||||
const refModel = getOrCreateLibFile(uri);
|
||||
if (refModel) {
|
||||
result.push({
|
||||
uri: uri,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue