@likec4/language-server 1.46.4 → 1.48.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/LICENSE +1 -1
- package/browser/package.json +2 -2
- package/browser-worker/package.json +2 -2
- package/bundled/package.json +4 -0
- package/dist/LikeC4LanguageServices.d.mts +4 -0
- package/dist/LikeC4LanguageServices.mjs +3 -0
- package/dist/_chunks/ConfigurableLayouter.mjs +1956 -0
- package/dist/_chunks/LikeC4LanguageServices.d.mts +1978 -0
- package/dist/_chunks/LikeC4LanguageServices.mjs +725 -0
- package/dist/_chunks/ast.d.mts +1444 -0
- package/dist/_chunks/ast.mjs +2375 -0
- package/dist/_chunks/ast2.mjs +176 -0
- package/dist/_chunks/common-exports.mjs +0 -0
- package/dist/_chunks/filesystem.mjs +58 -0
- package/dist/_chunks/grammar.mjs +8 -0
- package/dist/_chunks/icons.mjs +5211 -0
- package/dist/_chunks/libs/@hono/node-server.mjs +436 -0
- package/dist/_chunks/libs/@msgpack/msgpack.mjs +805 -0
- package/dist/_chunks/libs/eventemitter3.mjs +243 -0
- package/dist/_chunks/libs/fast-equals.mjs +446 -0
- package/dist/_chunks/libs/hono.mjs +1829 -0
- package/dist/_chunks/libs/p-queue.mjs +449 -0
- package/dist/_chunks/libs/parse-ms.mjs +36 -0
- package/dist/_chunks/libs/picomatch.mjs +1673 -0
- package/dist/_chunks/libs/pretty-ms.mjs +80 -0
- package/dist/_chunks/libs/remeda.mjs +482 -0
- package/dist/_chunks/libs/strip-indent.mjs +15 -0
- package/dist/_chunks/libs/ufo.mjs +166 -0
- package/dist/_chunks/likec4lib.mjs +9 -0
- package/dist/_chunks/mcp.mjs +33 -0
- package/dist/_chunks/module.mjs +28 -0
- package/dist/_chunks/module2.mjs +6576 -0
- package/dist/_chunks/protocol.d.mts +311 -0
- package/dist/_chunks/protocol.mjs +78 -0
- package/dist/_chunks/rolldown-runtime.mjs +42 -0
- package/dist/ast.d.mts +4 -0
- package/dist/ast.mjs +4 -0
- package/dist/browser-worker.d.mts +1 -0
- package/dist/browser-worker.mjs +6 -0
- package/dist/browser.d.mts +11 -0
- package/dist/browser.mjs +27 -0
- package/dist/bundled.d.mts +28 -0
- package/dist/bundled.mjs +51 -4681
- package/dist/common-exports.d.mts +4 -0
- package/dist/common-exports.mjs +5 -0
- package/dist/filesystem/index.d.mts +4 -0
- package/dist/filesystem/index.mjs +3 -0
- package/dist/generated/ast.d.mts +2 -0
- package/dist/generated/ast.mjs +3 -0
- package/dist/generated/grammar.d.mts +6 -0
- package/dist/generated/grammar.mjs +3 -0
- package/dist/generated/module.d.mts +14 -0
- package/dist/generated/module.mjs +3 -0
- package/dist/generated-lib/icons.d.mts +4 -0
- package/dist/generated-lib/icons.mjs +3 -0
- package/dist/index.d.mts +4 -0
- package/dist/index.mjs +48 -0
- package/dist/likec4lib.d.mts +9 -0
- package/dist/likec4lib.mjs +4 -0
- package/dist/mcp/index.d.mts +4 -0
- package/dist/mcp/index.mjs +3 -0
- package/dist/module.d.mts +4 -0
- package/dist/module.mjs +3 -0
- package/dist/protocol.d.mts +2 -0
- package/dist/protocol.mjs +3 -0
- package/likec4lib/package.json +2 -2
- package/package.json +106 -62
- package/protocol/package.json +2 -2
- package/dist/LikeC4LanguageServices.d.ts +0 -109
- package/dist/LikeC4LanguageServices.js +0 -154
- package/dist/Rpc.d.ts +0 -9
- package/dist/Rpc.js +0 -270
- package/dist/ast.d.ts +0 -226
- package/dist/ast.js +0 -264
- package/dist/browser-worker.d.ts +0 -1
- package/dist/browser-worker.js +0 -4
- package/dist/browser.d.ts +0 -11
- package/dist/browser.js +0 -35
- package/dist/bundled.d.ts +0 -8
- package/dist/bundled.js +0 -44
- package/dist/documentation/documentation-provider.d.ts +0 -8
- package/dist/documentation/documentation-provider.js +0 -51
- package/dist/documentation/index.d.ts +0 -1
- package/dist/documentation/index.js +0 -1
- package/dist/empty.d.ts +0 -2
- package/dist/empty.js +0 -2
- package/dist/filesystem/ChokidarWatcher.d.ts +0 -16
- package/dist/filesystem/ChokidarWatcher.js +0 -108
- package/dist/filesystem/FileSystemWatcher.d.ts +0 -19
- package/dist/filesystem/FileSystemWatcher.js +0 -14
- package/dist/filesystem/LikeC4FileSystem.d.ts +0 -3
- package/dist/filesystem/LikeC4FileSystem.js +0 -130
- package/dist/filesystem/index.d.ts +0 -55
- package/dist/filesystem/index.js +0 -29
- package/dist/formatting/LikeC4Formatter.d.ts +0 -59
- package/dist/formatting/LikeC4Formatter.js +0 -637
- package/dist/formatting/utils.d.ts +0 -6
- package/dist/formatting/utils.js +0 -18
- package/dist/generated/ast.d.ts +0 -1411
- package/dist/generated/ast.js +0 -2207
- package/dist/generated/grammar.d.ts +0 -6
- package/dist/generated/grammar.js +0 -7
- package/dist/generated/module.d.ts +0 -14
- package/dist/generated/module.js +0 -27
- package/dist/generated-lib/icons.d.ts +0 -1
- package/dist/generated-lib/icons.js +0 -18
- package/dist/index.d.ts +0 -38
- package/dist/index.js +0 -55
- package/dist/likec4lib.d.ts +0 -6
- package/dist/likec4lib.js +0 -7
- package/dist/logger.d.ts +0 -17
- package/dist/logger.js +0 -81
- package/dist/lsp/CodeActionProvider.d.ts +0 -14
- package/dist/lsp/CodeActionProvider.js +0 -33
- package/dist/lsp/CodeLensProvider.d.ts +0 -9
- package/dist/lsp/CodeLensProvider.js +0 -44
- package/dist/lsp/CompletionProvider.d.ts +0 -11
- package/dist/lsp/CompletionProvider.js +0 -200
- package/dist/lsp/DocumentHighlightProvider.d.ts +0 -9
- package/dist/lsp/DocumentHighlightProvider.js +0 -10
- package/dist/lsp/DocumentLinkProvider.d.ts +0 -11
- package/dist/lsp/DocumentLinkProvider.js +0 -58
- package/dist/lsp/DocumentSymbolProvider.d.ts +0 -33
- package/dist/lsp/DocumentSymbolProvider.js +0 -317
- package/dist/lsp/HoverProvider.d.ts +0 -10
- package/dist/lsp/HoverProvider.js +0 -106
- package/dist/lsp/RenameProvider.d.ts +0 -5
- package/dist/lsp/RenameProvider.js +0 -6
- package/dist/lsp/SemanticTokenProvider.d.ts +0 -12
- package/dist/lsp/SemanticTokenProvider.js +0 -264
- package/dist/lsp/index.d.ts +0 -8
- package/dist/lsp/index.js +0 -9
- package/dist/mcp/MCPServerFactory.d.ts +0 -8
- package/dist/mcp/MCPServerFactory.js +0 -73
- package/dist/mcp/NoopLikeC4MCPServer.d.ts +0 -9
- package/dist/mcp/NoopLikeC4MCPServer.js +0 -17
- package/dist/mcp/interfaces.d.ts +0 -13
- package/dist/mcp/interfaces.js +0 -5
- package/dist/mcp/server/StdioLikeC4MCPServer.d.ts +0 -16
- package/dist/mcp/server/StdioLikeC4MCPServer.js +0 -51
- package/dist/mcp/server/StreamableLikeC4MCPServer.d.ts +0 -16
- package/dist/mcp/server/StreamableLikeC4MCPServer.js +0 -145
- package/dist/mcp/server/WithMCPServer.d.ts +0 -4
- package/dist/mcp/server/WithMCPServer.js +0 -54
- package/dist/mcp/tools/_common.d.ts +0 -88
- package/dist/mcp/tools/_common.js +0 -49
- package/dist/mcp/tools/find-relationships.d.ts +0 -12
- package/dist/mcp/tools/find-relationships.js +0 -150
- package/dist/mcp/tools/list-projects.d.ts +0 -6
- package/dist/mcp/tools/list-projects.js +0 -62
- package/dist/mcp/tools/open-view.d.ts +0 -10
- package/dist/mcp/tools/open-view.js +0 -52
- package/dist/mcp/tools/read-deployment.d.ts +0 -10
- package/dist/mcp/tools/read-deployment.js +0 -150
- package/dist/mcp/tools/read-element.d.ts +0 -10
- package/dist/mcp/tools/read-element.js +0 -218
- package/dist/mcp/tools/read-project-summary.d.ts +0 -8
- package/dist/mcp/tools/read-project-summary.js +0 -176
- package/dist/mcp/tools/read-view.d.ts +0 -10
- package/dist/mcp/tools/read-view.js +0 -203
- package/dist/mcp/tools/search-element.d.ts +0 -8
- package/dist/mcp/tools/search-element.js +0 -177
- package/dist/mcp/utils.d.ts +0 -18
- package/dist/mcp/utils.js +0 -48
- package/dist/model/builder/MergedExtends.d.ts +0 -13
- package/dist/model/builder/MergedExtends.js +0 -74
- package/dist/model/builder/MergedSpecification.d.ts +0 -32
- package/dist/model/builder/MergedSpecification.js +0 -175
- package/dist/model/builder/buildModel.d.ts +0 -16
- package/dist/model/builder/buildModel.js +0 -245
- package/dist/model/deployments-index.d.ts +0 -10
- package/dist/model/deployments-index.js +0 -102
- package/dist/model/fqn-index.d.ts +0 -61
- package/dist/model/fqn-index.js +0 -253
- package/dist/model/index.d.ts +0 -6
- package/dist/model/index.js +0 -6
- package/dist/model/model-builder.d.ts +0 -52
- package/dist/model/model-builder.js +0 -224
- package/dist/model/model-locator.d.ts +0 -39
- package/dist/model/model-locator.js +0 -240
- package/dist/model/model-parser-where.d.ts +0 -4
- package/dist/model/model-parser-where.js +0 -81
- package/dist/model/model-parser.d.ts +0 -645
- package/dist/model/model-parser.js +0 -133
- package/dist/model/parser/Base.d.ts +0 -69
- package/dist/model/parser/Base.js +0 -372
- package/dist/model/parser/DeploymentModelParser.d.ts +0 -71
- package/dist/model/parser/DeploymentModelParser.js +0 -176
- package/dist/model/parser/DeploymentViewParser.d.ts +0 -75
- package/dist/model/parser/DeploymentViewParser.js +0 -86
- package/dist/model/parser/FqnRefParser.d.ts +0 -66
- package/dist/model/parser/FqnRefParser.js +0 -382
- package/dist/model/parser/GlobalsParser.d.ts +0 -109
- package/dist/model/parser/GlobalsParser.js +0 -84
- package/dist/model/parser/ImportsParser.d.ts +0 -46
- package/dist/model/parser/ImportsParser.js +0 -24
- package/dist/model/parser/ModelParser.d.ts +0 -71
- package/dist/model/parser/ModelParser.js +0 -209
- package/dist/model/parser/PredicatesParser.d.ts +0 -75
- package/dist/model/parser/PredicatesParser.js +0 -45
- package/dist/model/parser/SpecificationParser.d.ts +0 -53
- package/dist/model/parser/SpecificationParser.js +0 -113
- package/dist/model/parser/ValueConverter.d.ts +0 -4
- package/dist/model/parser/ValueConverter.js +0 -12
- package/dist/model/parser/ViewsParser.d.ts +0 -112
- package/dist/model/parser/ViewsParser.js +0 -492
- package/dist/model-change/ModelChanges.d.ts +0 -18
- package/dist/model-change/ModelChanges.js +0 -129
- package/dist/model-change/changeElementStyle.d.ts +0 -16
- package/dist/model-change/changeElementStyle.js +0 -134
- package/dist/model-change/changeViewLayout.d.ts +0 -12
- package/dist/model-change/changeViewLayout.js +0 -28
- package/dist/model-change/removeManualLayoutV1.d.ts +0 -7
- package/dist/model-change/removeManualLayoutV1.js +0 -27
- package/dist/module.d.ts +0 -92
- package/dist/module.js +0 -143
- package/dist/protocol.d.ts +0 -284
- package/dist/protocol.js +0 -123
- package/dist/references/index.d.ts +0 -3
- package/dist/references/index.js +0 -3
- package/dist/references/name-provider.d.ts +0 -9
- package/dist/references/name-provider.js +0 -37
- package/dist/references/scope-computation.d.ts +0 -20
- package/dist/references/scope-computation.js +0 -288
- package/dist/references/scope-provider.d.ts +0 -40
- package/dist/references/scope-provider.js +0 -239
- package/dist/shared/NodeKindProvider.d.ts +0 -15
- package/dist/shared/NodeKindProvider.js +0 -57
- package/dist/shared/WorkspaceSymbolProvider.d.ts +0 -3
- package/dist/shared/WorkspaceSymbolProvider.js +0 -3
- package/dist/shared/index.d.ts +0 -2
- package/dist/shared/index.js +0 -2
- package/dist/test/index.d.ts +0 -1
- package/dist/test/index.js +0 -1
- package/dist/test/testServices.d.ts +0 -64
- package/dist/test/testServices.js +0 -210
- package/dist/utils/disposable.d.ts +0 -8
- package/dist/utils/disposable.js +0 -26
- package/dist/utils/elementRef.d.ts +0 -11
- package/dist/utils/elementRef.js +0 -27
- package/dist/utils/fqnRef.d.ts +0 -11
- package/dist/utils/fqnRef.js +0 -63
- package/dist/utils/index.d.ts +0 -11
- package/dist/utils/index.js +0 -35
- package/dist/utils/printDocs.d.ts +0 -2
- package/dist/utils/printDocs.js +0 -1
- package/dist/utils/projectId.d.ts +0 -4
- package/dist/utils/projectId.js +0 -16
- package/dist/utils/stringHash.d.ts +0 -1
- package/dist/utils/stringHash.js +0 -5
- package/dist/validation/DocumentValidator.d.ts +0 -11
- package/dist/validation/DocumentValidator.js +0 -17
- package/dist/validation/_shared.d.ts +0 -3
- package/dist/validation/_shared.js +0 -26
- package/dist/validation/deployment-checks.d.ts +0 -7
- package/dist/validation/deployment-checks.js +0 -140
- package/dist/validation/dynamic-view.d.ts +0 -6
- package/dist/validation/dynamic-view.js +0 -67
- package/dist/validation/element-ref.d.ts +0 -4
- package/dist/validation/element-ref.js +0 -12
- package/dist/validation/element.d.ts +0 -4
- package/dist/validation/element.js +0 -49
- package/dist/validation/imports.d.ts +0 -4
- package/dist/validation/imports.js +0 -46
- package/dist/validation/index.d.ts +0 -15
- package/dist/validation/index.js +0 -167
- package/dist/validation/property-checks.d.ts +0 -7
- package/dist/validation/property-checks.js +0 -108
- package/dist/validation/relation.d.ts +0 -6
- package/dist/validation/relation.js +0 -141
- package/dist/validation/specification.d.ts +0 -12
- package/dist/validation/specification.js +0 -190
- package/dist/validation/view-checks.d.ts +0 -4
- package/dist/validation/view-checks.js +0 -46
- package/dist/validation/view-predicates/fqn-expr-with.d.ts +0 -4
- package/dist/validation/view-predicates/fqn-expr-with.js +0 -43
- package/dist/validation/view-predicates/fqn-ref-expr.d.ts +0 -4
- package/dist/validation/view-predicates/fqn-ref-expr.js +0 -51
- package/dist/validation/view-predicates/incoming.d.ts +0 -4
- package/dist/validation/view-predicates/incoming.js +0 -16
- package/dist/validation/view-predicates/index.d.ts +0 -6
- package/dist/validation/view-predicates/index.js +0 -6
- package/dist/validation/view-predicates/outgoing.d.ts +0 -4
- package/dist/validation/view-predicates/outgoing.js +0 -20
- package/dist/validation/view-predicates/relation-expr.d.ts +0 -4
- package/dist/validation/view-predicates/relation-expr.js +0 -46
- package/dist/validation/view-predicates/relation-with.d.ts +0 -4
- package/dist/validation/view-predicates/relation-with.js +0 -16
- package/dist/validation/view.d.ts +0 -4
- package/dist/validation/view.js +0 -42
- package/dist/view-utils/assignNavigateTo.d.ts +0 -2
- package/dist/view-utils/assignNavigateTo.js +0 -27
- package/dist/view-utils/index.d.ts +0 -2
- package/dist/view-utils/index.js +0 -2
- package/dist/view-utils/manual-layout.d.ts +0 -13
- package/dist/view-utils/manual-layout.js +0 -149
- package/dist/views/ConfigurableLayouter.d.ts +0 -7
- package/dist/views/ConfigurableLayouter.js +0 -51
- package/dist/views/LikeC4ManualLayouts.d.ts +0 -42
- package/dist/views/LikeC4ManualLayouts.js +0 -209
- package/dist/views/LikeC4Views.d.ts +0 -89
- package/dist/views/LikeC4Views.js +0 -216
- package/dist/views/index.d.ts +0 -4
- package/dist/views/index.js +0 -11
- package/dist/workspace/AstNodeDescriptionProvider.d.ts +0 -7
- package/dist/workspace/AstNodeDescriptionProvider.js +0 -18
- package/dist/workspace/IndexManager.d.ts +0 -10
- package/dist/workspace/IndexManager.js +0 -26
- package/dist/workspace/LangiumDocuments.d.ts +0 -25
- package/dist/workspace/LangiumDocuments.js +0 -98
- package/dist/workspace/ProjectsManager.d.ts +0 -130
- package/dist/workspace/ProjectsManager.js +0 -605
- package/dist/workspace/WorkspaceManager.d.ts +0 -31
- package/dist/workspace/WorkspaceManager.js +0 -132
- package/dist/workspace/index.d.ts +0 -5
- package/dist/workspace/index.js +0 -5
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
import type { LikeC4ProjectJsonConfig } from '@likec4/config';
|
|
2
|
-
import type { ComputedLikeC4ModelData } from '@likec4/core';
|
|
3
|
-
import { type LangiumDocument } from 'langium';
|
|
4
|
-
import type { LiteralUnion } from 'type-fest';
|
|
5
|
-
import { URI } from 'vscode-uri';
|
|
6
|
-
import type { LikeC4LangiumDocument } from '../ast';
|
|
7
|
-
export declare function createTestServices(options?: {
|
|
8
|
-
workspace?: string;
|
|
9
|
-
projectConfig?: Partial<LikeC4ProjectJsonConfig>;
|
|
10
|
-
}): {
|
|
11
|
-
services: import("langium").LangiumGeneratedCoreServices & import("langium").LangiumDefaultCoreServices & import("langium/lsp").LangiumLSPServices & import("../module").LikeC4AddedServices;
|
|
12
|
-
addDocument: (input: string, uri?: string) => Promise<LikeC4LangiumDocument>;
|
|
13
|
-
removeDocument: (doc: LangiumDocument | URI) => Promise<void>;
|
|
14
|
-
parse: (input: string, uri?: string) => Promise<LikeC4LangiumDocument>;
|
|
15
|
-
validate: (input: string | LikeC4LangiumDocument, uri?: string) => Promise<{
|
|
16
|
-
document: LikeC4LangiumDocument;
|
|
17
|
-
diagnostics: (import("vscode-languageserver-types").Diagnostic & import("langium").DiagnosticInfo<import("../ast").LikeC4AstNode>)[];
|
|
18
|
-
warnings: string[];
|
|
19
|
-
errors: string[];
|
|
20
|
-
}>;
|
|
21
|
-
validateAll: () => Promise<{
|
|
22
|
-
diagnostics: import("vscode-languageserver-types").Diagnostic[];
|
|
23
|
-
errors: string[];
|
|
24
|
-
warnings: string[];
|
|
25
|
-
}>;
|
|
26
|
-
buildModel: () => Promise<ComputedLikeC4ModelData>;
|
|
27
|
-
buildLikeC4Model: () => Promise<import("@likec4/core/model").LikeC4Model<import("@likec4/core").UnknownComputed>>;
|
|
28
|
-
resetState: () => Promise<void>;
|
|
29
|
-
format: (input: string | LikeC4LangiumDocument, uri?: string) => Promise<string>;
|
|
30
|
-
};
|
|
31
|
-
/**
|
|
32
|
-
* @example
|
|
33
|
-
* ```ts
|
|
34
|
-
* const { projects } = await createMultiProjectTestServices({
|
|
35
|
-
* project1: {
|
|
36
|
-
* doc1: `...`,
|
|
37
|
-
* doc2: `...`,
|
|
38
|
-
* },
|
|
39
|
-
* project2: {
|
|
40
|
-
* doc1: `...`,
|
|
41
|
-
* },
|
|
42
|
-
* })
|
|
43
|
-
* ```
|
|
44
|
-
*/
|
|
45
|
-
export declare function createMultiProjectTestServices<const Projects extends Record<string, Record<string, string>>>(data: Projects): Promise<{
|
|
46
|
-
services: import("langium").LangiumGeneratedCoreServices & import("langium").LangiumDefaultCoreServices & import("langium/lsp").LangiumLSPServices & import("../module").LikeC4AddedServices;
|
|
47
|
-
projects: { readonly [K in keyof Projects]: { readonly [L in keyof Projects[K]]: LikeC4LangiumDocument; }; };
|
|
48
|
-
projectsManager: import("..").ProjectsManager;
|
|
49
|
-
addDocument: (uri: string | URI, input: string) => Promise<LikeC4LangiumDocument>;
|
|
50
|
-
/**
|
|
51
|
-
* Add document outside of projects
|
|
52
|
-
*/
|
|
53
|
-
addDocumentOutside: (input: string) => Promise<LikeC4LangiumDocument>;
|
|
54
|
-
validateAll: () => Promise<{
|
|
55
|
-
diagnostics: import("vscode-languageserver-types").Diagnostic[];
|
|
56
|
-
errors: string[];
|
|
57
|
-
warnings: string[];
|
|
58
|
-
}>;
|
|
59
|
-
buildModel: (projectId: LiteralUnion<keyof Projects, string>) => Promise<ComputedLikeC4ModelData<import("@likec4/core").UnknownComputed>>;
|
|
60
|
-
buildLikeC4Model: (projectId: LiteralUnion<keyof Projects, string>) => Promise<import("@likec4/core/model").LikeC4Model<import("@likec4/core").UnknownComputed>>;
|
|
61
|
-
}>;
|
|
62
|
-
export type TestServices = ReturnType<typeof createTestServices>;
|
|
63
|
-
export type TestParseFn = TestServices['validate'];
|
|
64
|
-
export type TestValidateFn = TestServices['validate'];
|
|
@@ -1,210 +0,0 @@
|
|
|
1
|
-
import { DocumentState, TextDocument, UriUtils } from 'langium';
|
|
2
|
-
import * as assert from 'node:assert';
|
|
3
|
-
import { entries } from 'remeda';
|
|
4
|
-
import stripIndent from 'strip-indent';
|
|
5
|
-
import { DiagnosticSeverity } from 'vscode-languageserver-types';
|
|
6
|
-
import { URI, Utils } from 'vscode-uri';
|
|
7
|
-
import { NoopFileSystem } from '../filesystem';
|
|
8
|
-
import { createLanguageServices } from '../module';
|
|
9
|
-
export function createTestServices(options) {
|
|
10
|
-
const workspace = options?.workspace ?? 'file:///test/workspace';
|
|
11
|
-
const projectConfig = options?.projectConfig;
|
|
12
|
-
const services = createLanguageServices(NoopFileSystem).likec4;
|
|
13
|
-
const metaData = services.LanguageMetaData;
|
|
14
|
-
const langiumDocuments = services.shared.workspace.LangiumDocuments;
|
|
15
|
-
const documentBuilder = services.shared.workspace.DocumentBuilder;
|
|
16
|
-
const modelBuilder = services.likec4.ModelBuilder;
|
|
17
|
-
const workspaceUri = URI.parse(workspace);
|
|
18
|
-
const formatter = services.lsp.Formatter;
|
|
19
|
-
const workspaceFolder = {
|
|
20
|
-
name: projectConfig?.name || 'test-project',
|
|
21
|
-
uri: workspaceUri.toString(),
|
|
22
|
-
};
|
|
23
|
-
let isInitialized = false;
|
|
24
|
-
let documentIndex = 1;
|
|
25
|
-
async function initialize() {
|
|
26
|
-
if (isInitialized)
|
|
27
|
-
return;
|
|
28
|
-
isInitialized = true;
|
|
29
|
-
services.shared.workspace.ConfigurationProvider.updateConfiguration({
|
|
30
|
-
settings: { likec4: { formatting: { quoteStyle: 'single' } } },
|
|
31
|
-
});
|
|
32
|
-
services.shared.workspace.WorkspaceManager.initialize({
|
|
33
|
-
capabilities: {},
|
|
34
|
-
processId: null,
|
|
35
|
-
rootUri: workspaceFolder.uri,
|
|
36
|
-
workspaceFolders: [workspaceFolder],
|
|
37
|
-
});
|
|
38
|
-
await services.shared.workspace.WorkspaceManager.initializeWorkspace([workspaceFolder]);
|
|
39
|
-
// Register project with config if provided...
|
|
40
|
-
if (projectConfig) {
|
|
41
|
-
const projectFolderUri = Utils.resolvePath(workspaceUri, 'src');
|
|
42
|
-
await services.shared.workspace.ProjectsManager.registerProject({
|
|
43
|
-
config: {
|
|
44
|
-
name: projectConfig?.name || 'test-project',
|
|
45
|
-
title: projectConfig?.title || 'Test Project',
|
|
46
|
-
contactPerson: projectConfig?.contactPerson || 'Unknown',
|
|
47
|
-
imageAliases: projectConfig?.imageAliases || {},
|
|
48
|
-
exclude: projectConfig?.exclude || ['node_modules'],
|
|
49
|
-
},
|
|
50
|
-
folderUri: projectFolderUri,
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
const addDocument = async (input, uri) => {
|
|
55
|
-
await initialize();
|
|
56
|
-
const docUri = Utils.resolvePath(workspaceUri, './src/', uri ?? `${documentIndex++}${metaData.fileExtensions[0]}`);
|
|
57
|
-
const document = services.shared.workspace.LangiumDocumentFactory.fromString(stripIndent(input), docUri);
|
|
58
|
-
langiumDocuments.addDocument(document);
|
|
59
|
-
return document;
|
|
60
|
-
};
|
|
61
|
-
const removeDocument = async (doc) => {
|
|
62
|
-
const uri = doc instanceof URI ? doc : doc.uri;
|
|
63
|
-
await documentBuilder.update([], [uri]);
|
|
64
|
-
};
|
|
65
|
-
const parse = async (input, uri) => {
|
|
66
|
-
const document = await addDocument(input, uri);
|
|
67
|
-
await documentBuilder.build([document], { validation: false });
|
|
68
|
-
return document;
|
|
69
|
-
};
|
|
70
|
-
const validate = async (input, uri) => {
|
|
71
|
-
const document = typeof input === 'string' ? await addDocument(input, uri) : input;
|
|
72
|
-
await documentBuilder.build([document], { validation: true });
|
|
73
|
-
const diagnostics = document.diagnostics ?? [];
|
|
74
|
-
const warnings = diagnostics.flatMap(d => d.severity === DiagnosticSeverity.Warning ? d.message : []);
|
|
75
|
-
const errors = diagnostics.flatMap(d => d.severity === DiagnosticSeverity.Error ? d.message : []);
|
|
76
|
-
return {
|
|
77
|
-
document,
|
|
78
|
-
diagnostics,
|
|
79
|
-
warnings,
|
|
80
|
-
errors,
|
|
81
|
-
};
|
|
82
|
-
};
|
|
83
|
-
const format = async (input, uri) => {
|
|
84
|
-
const document = typeof input === 'string' ? await parse(stripIndent(input), uri) : input;
|
|
85
|
-
await documentBuilder.build([document], { validation: true });
|
|
86
|
-
const edits = await formatter?.formatDocument(document, {
|
|
87
|
-
options: { tabSize: 2, insertSpaces: true },
|
|
88
|
-
textDocument: { uri: document.uri.toString() },
|
|
89
|
-
});
|
|
90
|
-
return TextDocument.applyEdits(document.textDocument, edits ?? []);
|
|
91
|
-
};
|
|
92
|
-
const validateAll = async () => {
|
|
93
|
-
const docs = langiumDocuments.all.toArray();
|
|
94
|
-
assert.ok(docs.length > 0, 'no documents to validate');
|
|
95
|
-
await documentBuilder.build(docs, { validation: true });
|
|
96
|
-
const diagnostics = docs.flatMap(doc => doc.diagnostics ?? []);
|
|
97
|
-
const warnings = diagnostics.flatMap(d => d.severity === DiagnosticSeverity.Warning ? d.message : []);
|
|
98
|
-
const errors = diagnostics.flatMap(d => d.severity === DiagnosticSeverity.Error ? d.message : []);
|
|
99
|
-
return {
|
|
100
|
-
diagnostics,
|
|
101
|
-
errors,
|
|
102
|
-
warnings,
|
|
103
|
-
};
|
|
104
|
-
};
|
|
105
|
-
const buildModel = async () => {
|
|
106
|
-
if (langiumDocuments.all.some(doc => doc.state < DocumentState.Validated)) {
|
|
107
|
-
await validateAll();
|
|
108
|
-
}
|
|
109
|
-
const likec4model = await modelBuilder.computeModel();
|
|
110
|
-
if (!likec4model)
|
|
111
|
-
throw new Error('No model found');
|
|
112
|
-
return likec4model.$data;
|
|
113
|
-
};
|
|
114
|
-
const buildLikeC4Model = async () => {
|
|
115
|
-
if (langiumDocuments.all.some(doc => doc.state < DocumentState.Validated)) {
|
|
116
|
-
await validateAll();
|
|
117
|
-
}
|
|
118
|
-
const likec4model = await modelBuilder.computeModel();
|
|
119
|
-
if (!likec4model)
|
|
120
|
-
throw new Error('No model found');
|
|
121
|
-
return likec4model;
|
|
122
|
-
};
|
|
123
|
-
/**
|
|
124
|
-
* This will clear all documents
|
|
125
|
-
*/
|
|
126
|
-
const resetState = async () => {
|
|
127
|
-
await services.shared.workspace.WorkspaceLock.write(async (cancelToken) => {
|
|
128
|
-
const docs = langiumDocuments.allExcludingBuiltin.toArray().map(doc => doc.uri);
|
|
129
|
-
await documentBuilder.update([], docs, cancelToken);
|
|
130
|
-
});
|
|
131
|
-
};
|
|
132
|
-
return {
|
|
133
|
-
services,
|
|
134
|
-
addDocument,
|
|
135
|
-
removeDocument,
|
|
136
|
-
parse,
|
|
137
|
-
validate,
|
|
138
|
-
validateAll,
|
|
139
|
-
buildModel,
|
|
140
|
-
buildLikeC4Model,
|
|
141
|
-
resetState,
|
|
142
|
-
format,
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
/**
|
|
146
|
-
* @example
|
|
147
|
-
* ```ts
|
|
148
|
-
* const { projects } = await createMultiProjectTestServices({
|
|
149
|
-
* project1: {
|
|
150
|
-
* doc1: `...`,
|
|
151
|
-
* doc2: `...`,
|
|
152
|
-
* },
|
|
153
|
-
* project2: {
|
|
154
|
-
* doc1: `...`,
|
|
155
|
-
* },
|
|
156
|
-
* })
|
|
157
|
-
* ```
|
|
158
|
-
*/
|
|
159
|
-
export async function createMultiProjectTestServices(data) {
|
|
160
|
-
const workspace = 'file:///test/workspace';
|
|
161
|
-
const { services, addDocument, validateAll, } = createTestServices({ workspace });
|
|
162
|
-
const projects = {};
|
|
163
|
-
for (const [name, files] of entries(data)) {
|
|
164
|
-
const folderUri = UriUtils.joinPath(URI.parse(workspace), 'src', name);
|
|
165
|
-
await services.shared.workspace.ProjectsManager.registerProject({
|
|
166
|
-
config: {
|
|
167
|
-
name,
|
|
168
|
-
exclude: ['node_modules'],
|
|
169
|
-
},
|
|
170
|
-
folderUri,
|
|
171
|
-
});
|
|
172
|
-
// @ts-ignore
|
|
173
|
-
projects[name] = {};
|
|
174
|
-
for (let [docName, content] of entries(files)) {
|
|
175
|
-
const fileName = docName.endsWith('.c4') ? docName : `${docName}.c4`;
|
|
176
|
-
// @ts-ignore
|
|
177
|
-
projects[name][docName] = await addDocument(content, `${name}/${fileName}`);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
async function buildLikeC4Model(projectId) {
|
|
181
|
-
if (services.shared.workspace.LangiumDocuments.all.some(doc => doc.state < DocumentState.Validated)) {
|
|
182
|
-
await validateAll();
|
|
183
|
-
}
|
|
184
|
-
const likec4model = await services.likec4.ModelBuilder.computeModel(projectId);
|
|
185
|
-
if (!likec4model)
|
|
186
|
-
throw new Error('No model found');
|
|
187
|
-
return likec4model;
|
|
188
|
-
}
|
|
189
|
-
async function buildModel(projectId) {
|
|
190
|
-
const model = await buildLikeC4Model(projectId);
|
|
191
|
-
return model.$data;
|
|
192
|
-
}
|
|
193
|
-
return {
|
|
194
|
-
services,
|
|
195
|
-
projects,
|
|
196
|
-
projectsManager: services.shared.workspace.ProjectsManager,
|
|
197
|
-
addDocument: async (uri, input) => {
|
|
198
|
-
return await addDocument(input, uri.toString());
|
|
199
|
-
},
|
|
200
|
-
/**
|
|
201
|
-
* Add document outside of projects
|
|
202
|
-
*/
|
|
203
|
-
addDocumentOutside: async (input) => {
|
|
204
|
-
return await addDocument(input);
|
|
205
|
-
},
|
|
206
|
-
validateAll,
|
|
207
|
-
buildModel,
|
|
208
|
-
buildLikeC4Model,
|
|
209
|
-
};
|
|
210
|
-
}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import type { Disposable } from 'langium';
|
|
2
|
-
export declare abstract class ADisposable implements Disposable {
|
|
3
|
-
protected toDispose: Disposable[];
|
|
4
|
-
protected isDisposed: boolean;
|
|
5
|
-
onDispose(...disposable: Disposable[]): void;
|
|
6
|
-
dispose(): void;
|
|
7
|
-
protected throwIfDisposed(): void;
|
|
8
|
-
}
|
package/dist/utils/disposable.js
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { logWarnError } from '../logger';
|
|
2
|
-
export class ADisposable {
|
|
3
|
-
toDispose = [];
|
|
4
|
-
isDisposed = false;
|
|
5
|
-
onDispose(...disposable) {
|
|
6
|
-
this.toDispose.push(...disposable);
|
|
7
|
-
}
|
|
8
|
-
dispose() {
|
|
9
|
-
this.throwIfDisposed();
|
|
10
|
-
this.isDisposed = true;
|
|
11
|
-
let item;
|
|
12
|
-
while ((item = this.toDispose.pop())) {
|
|
13
|
-
try {
|
|
14
|
-
item.dispose();
|
|
15
|
-
}
|
|
16
|
-
catch (e) {
|
|
17
|
-
logWarnError(e);
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
throwIfDisposed() {
|
|
22
|
-
if (this.isDisposed) {
|
|
23
|
-
throw new Error('This has already been disposed');
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type * as c4 from '@likec4/core';
|
|
2
|
-
import { ast } from '../ast';
|
|
3
|
-
/**
|
|
4
|
-
* Returns referenced AST Element
|
|
5
|
-
*/
|
|
6
|
-
export declare function elementRef(node: ast.ElementRef | ast.StrictFqnElementRef): ast.Element | undefined;
|
|
7
|
-
/**
|
|
8
|
-
* Returns FQN of StrictFqnElementRef
|
|
9
|
-
* a.b.c.d - for c node returns a.b.c
|
|
10
|
-
*/
|
|
11
|
-
export declare function readStrictFqn(node: ast.StrictFqnElementRef | ast.StrictFqnRef): c4.Fqn;
|
package/dist/utils/elementRef.js
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { ast } from '../ast';
|
|
2
|
-
/**
|
|
3
|
-
* Returns referenced AST Element
|
|
4
|
-
*/
|
|
5
|
-
export function elementRef(node) {
|
|
6
|
-
let el = ast.isStrictFqnElementRef(node) ? node.el.ref : node.modelElement.value.ref;
|
|
7
|
-
if (el?.$type === 'Imported') {
|
|
8
|
-
el = el.imported.ref;
|
|
9
|
-
}
|
|
10
|
-
return el?.$type === 'Element' ? el : undefined;
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Returns FQN of StrictFqnElementRef
|
|
14
|
-
* a.b.c.d - for c node returns a.b.c
|
|
15
|
-
*/
|
|
16
|
-
export function readStrictFqn(node) {
|
|
17
|
-
const name = [node.$type === 'StrictFqnRef' ? node.value.$refText : node.el.$refText];
|
|
18
|
-
let parent = node.parent;
|
|
19
|
-
while (parent) {
|
|
20
|
-
name.push(parent.$type === 'StrictFqnRef' ? parent.value.$refText : parent.el.$refText);
|
|
21
|
-
parent = parent.parent;
|
|
22
|
-
}
|
|
23
|
-
if (name.length === 1) {
|
|
24
|
-
return name[0];
|
|
25
|
-
}
|
|
26
|
-
return name.reverse().join('.');
|
|
27
|
-
}
|
package/dist/utils/fqnRef.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { ast } from '../ast';
|
|
2
|
-
export declare function referenceableParent(node: ast.FqnRef): ast.Referenceable | null;
|
|
3
|
-
export declare function instanceRef(deploymentRef: ast.FqnRef): ast.DeployedInstance | null;
|
|
4
|
-
export declare function deploymentNodeRef(deploymentRef: ast.FqnRef): ast.DeploymentNode | null;
|
|
5
|
-
export declare function importsRef(node: ast.FqnRef): ast.Imported | null;
|
|
6
|
-
export declare function isImportsRef(node: ast.FqnRef): boolean;
|
|
7
|
-
export declare function isReferenceToLogicalModel(node: ast.FqnRef): boolean;
|
|
8
|
-
/**
|
|
9
|
-
* Returns true if node references deployment model
|
|
10
|
-
*/
|
|
11
|
-
export declare function isReferenceToDeploymentModel(node: ast.FqnRef): boolean;
|
package/dist/utils/fqnRef.js
DELETED
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
import { AstUtils } from 'langium';
|
|
2
|
-
import { isNullish } from 'remeda';
|
|
3
|
-
import { ast } from '../ast';
|
|
4
|
-
export function referenceableParent(node) {
|
|
5
|
-
// iterate up the root parent
|
|
6
|
-
while (node.parent) {
|
|
7
|
-
node = node.parent;
|
|
8
|
-
}
|
|
9
|
-
return node.value.ref ?? null;
|
|
10
|
-
}
|
|
11
|
-
export function instanceRef(deploymentRef) {
|
|
12
|
-
let referenceable;
|
|
13
|
-
while ((referenceable = deploymentRef.value?.ref)) {
|
|
14
|
-
if (ast.isDeploymentNode(referenceable)) {
|
|
15
|
-
return null;
|
|
16
|
-
}
|
|
17
|
-
if (ast.isDeployedInstance(referenceable)) {
|
|
18
|
-
return referenceable;
|
|
19
|
-
}
|
|
20
|
-
if (isNullish(deploymentRef.parent)) {
|
|
21
|
-
return null;
|
|
22
|
-
}
|
|
23
|
-
deploymentRef = deploymentRef.parent;
|
|
24
|
-
}
|
|
25
|
-
return null;
|
|
26
|
-
}
|
|
27
|
-
export function deploymentNodeRef(deploymentRef) {
|
|
28
|
-
let referenceable = deploymentRef.value.ref ?? null;
|
|
29
|
-
if (!referenceable || ast.isDeploymentNode(referenceable)) {
|
|
30
|
-
return referenceable;
|
|
31
|
-
}
|
|
32
|
-
const artifact = instanceRef(deploymentRef);
|
|
33
|
-
// Because path in deploymentRef may be omitted,
|
|
34
|
-
// we find artifact first and then its container
|
|
35
|
-
return artifact ? AstUtils.getContainerOfType(artifact, ast.isDeploymentNode) ?? null : null;
|
|
36
|
-
}
|
|
37
|
-
export function importsRef(node) {
|
|
38
|
-
const referenceable = referenceableParent(node);
|
|
39
|
-
return referenceable?.$type === 'Imported' ? referenceable : null;
|
|
40
|
-
}
|
|
41
|
-
export function isImportsRef(node) {
|
|
42
|
-
return !!importsRef(node);
|
|
43
|
-
}
|
|
44
|
-
export function isReferenceToLogicalModel(node) {
|
|
45
|
-
const referenceable = referenceableParent(node);
|
|
46
|
-
return referenceable?.$type === 'Element';
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Returns true if node references deployment model
|
|
50
|
-
*/
|
|
51
|
-
export function isReferenceToDeploymentModel(node) {
|
|
52
|
-
let referenceable;
|
|
53
|
-
while ((referenceable = node.value?.ref)) {
|
|
54
|
-
if (ast.isDeploymentElement(referenceable)) {
|
|
55
|
-
return true;
|
|
56
|
-
}
|
|
57
|
-
if (isNullish(node.parent)) {
|
|
58
|
-
return false;
|
|
59
|
-
}
|
|
60
|
-
node = node.parent;
|
|
61
|
-
}
|
|
62
|
-
return false;
|
|
63
|
-
}
|
package/dist/utils/index.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export * from './disposable';
|
|
2
|
-
export * from './elementRef';
|
|
3
|
-
export * from './fqnRef';
|
|
4
|
-
export * from './projectId';
|
|
5
|
-
export * from './stringHash';
|
|
6
|
-
export declare function safeCall<T>(fn: () => T): T | undefined;
|
|
7
|
-
export declare function performanceNow(): number;
|
|
8
|
-
export declare function performanceMark(): {
|
|
9
|
-
readonly ms: number;
|
|
10
|
-
readonly pretty: string;
|
|
11
|
-
};
|
package/dist/utils/index.js
DELETED
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import prettyMs from 'pretty-ms';
|
|
2
|
-
import { logger } from '../logger';
|
|
3
|
-
export * from './disposable';
|
|
4
|
-
export * from './elementRef';
|
|
5
|
-
export * from './fqnRef';
|
|
6
|
-
export * from './projectId';
|
|
7
|
-
export * from './stringHash';
|
|
8
|
-
export function safeCall(fn) {
|
|
9
|
-
try {
|
|
10
|
-
return fn();
|
|
11
|
-
}
|
|
12
|
-
catch (e) {
|
|
13
|
-
logger.debug(`Safe call failed`, { error: e });
|
|
14
|
-
return undefined;
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
export function performanceNow() {
|
|
18
|
-
try {
|
|
19
|
-
return performance.now();
|
|
20
|
-
}
|
|
21
|
-
catch {
|
|
22
|
-
return Date.now();
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
export function performanceMark() {
|
|
26
|
-
const t0 = performanceNow();
|
|
27
|
-
return {
|
|
28
|
-
get ms() {
|
|
29
|
-
return performanceNow() - t0;
|
|
30
|
-
},
|
|
31
|
-
get pretty() {
|
|
32
|
-
return prettyMs(performanceNow() - t0);
|
|
33
|
-
},
|
|
34
|
-
};
|
|
35
|
-
}
|
package/dist/utils/printDocs.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export const printDocs = (docs) => docs.map(d => ' - ' + d.uri.toString(true)).join('\n');
|
package/dist/utils/projectId.js
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { invariant, nonNullable } from '@likec4/core';
|
|
2
|
-
import { AstUtils, isAstNode } from 'langium';
|
|
3
|
-
import { ast } from '../ast';
|
|
4
|
-
export function projectIdFrom(value) {
|
|
5
|
-
if (ast.isImported(value)) {
|
|
6
|
-
while (value.$type === 'Imported' && value.$container) {
|
|
7
|
-
value = value.$container;
|
|
8
|
-
}
|
|
9
|
-
invariant(ast.isImportsFromPoject(value));
|
|
10
|
-
}
|
|
11
|
-
if (ast.isImportsFromPoject(value)) {
|
|
12
|
-
return value.project;
|
|
13
|
-
}
|
|
14
|
-
const doc = isAstNode(value) ? AstUtils.getDocument(value) : value;
|
|
15
|
-
return nonNullable(doc.likec4ProjectId, () => `Invalid state, document ${doc.uri} has no project ID assigned`);
|
|
16
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function stringHash(...str: [string, ...string[]]): string;
|
package/dist/utils/stringHash.js
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { type LangiumDocument, type ValidationOptions, Cancellation, DefaultDocumentValidator } from 'langium';
|
|
2
|
-
import type { Diagnostic } from 'vscode-languageserver-types';
|
|
3
|
-
import type { LikeC4Services } from '../module';
|
|
4
|
-
export declare class LikeC4DocumentValidator extends DefaultDocumentValidator {
|
|
5
|
-
protected services: LikeC4Services;
|
|
6
|
-
constructor(services: LikeC4Services);
|
|
7
|
-
/**
|
|
8
|
-
* If the document is excluded, then we skip validation and return an empty array of diagnostics.
|
|
9
|
-
*/
|
|
10
|
-
validateDocument(document: LangiumDocument, options?: ValidationOptions, cancelToken?: Cancellation.CancellationToken): Promise<Diagnostic[]>;
|
|
11
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { Cancellation, DefaultDocumentValidator } from 'langium';
|
|
2
|
-
export class LikeC4DocumentValidator extends DefaultDocumentValidator {
|
|
3
|
-
services;
|
|
4
|
-
constructor(services) {
|
|
5
|
-
super(services);
|
|
6
|
-
this.services = services;
|
|
7
|
-
}
|
|
8
|
-
/**
|
|
9
|
-
* If the document is excluded, then we skip validation and return an empty array of diagnostics.
|
|
10
|
-
*/
|
|
11
|
-
async validateDocument(document, options, cancelToken) {
|
|
12
|
-
if (this.services.shared.workspace.ProjectsManager.isExcluded(document)) {
|
|
13
|
-
return [];
|
|
14
|
-
}
|
|
15
|
-
return await super.validateDocument(document, options, cancelToken);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { isPromise } from 'remeda';
|
|
2
|
-
import { logger } from '../logger';
|
|
3
|
-
export const RESERVED_WORDS = [
|
|
4
|
-
'this',
|
|
5
|
-
'it',
|
|
6
|
-
'self',
|
|
7
|
-
'super',
|
|
8
|
-
'likec4lib',
|
|
9
|
-
'global',
|
|
10
|
-
];
|
|
11
|
-
export function tryOrLog(fn) {
|
|
12
|
-
return async function tryOrLogFn(node, accept, cancelToken) {
|
|
13
|
-
try {
|
|
14
|
-
const result = fn(node, accept, cancelToken);
|
|
15
|
-
if (isPromise(result)) {
|
|
16
|
-
await result;
|
|
17
|
-
}
|
|
18
|
-
return;
|
|
19
|
-
}
|
|
20
|
-
catch (e) {
|
|
21
|
-
const message = e instanceof Error ? e.message : String(e);
|
|
22
|
-
accept('error', `Validation failed: ${message}`, { node });
|
|
23
|
-
logger.debug(`Validation failed: ${message}`, { error: e });
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { type ValidationCheck } from 'langium';
|
|
2
|
-
import { ast } from '../ast';
|
|
3
|
-
import type { LikeC4Services } from '../module';
|
|
4
|
-
export declare const deploymentNodeChecks: (services: LikeC4Services) => ValidationCheck<ast.DeploymentNode>;
|
|
5
|
-
export declare const deployedInstanceChecks: (services: LikeC4Services) => ValidationCheck<ast.DeployedInstance>;
|
|
6
|
-
export declare const deploymentRelationChecks: (services: LikeC4Services) => ValidationCheck<ast.DeploymentRelation>;
|
|
7
|
-
export declare const extendDeploymentChecks: (_services: LikeC4Services) => ValidationCheck<ast.ExtendDeployment>;
|