@kusto/monaco-kusto 6.1.2 → 7.0.0
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/README.md +39 -13
- package/globalApi.d.ts +13 -0
- package/package.json +6 -5
- package/release/dev/kustoMode.js +47 -31
- package/release/dev/kustoWorker.js +2 -2
- package/release/dev/{main-1f7cc4fa.js → main-5ef10bd7.js} +2 -2
- package/release/dev/monaco.contribution.js +306 -290
- package/release/esm/commandFormatter.d.ts +1 -1
- package/release/esm/commandHighlighter.d.ts +1 -2
- package/release/esm/extendedEditor.d.ts +2 -2
- package/release/esm/kusto.worker.js +1 -1
- package/release/esm/kustoMode.d.ts +4 -6
- package/release/esm/kustoMode.js +12 -15
- package/release/esm/kustoWorker.d.ts +1 -1
- package/release/esm/languageFeatures.d.ts +15 -21
- package/release/esm/languageService/kustoMonarchLanguageDefinition.d.ts +1 -1
- package/release/esm/languageService/settings.d.ts +2 -2
- package/release/esm/monaco.contribution.d.ts +12 -9
- package/release/esm/monaco.contribution.js +276 -282
- package/release/esm/types.d.ts +261 -0
- package/release/esm/workerManager.d.ts +4 -7
- package/release/min/kustoMode.js +2 -2
- package/release/min/kustoWorker.js +2 -2
- package/release/min/{main-d13ce646.js → main-c8dacaab.js} +2 -2
- package/release/min/monaco.contribution.js +2 -2
- package/release/monaco.d.ts +1 -319
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
|
|
2
|
+
export declare function getCurrentCommandRange(editor: monaco.editor.ICodeEditor, cursorPosition: monaco.Position): monaco.Range;
|
|
3
3
|
/**
|
|
4
4
|
* Extending ICode editor to contain additional kusto-specific methods.
|
|
5
5
|
* note that the extend method needs to be called at least once to take affect, otherwise this here code is useless.
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/*!-----------------------------------------------------------------------------
|
|
2
2
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
3
|
-
* monaco-kusto version:
|
|
3
|
+
* monaco-kusto version: 7.0.0(f23f8fe8dd705f8413d0d094c76eb0af2131aace)
|
|
4
4
|
* Released under the MIT license
|
|
5
5
|
* https://https://github.com/Azure/monaco-kusto/blob/master/README.md
|
|
6
6
|
*-----------------------------------------------------------------------------*/
|
|
@@ -1,10 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import type { LanguageServiceDefaultsImpl } from './monaco.contribution';
|
|
4
|
-
import { WorkerAccessor } from './languageFeatures';
|
|
1
|
+
import type { LanguageServiceDefaults } from './monaco.contribution';
|
|
2
|
+
import * as languageFeatures from './languageFeatures';
|
|
5
3
|
/**
|
|
6
4
|
* Called when Kusto language is first needed (a model has the language set)
|
|
7
5
|
* @param defaults
|
|
8
6
|
*/
|
|
9
|
-
export declare function setupMode(defaults:
|
|
10
|
-
export declare function getKustoWorker(): Promise<WorkerAccessor>;
|
|
7
|
+
export declare function setupMode(defaults: LanguageServiceDefaults, monacoInstance: typeof globalThis.monaco): languageFeatures.WorkerAccessor;
|
|
8
|
+
export declare function getKustoWorker(): Promise<languageFeatures.WorkerAccessor>;
|
package/release/esm/kustoMode.js
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
/*!-----------------------------------------------------------------------------
|
|
2
2
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
3
|
-
* monaco-kusto version:
|
|
3
|
+
* monaco-kusto version: 7.0.0(f23f8fe8dd705f8413d0d094c76eb0af2131aace)
|
|
4
4
|
* Released under the MIT license
|
|
5
5
|
* https://https://github.com/Azure/monaco-kusto/blob/master/README.md
|
|
6
6
|
*-----------------------------------------------------------------------------*/
|
|
7
7
|
|
|
8
|
+
import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
|
|
8
9
|
import * as ls from 'vscode-languageserver-types';
|
|
9
10
|
import debounce from 'lodash-es/debounce';
|
|
10
11
|
|
|
@@ -174,12 +175,8 @@ const KustoLanguageDefinition = {
|
|
|
174
175
|
}
|
|
175
176
|
};
|
|
176
177
|
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
var Range = monaco.Range;
|
|
180
|
-
monaco.Thenable;
|
|
181
|
-
monaco.CancellationToken;
|
|
182
|
-
monaco.IDisposable; // --- diagnostics ---
|
|
178
|
+
// --- diagnostics ---
|
|
179
|
+
|
|
183
180
|
class DiagnosticsAdapter {
|
|
184
181
|
_disposables = [];
|
|
185
182
|
_contentListener = Object.create(null);
|
|
@@ -635,7 +632,7 @@ class ColorizationAdapter {
|
|
|
635
632
|
|
|
636
633
|
/**
|
|
637
634
|
* Return true if the range doesn't intersect any of the line ranges.
|
|
638
|
-
* @param range Range
|
|
635
|
+
* @param range monaco.Range
|
|
639
636
|
* @param impactedLineRanges an array of line ranges
|
|
640
637
|
*/
|
|
641
638
|
_rangeDoesNotIntersectAny(range, impactedLineRanges) {
|
|
@@ -731,7 +728,7 @@ function injectCss() {
|
|
|
731
728
|
function toDecoration(model, classification) {
|
|
732
729
|
const start = model.getPositionAt(classification.start);
|
|
733
730
|
const end = model.getPositionAt(classification.start + classification.length);
|
|
734
|
-
const range = new Range(start.lineNumber, start.column, end.lineNumber, end.column);
|
|
731
|
+
const range = new monaco.Range(start.lineNumber, start.column, end.lineNumber, end.column);
|
|
735
732
|
const inlineClassName = ClassificationKindNames[classification.kind];
|
|
736
733
|
return {
|
|
737
734
|
range,
|
|
@@ -765,7 +762,7 @@ function toRange(range) {
|
|
|
765
762
|
if (!range) {
|
|
766
763
|
return void 0;
|
|
767
764
|
}
|
|
768
|
-
return new Range(range.start.line + 1, range.start.character + 1, range.end.line + 1, range.end.character + 1);
|
|
765
|
+
return new monaco.Range(range.start.line + 1, range.start.character + 1, range.end.line + 1, range.end.character + 1);
|
|
769
766
|
}
|
|
770
767
|
function toCompletionItemKind(kind) {
|
|
771
768
|
let mItemKind = monaco.languages.CompletionItemKind;
|
|
@@ -850,7 +847,7 @@ class CompletionAdapter {
|
|
|
850
847
|
}
|
|
851
848
|
provideCompletionItems(model, position, context, token) {
|
|
852
849
|
const wordInfo = model.getWordUntilPosition(position);
|
|
853
|
-
const wordRange = new Range(position.lineNumber, wordInfo.startColumn, position.lineNumber, wordInfo.endColumn);
|
|
850
|
+
const wordRange = new monaco.Range(position.lineNumber, wordInfo.startColumn, position.lineNumber, wordInfo.endColumn);
|
|
854
851
|
const resource = model.uri;
|
|
855
852
|
const onDidProvideCompletionItems = this.languageSettings.onDidProvideCompletionItems;
|
|
856
853
|
return this._worker(resource).then(worker => {
|
|
@@ -865,12 +862,14 @@ class CompletionAdapter {
|
|
|
865
862
|
insertText: entry.insertText,
|
|
866
863
|
sortText: entry.sortText,
|
|
867
864
|
filterText: entry.filterText,
|
|
865
|
+
// TODO: Is this cast safe?
|
|
868
866
|
documentation: formatDocLink(entry.documentation?.value),
|
|
869
867
|
detail: entry.detail,
|
|
870
868
|
range: wordRange,
|
|
871
869
|
kind: toCompletionItemKind(entry.kind)
|
|
872
870
|
};
|
|
873
871
|
if (entry.textEdit) {
|
|
872
|
+
// TODO: Where is the "range" property coming from?
|
|
874
873
|
item.range = toRange(entry.textEdit.range);
|
|
875
874
|
item.insertText = entry.textEdit.newText;
|
|
876
875
|
}
|
|
@@ -923,7 +922,7 @@ function toMarkedStringArray(contents) {
|
|
|
923
922
|
|
|
924
923
|
function toLocation(location) {
|
|
925
924
|
return {
|
|
926
|
-
uri: Uri.parse(location.uri),
|
|
925
|
+
uri: monaco.Uri.parse(location.uri),
|
|
927
926
|
range: toRange(location.range)
|
|
928
927
|
};
|
|
929
928
|
}
|
|
@@ -971,7 +970,7 @@ function toWorkspaceEdit(edit) {
|
|
|
971
970
|
}
|
|
972
971
|
let resourceEdits = [];
|
|
973
972
|
for (let uri in edit.changes) {
|
|
974
|
-
const _uri = Uri.parse(uri);
|
|
973
|
+
const _uri = monaco.Uri.parse(uri);
|
|
975
974
|
for (let e of edit.changes[uri]) {
|
|
976
975
|
resourceEdits.push({
|
|
977
976
|
resource: _uri,
|
|
@@ -1068,8 +1067,6 @@ class HoverAdapter {
|
|
|
1068
1067
|
}
|
|
1069
1068
|
}
|
|
1070
1069
|
|
|
1071
|
-
monaco.Uri;
|
|
1072
|
-
monaco.IDisposable;
|
|
1073
1070
|
let kustoWorker;
|
|
1074
1071
|
let resolveWorker;
|
|
1075
1072
|
let workerPromise = new Promise((resolve, reject) => {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
/// <reference types="monaco-editor/monaco" />
|
|
2
1
|
import * as ls from 'vscode-languageserver-types';
|
|
2
|
+
import type * as monaco from 'monaco-editor/esm/vs/editor/editor.worker';
|
|
3
3
|
import * as kustoService from './languageService/kustoLanguageService';
|
|
4
4
|
import type { LanguageSettings } from './languageService/settings';
|
|
5
5
|
import { Schema, showSchema, ScalarParameter, Database, TabularParameter } from './languageService/schema';
|
|
@@ -1,15 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import type { LanguageServiceDefaultsImpl } from './monaco.contribution';
|
|
1
|
+
import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
|
|
2
|
+
import type { LanguageServiceDefaults, LanguageSettings } from './monaco.contribution';
|
|
4
3
|
import type { KustoWorker } from './kustoWorker';
|
|
5
|
-
import Uri = monaco.Uri;
|
|
6
|
-
import Position = monaco.Position;
|
|
7
|
-
import Range = monaco.Range;
|
|
8
|
-
import Thenable = monaco.Thenable;
|
|
9
|
-
import CancellationToken = monaco.CancellationToken;
|
|
10
4
|
import type { Schema } from './languageService/schema';
|
|
11
5
|
export interface WorkerAccessor {
|
|
12
|
-
(first: Uri, ...more: Uri[]): Promise<KustoWorker>;
|
|
6
|
+
(first: monaco.Uri, ...more: monaco.Uri[]): Promise<KustoWorker>;
|
|
13
7
|
}
|
|
14
8
|
export declare class DiagnosticsAdapter {
|
|
15
9
|
private _monacoInstance;
|
|
@@ -22,7 +16,7 @@ export declare class DiagnosticsAdapter {
|
|
|
22
16
|
private _schemaListener;
|
|
23
17
|
private _cursorListener;
|
|
24
18
|
private _debouncedValidations;
|
|
25
|
-
constructor(_monacoInstance: typeof monaco, _languageId: string, _worker: WorkerAccessor, defaults:
|
|
19
|
+
constructor(_monacoInstance: typeof globalThis.monaco, _languageId: string, _worker: WorkerAccessor, defaults: LanguageServiceDefaults, onSchemaChange: monaco.IEvent<Schema>);
|
|
26
20
|
private getMonacoCodeActions;
|
|
27
21
|
private getOrCreateDebouncedValidation;
|
|
28
22
|
dispose(): void;
|
|
@@ -37,11 +31,11 @@ export declare class ColorizationAdapter {
|
|
|
37
31
|
private _configurationListener;
|
|
38
32
|
private _schemaListener;
|
|
39
33
|
private decorations;
|
|
40
|
-
constructor(_monacoInstance: typeof monaco, _languageId: string, _worker: WorkerAccessor, defaults:
|
|
34
|
+
constructor(_monacoInstance: typeof globalThis.monaco, _languageId: string, _worker: WorkerAccessor, defaults: LanguageServiceDefaults, onSchemaChange: monaco.IEvent<Schema>);
|
|
41
35
|
dispose(): void;
|
|
42
36
|
/**
|
|
43
37
|
* Return true if the range doesn't intersect any of the line ranges.
|
|
44
|
-
* @param range Range
|
|
38
|
+
* @param range monaco.Range
|
|
45
39
|
* @param impactedLineRanges an array of line ranges
|
|
46
40
|
*/
|
|
47
41
|
private _rangeDoesNotIntersectAny;
|
|
@@ -50,42 +44,42 @@ export declare class ColorizationAdapter {
|
|
|
50
44
|
export declare class CompletionAdapter implements monaco.languages.CompletionItemProvider {
|
|
51
45
|
private _worker;
|
|
52
46
|
private languageSettings;
|
|
53
|
-
constructor(_worker: WorkerAccessor, languageSettings:
|
|
47
|
+
constructor(_worker: WorkerAccessor, languageSettings: LanguageSettings);
|
|
54
48
|
get triggerCharacters(): string[];
|
|
55
|
-
provideCompletionItems(model: monaco.editor.IReadOnlyModel, position: Position, context: monaco.languages.CompletionContext, token: CancellationToken): Thenable<monaco.languages.CompletionList>;
|
|
49
|
+
provideCompletionItems(model: monaco.editor.IReadOnlyModel, position: monaco.Position, context: monaco.languages.CompletionContext, token: monaco.CancellationToken): monaco.Thenable<monaco.languages.CompletionList>;
|
|
56
50
|
}
|
|
57
51
|
export declare class DefinitionAdapter {
|
|
58
52
|
private _worker;
|
|
59
53
|
constructor(_worker: WorkerAccessor);
|
|
60
|
-
provideDefinition(model: monaco.editor.IReadOnlyModel, position: Position, token: CancellationToken): Thenable<monaco.languages.Definition>;
|
|
54
|
+
provideDefinition(model: monaco.editor.IReadOnlyModel, position: monaco.Position, token: monaco.CancellationToken): monaco.Thenable<monaco.languages.Definition>;
|
|
61
55
|
}
|
|
62
56
|
export declare class ReferenceAdapter implements monaco.languages.ReferenceProvider {
|
|
63
57
|
private _worker;
|
|
64
58
|
constructor(_worker: WorkerAccessor);
|
|
65
|
-
provideReferences(model: monaco.editor.IReadOnlyModel, position: Position, context: monaco.languages.ReferenceContext, token: CancellationToken): Thenable<monaco.languages.Location[]>;
|
|
59
|
+
provideReferences(model: monaco.editor.IReadOnlyModel, position: monaco.Position, context: monaco.languages.ReferenceContext, token: monaco.CancellationToken): monaco.Thenable<monaco.languages.Location[]>;
|
|
66
60
|
}
|
|
67
61
|
export declare class RenameAdapter implements monaco.languages.RenameProvider {
|
|
68
62
|
private _worker;
|
|
69
63
|
constructor(_worker: WorkerAccessor);
|
|
70
|
-
provideRenameEdits(model: monaco.editor.IReadOnlyModel, position: Position, newName: string, token: CancellationToken): Thenable<monaco.languages.WorkspaceEdit>;
|
|
64
|
+
provideRenameEdits(model: monaco.editor.IReadOnlyModel, position: monaco.Position, newName: string, token: monaco.CancellationToken): monaco.Thenable<monaco.languages.WorkspaceEdit>;
|
|
71
65
|
}
|
|
72
66
|
export declare class DocumentFormatAdapter implements monaco.languages.DocumentFormattingEditProvider {
|
|
73
67
|
private _worker;
|
|
74
68
|
constructor(_worker: WorkerAccessor);
|
|
75
|
-
provideDocumentFormattingEdits(model: monaco.editor.IReadOnlyModel, options: monaco.languages.FormattingOptions, token: CancellationToken): monaco.languages.TextEdit[] | Thenable<monaco.languages.TextEdit[]>;
|
|
69
|
+
provideDocumentFormattingEdits(model: monaco.editor.IReadOnlyModel, options: monaco.languages.FormattingOptions, token: monaco.CancellationToken): monaco.languages.TextEdit[] | monaco.Thenable<monaco.languages.TextEdit[]>;
|
|
76
70
|
}
|
|
77
71
|
export declare class FormatAdapter implements monaco.languages.DocumentRangeFormattingEditProvider {
|
|
78
72
|
private _worker;
|
|
79
73
|
constructor(_worker: WorkerAccessor);
|
|
80
|
-
provideDocumentRangeFormattingEdits(model: monaco.editor.IReadOnlyModel, range: Range, options: monaco.languages.FormattingOptions, token: CancellationToken): monaco.languages.TextEdit[] | Thenable<monaco.languages.TextEdit[]>;
|
|
74
|
+
provideDocumentRangeFormattingEdits(model: monaco.editor.IReadOnlyModel, range: monaco.Range, options: monaco.languages.FormattingOptions, token: monaco.CancellationToken): monaco.languages.TextEdit[] | monaco.Thenable<monaco.languages.TextEdit[]>;
|
|
81
75
|
}
|
|
82
76
|
export declare class FoldingAdapter implements monaco.languages.FoldingRangeProvider {
|
|
83
77
|
private _worker;
|
|
84
78
|
constructor(_worker: WorkerAccessor);
|
|
85
|
-
provideFoldingRanges(model: monaco.editor.ITextModel, context: monaco.languages.FoldingContext, token: CancellationToken): monaco.languages.FoldingRange[] | PromiseLike<monaco.languages.FoldingRange[]>;
|
|
79
|
+
provideFoldingRanges(model: monaco.editor.ITextModel, context: monaco.languages.FoldingContext, token: monaco.CancellationToken): monaco.languages.FoldingRange[] | PromiseLike<monaco.languages.FoldingRange[]>;
|
|
86
80
|
}
|
|
87
81
|
export declare class HoverAdapter implements monaco.languages.HoverProvider {
|
|
88
82
|
private _worker;
|
|
89
83
|
constructor(_worker: WorkerAccessor);
|
|
90
|
-
provideHover(model: monaco.editor.IReadOnlyModel, position: Position, token: CancellationToken): Thenable<monaco.languages.Hover>;
|
|
84
|
+
provideHover(model: monaco.editor.IReadOnlyModel, position: monaco.Position, token: monaco.CancellationToken): monaco.Thenable<monaco.languages.Hover>;
|
|
91
85
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import type * as monaco from 'monaco-editor/esm/vs/editor/editor.worker';
|
|
2
2
|
export declare const KustoLanguageDefinition: monaco.languages.IMonarchLanguage;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
import type { OnDidProvideCompletionItems } from '../types';
|
|
2
2
|
export interface LanguageSettings {
|
|
3
3
|
includeControlCommands?: boolean;
|
|
4
4
|
newlineAfterPipe?: boolean;
|
|
@@ -7,7 +7,7 @@ export interface LanguageSettings {
|
|
|
7
7
|
useSemanticColorization?: boolean;
|
|
8
8
|
useTokenColorization?: boolean;
|
|
9
9
|
disabledCompletionItems?: string[];
|
|
10
|
-
onDidProvideCompletionItems?:
|
|
10
|
+
onDidProvideCompletionItems?: OnDidProvideCompletionItems;
|
|
11
11
|
enableHover?: boolean;
|
|
12
12
|
formatter?: FormatterOptions;
|
|
13
13
|
syntaxErrorAsMarkDown?: SyntaxErrorAsMarkDownOptions;
|
|
@@ -1,15 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import '
|
|
4
|
-
export
|
|
1
|
+
import * as monaco from 'monaco-editor/esm/vs/editor/editor.api';
|
|
2
|
+
import type { KustoWorker } from './kustoWorker';
|
|
3
|
+
import type { LanguageServiceDefaults, LanguageSettings } from './types';
|
|
4
|
+
export * from './types';
|
|
5
|
+
export { getCurrentCommandRange } from './extendedEditor';
|
|
6
|
+
declare class LanguageServiceDefaultsImpl implements LanguageServiceDefaults {
|
|
5
7
|
private _onDidChange;
|
|
6
8
|
private _languageSettings;
|
|
7
9
|
private _workerMaxIdleTime;
|
|
8
|
-
constructor(languageSettings:
|
|
9
|
-
get onDidChange(): monaco.IEvent<
|
|
10
|
-
get languageSettings():
|
|
11
|
-
setLanguageSettings(options:
|
|
10
|
+
constructor(languageSettings: LanguageSettings);
|
|
11
|
+
get onDidChange(): monaco.IEvent<LanguageServiceDefaults>;
|
|
12
|
+
get languageSettings(): LanguageSettings;
|
|
13
|
+
setLanguageSettings(options: LanguageSettings): void;
|
|
12
14
|
setMaximumWorkerIdleTime(value: number): void;
|
|
13
15
|
getWorkerMaxIdleTime(): number;
|
|
14
16
|
}
|
|
15
|
-
export declare function
|
|
17
|
+
export declare function getKustoWorker(): Promise<(first: monaco.Uri, ...more: monaco.Uri[]) => Promise<KustoWorker>>;
|
|
18
|
+
export declare const kustoDefaults: LanguageServiceDefaultsImpl;
|